- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章iOS实现自定义购物车角标显示购物数量(添加商品时角标抖动 Vie)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
前言:
适用场景:商城类的 app 。将自定义的购物车 view 设置为 navigationitem 的导航栏按钮。效果图如下:
图1、右上角的购物车即是我们定义的view 。
实现原理:
1、利用 navigationitem 可以将 uiview 设置为导航栏的按钮; 。
2、将一个 uibutton 和 一个 uilabel 添加到一个 uiview 上。然后将这个 uiview 设置为 navigationitem 的右侧按钮;3、uilabel 控件的动画效果.
具体实现代码如下: 。
1、shopcarview.h 文件 。
1
2
3
4
5
6
7
8
9
10
|
#import
@protocol shopcarbuttondelegate <</span>nsobject>
// 代理的方法,在此方法内,完成按钮的点击事件。
- (
void
)shopcarbuttonclickaction;
@end
@interfaceshopcarview : uiview
@property (nonatomic, assign)id<</span>shopcarbuttondelegate> delegate;
// 为购物车设置角标内数值
- (
void
)setshopcarcount:(nsstring *)count;
@end
|
2、shopcarview.m 文件 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
#import
"shopcarview.h"
@interfaceshopcarview()
@property (nonatomic, strong)uibutton *carbutton;
@property (nonatomic, strong)uilabel *countlabel;
@end
@implementation shopcarview
- (instancetype)initwithframe:(cgrect)frame{
cgrect myframe = cgrectmake(0, 0, 40, 40);
self = [superinitwithframe:myframe];
if
(self) {
[selfaddsubview:self.carbutton];
}
returnself;
}
- (uibutton *)carbutton{
if
(!_carbutton) {
_carbutton = [uibuttonbuttonwithtype:uibuttontypecustom];
_carbutton.frame = cgrectmake(0, 8, 32, 32);
[_carbuttonsetimage:[uiimageimagenamed:@
"购物1"
] forstate:uicontrolstatenormal];
[_carbuttonaddtarget:selfaction:@selector(shopcarbuttonaction) forcontrolevents:uicontroleventtouchupinside];
}
return_carbutton;
}
- (uilabel *)countlabel{
if
(!_countlabel) {
_countlabel = [[uilabelalloc] initwithframe:cgrectmake(24, 5, 16, 16)];
_countlabel.backgroundcolor = [uicolorredcolor];
_countlabel.textalignment = nstextalignmentcenter;
_countlabel.textcolor = [uicolorwhitecolor];
_countlabel.layer.cornerradius = 8;
_countlabel.font = [uifontsystemfontofsize:12];
_countlabel.layer.maskstobounds = yes;
[selfaddsubview:_countlabel];
}
return_countlabel;
}
// 为购物车设置角标内数值
- (
void
)setshopcarcount:(nsstring *)count{
if
([count integervalue] == 0) {
if
(_countlabel) {
[_countlabelremovefromsuperview];
_countlabel = nil;
}
return
;
}
if
([count integervalue] > 9) {
self.countlabel.text = @
"9+"
;
}
else
{
self.countlabel.text = count;
}
[selfshakeview:_countlabel];
}
// 实现的代理方法
- (
void
)shopcarbuttonaction{
[self.delegateshopcarbuttonclickaction];
}
// 实现抖动效果
-(
void
)shakeview:(uiview*)viewtoshake
{
cgfloat t =2.0;
cgaffinetransform translateright =cgaffinetransformtranslate(cgaffinetransformidentity, t,0.0);
cgaffinetransform translateleft =cgaffinetransformtranslate(cgaffinetransformidentity,-t,0.0);
viewtoshake.transform = translateleft;
[uiviewanimatewithduration:0.07delay:0.0options:uiviewanimationoptionautoreverse|uiviewanimationoptionrepeatanimations:^{
[uiviewsetanimationrepeatcount:2.0];
viewtoshake.transform = translateright;
} completion:^(
bool
finished){
if
(finished){
[uiviewanimatewithduration:0.05delay:0.0options:uiviewanimationoptionbeginfromcurrentstateanimations:^{
viewtoshake.transform =cgaffinetransformidentity;
} completion:null];
}
}];
}
@end
|
代码很简单,逻辑也比较清晰。使用代理方法,将自定义的 view 的属性隐藏起来,打到很好的封装效果.
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持我! 。
原文链接:http://blog.sina.com.cn/s/blog_13d30a6170102wa46.html 。
最后此篇关于iOS实现自定义购物车角标显示购物数量(添加商品时角标抖动 Vie)的文章就讲到这里了,如果你想了解更多关于iOS实现自定义购物车角标显示购物数量(添加商品时角标抖动 Vie)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我创建了一个用户可以添加测试的字段。这一切运行顺利我只希望当用户点击(添加另一个测试)然后上一个(添加另一个测试)删除并且这个显示在新字段中。 所有运行良好的唯一问题是点击(添加另一个字段)之前添加另
String[] option = {"Adlawan", "Angeles", "Arreza", "Benenoso", "Bermas", "Brebant
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在努力将 jQuery 滚动功能添加到 nav-tab (Bootstrap 3)。我希望用户能够选择他们想要的选项卡,并在选项卡内容中有一个可以平滑滚动到 anchor 的链接。这是我的代码,可
我正在尝试在用户登录后再添加 2 个 ui 选项卡。首先,我尝试做一个之后。 $('#slideshow').tabs('remove', '4'); $("#slideshow ul li:last
我有一个包含选择元素的表单,我想通过选择添加和删除其中一些元素。这是html代码(这里也有jsfiddle http://jsfiddle.net/txhajy2w/):
正在写这个: view.backgroundColor = UIColor.white.withAlphaComponent(0.9) 等同于: view.backgroundColor = UICo
好的,如果其中有任何信息,我想将这些列添加到一起。所以说我有 账户 1 2 3 . 有 4 个帐户空间,但只有 3 个帐户。我如何创建 java 脚本来添加它。 最佳答案 Live Example H
我想知道是否有一种有效的预制算法来确定一组数字的和/差是否可以等于不同的数字。示例: 5、8、10、2,使用 + 或 - 等于 9。5 - 8 = -3 + 10 = 7 + 2 = 9 如果有一个预
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我的 Oracle SQL 查询如下- Q1- select hca.account_number, hca.attribute3, SUM(rcl.extended_amou
我正在阅读 http://developer.apple.com/iphone/library/documentation/iPhone/Conceptual/iPhoneOSProgrammingG
我正在尝试添加一个“加载更多”按钮并限制下面的结果,这样投资组合页面中就不会同时加载 1000 个内容,如下所示:http://typesetdesign.com/portfolio/ 我对 PHP
我遇到这个问题,我添加了 8 个文本框,它工作正常,但是当我添加更多文本框(如 16 个文本框)时,它不会添加最后一个文本框。有人遇到过这个问题吗?提前致谢。 Live Link: JAVASCRIP
add/remove clone first row default not delete 添加/删除克隆第一行默认不删除&并获取正确的SrNo(例如:添加3行并在看到问题后删除SrNo.2)
我编码this ,但删除按钮不起作用。我在控制台中没有任何错误.. var counter = 0; var dataList = document.getElementById('materi
我有一个类似数组的对象: [1:数组[10]、2:数组[2]、3:数组[2]、4:数组[2]、5:数组[3]、6:数组[1]] 我正在尝试删除前两个元素,执行一些操作,然后将它们再次插入到同一位置。
使用的 Delphi 版本:2007 你好, 我有一个 Tecord 数组 TInfo = Record Name : String; Price : Integer; end; var Info
我使用了基本的 gridster 代码,然后我声明了通过按钮添加和删除小部件的函数它工作正常但是当我将调整大小功能添加到上面的代码中时,它都不起作用(我的意思是调整大小,添加和删除小部件) 我的js代
title 323 323 323 title 323 323 323 title 323 323 323 JS $(document).keydown(function(e){
我是一名优秀的程序员,十分优秀!