- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章IOS自定义UIButton九宫格效果由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
此篇文章给大家描写如何写自定义九宫格,因为在开发中,这种需求也是常见不少。因此,主要利用UIButton阐述的; 。
实列不复杂,就两三个步骤完成:
1、定义宽度与高度(self.view) 。
1
2
3
4
5
|
#define SCREEN_WIDTH [UIScreen mainScreen].bounds.size.width
#define SCREEN_HEIGHT [UIScreen mainScreen].bounds.size.height
#define JHRGB(r,g,b) [UIColor colorWithRed:(r/255.0) green:(g/255.0) blue:(b/255.0) alpha:1.0]
#define JHRandomColor JHRGB(arc4random_uniform(255), arc4random_uniform(255), arc4random_uniform(255))
|
2、定义九宫格的文字与图片 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
@property (nonatomic, strong) NSArray * titlesArr;
@property (nonatomic, strong) UILabel * numberLab;
@property (nonatomic, strong) NSArray * titleimg;
-(NSArray *)titlesArr{
if
(!_titlesArr) {
_titlesArr = @[@
"首页"
,@
"采购"
,@
"文章"
,@
"社区"
,@
"服务"
,@
"扫描"
,@
"定位"
,@
"售后"
,@
"订单"
];
}
return
_titlesArr;
}
-(NSArray *)titleimg{
if
(!_titleimg) {
_titleimg = @[@
"me"
,@
"msg"
,@
"meg"
,@
"1"
,@
"2"
,@
"3"
,@
"me"
,@
"2"
,@
"3"
];
}
return
_titleimg;
}
|
3、循环出9个UIBtton数据,以及相关样式动态调整 。
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
|
-(
void
)setButton{
NSInteger totalLoc = 3;
//一列三个数
CGFloat W = 50;
//宽度
CGFloat H = W;
//高度
CGFloat margin=(self.view.frame.size.width-totalLoc * W)/(totalLoc+1);
for
(NSInteger i = 0; i < self.titlesArr.count; i++) {
//循环体
UIButton * btn = [UIButton buttonWithType:UIButtonTypeCustom];
//button的定义
btn.frame = CGRectMake(100, 100, 80, 80);
//button大小
[btn setTitle:self.titlesArr[i] forState:UIControlStateNormal];
//动态设置button文本
[btn setBackgroundImage:[UIImage imageNamed:self.titleimg[i]] forState:UIControlStateNormal];
//动态设置图片
[btn setTitleColor:[UIColor darkGrayColor] forState:0];
//文本的颜色
[btn setImageEdgeInsets:UIEdgeInsetsMake(5, 25, 45, 25)];
//图片的大小
[btn setTitleEdgeInsets:UIEdgeInsetsMake(80, 0, 5, 0)];
//文本的位置
//btn.backgroundColor = [UIColor blueColor];
/*计算frame*/
NSInteger row = i / totalLoc;
//行号
NSInteger loc = i % totalLoc;
//列号
//0/3=0,1/3=0,2/3=0,3/3=1;
//0%3=0,1%3=1,2%3=2,3%3=0;
CGFloat X= margin + (margin + W) * loc;
CGFloat Y= margin + (margin + H) * row;
btn.frame = CGRectMake(X, Y, W, H);
//设置tag值(这里的tag,只是为了让button的每次点击都有不同的动画效果)
btn.tag = i;
[btn addTarget:self action:@selector(clickBtn:) forControlEvents:UIControlEventTouchUpInside];
[self.lgView.imgview addSubview:btn];
}
}
|
4、点击按钮的事件监听 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
-(
void
)clickBtn:(UIButton *)btn{
NSString *stringInt = [NSString stringWithFormat:@
"%ld"
,(
long
)btn.tag];
btn.layer.transform = CATransform3DMakeScale(0.5*arc4random_uniform([stringInt floatValue]), 0.5*arc4random_uniform([stringInt floatValue]), 1);
self.numberLab.text = btn.titleLabel.text;
NSLog(@
"%@wo dian ji l:"
,stringInt);
[UIView animateWithDuration:0.5 animations:^{
btn.layer.transform = CATransform3DMakeScale(1, 1, 1);
}];
}
|
总结:
如下逻辑分析:
1.上面用的是masonry布局,所以我的view容器就没用宽度,高度(写在我的view层里了)。 2.先定义一个View容器 3.在容器里,循环体里面定义button,设置button的属性等。 4.定义相关的数组,如:(文本,图片) 5.点击按钮事件触发函数; 。
就以上信息需要理解的逻辑,把上面的复制粘贴就可以,项目亲测可以的.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://blog.csdn.net/qq_37523448/article/details/94577131 。
最后此篇关于IOS自定义UIButton九宫格效果的文章就讲到这里了,如果你想了解更多关于IOS自定义UIButton九宫格效果的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我可以使用 javascript 和其他所有东西,但在重新发明轮子之前,我想知道是否已经有一个类似的 jquery 插件,因为我想使用那个框架而不是 mootools。 我没有钱的问题,特别是 5 欧
我正在 React 应用程序中处理动画。我需要动画在悬停 后开始工作。我尝试了 :hover:after css 但不起作用。将鼠标悬停在图像上后动画可以工作,但我需要在悬停后开始。将鼠标悬停在图像上
我正在使用 jQuery 在按钮单击时实现 slider 效果。我的代码是: $(document).ready(function() { $("#mybutton").click(functio
我需要一个div标签在屏幕右侧滑出,如何使用jQuery获得这种效果?我一直在看这里:http://api.jquery.com/category/effects/sliding/而且这似乎不是我要找
我正在使用此代码实现页面 curl 效果......它在模拟器和设备中工作正常......但它不是(setType:@“pageCurl”)苹果记录的api,这导致它被iPhone拒绝App Stor
我见过各种关于 WPF 效果的引用,但它们似乎是针对位图的,而不是针对文本的。是否可以将除模糊或投影以外的效果应用于XAML中的TextBlock对象? 我想要做的示例可能是轮廓笔划,或斜角/浮雕效果
我见过各种关于 WPF 效果的引用,但它们似乎是针对位图的,而不是针对文本的。是否可以将除模糊或投影以外的效果应用于XAML中的TextBlock对象? 我想要做的示例可能是轮廓笔划,或斜角/浮雕效果
我正在尝试模拟这种效果:http://meyerweb.com/eric/css/edge/complexspiral/demo.html在我的博客上:http://segment6.blogspot
我尝试将样式应用到 Accordion Pane ,但遇到了问题。 这行不通。 accordion.setEffect(new DropShadow(BlurType.ONE_PASS_BOX, Co
关于 Datatables website 的教程足够清楚了: 在我告诉 Datatables 我正在谈论哪一列后,我只需将切换按钮放入: column.visible( ! column.visib
我正在寻找 scratchOut 效果,随便叫它什么。 这是从前景中删除图像的效果,因此背景图像变得可见。 我曾尝试使用 jquery 插件重新创建此效果,但它并不像我希望的那样流畅。 有没有人有这种
本文实例讲述了android实现文字和图片混排(文字环绕图片)效果。分享给大家供大家参考,具体如下: 在平时我们做项目中,或许有要对一张图片或者某一个东西进行文字和图片说明,这时候要求排版美观,所
本文实例讲述了Javafx简单实现【我的电脑资源管理器】效果。分享给大家供大家参考。具体如下: 1. java代码: ?
我是 ngrx 的新手,正在尝试让我的 ngrx 商店的 @Effect 函数正常工作。下面的代码显示了如果我没有使用 ngrx 商店,服务是如何工作的。我首先调用 http.get 来获取列表,然后
基本上我搜索了很多,解决方案建议应用一些 PNG 掩码或不提供所需的解决方案。 我发现了什么。 ffmpeg -i main.mkv -i facecloseup.mkv -filter_compl
有关使用从商店中选择的状态的效果的 Ngrx 文档状态(没有双关语意) Note: For performance reasons, use a flattening operator like co
我有一个数据网格控件,我在其中使用名为 FastShadow 的自定义效果,它就像一个光晕。 我希望效果在其边界之外发光,这样很好,但是当我在顶部绘制另一个形状时,我不希望这个形状受到影响。在本例中,
除了子 div.exception 中的所有内容,我想将 div.main 中的所有文本设为灰色。 div.exception 应该看起来好像类 main 从未添加到父 div。 这可能吗?如果是这样
我有一个 PDF 文件,我想重现此包页面中的页面 curl 效果: https://pub.flutter-io.cn/packages/page_turn 我试过用这个 page_turn插件,它需
我想测试一个效果如下: 如果调度了 LoadEntriesSucces 操作,则效果开始 等待 5 秒 5 秒后发送 http 请求 当响应到达时,将分派(dispatch)新的操作(取决于响应是成功
我是一名优秀的程序员,十分优秀!