for循环创建UIButton,如何去修改边框颜色
2016-06-06 15:10
344 查看
看一下效果图,类似于淘宝加入购物车,我用的是UIButton
颜色颜色Button和型号一样:
1.创建UIButton
for (int i = 0; i < 6; i++) {
self.selectColorBtn = [UIButton buttonWithType:UIButtonTypeCustom];
if (i > 4) {
self.selectColorBtn.frame = CGRectMake(70 * widthScale + 60 * widthScale * (i-5) , 50 * widthScale, 50 * widthScale, 30 *widthScale);
}else{
self.selectColorBtn.frame = CGRectMake(70 * widthScale + 60 * widthScale * i , 10 * widthScale, 50 * widthScale, 30 *widthScale);
}
[self.selectColorBtn setTitle:@"暗灰色" forState:UIControlStateNormal];
[self.selectColorBtn setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
self.selectColorBtn.tag = 100 + i;
self.selectColorBtn.titleLabel.font = [UIFont systemFontOfSize:15 * widthScale];
[self.selectColorBtn.layer setBorderWidth:1.0];
[self.selectColorBtn.layer setBorderColor:[gray CGColor]];
[self.selectColorBtn addTarget:self action:@selector(selectColorAction:) forControlEvents:UIControlEventTouchUpInside];
[self.twoView addSubview:self.selectColorBtn];
}
2.按钮点击事件
- (void)selectColorAction:(UIButton *)btn{
//将Button颜色全部修改为灰色
for (int i = 0; i < 6; i++) {
//通过tag值获取UIbutton
UIButton *btn = (UIButton *)[self.twoView viewWithTag:100 + i];
[btn.layer setBorderColor:[gray CGColor]];
}
//获取当前UIButton
UIButton *nowBtn = btn;
switch (btn.tag) {
case 100:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
case 101:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
case 102:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
case 103:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
case 104:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
case 105:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
default:
break;
}
颜色颜色Button和型号一样:
1.创建UIButton
for (int i = 0; i < 6; i++) {
self.selectColorBtn = [UIButton buttonWithType:UIButtonTypeCustom];
if (i > 4) {
self.selectColorBtn.frame = CGRectMake(70 * widthScale + 60 * widthScale * (i-5) , 50 * widthScale, 50 * widthScale, 30 *widthScale);
}else{
self.selectColorBtn.frame = CGRectMake(70 * widthScale + 60 * widthScale * i , 10 * widthScale, 50 * widthScale, 30 *widthScale);
}
[self.selectColorBtn setTitle:@"暗灰色" forState:UIControlStateNormal];
[self.selectColorBtn setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
self.selectColorBtn.tag = 100 + i;
self.selectColorBtn.titleLabel.font = [UIFont systemFontOfSize:15 * widthScale];
[self.selectColorBtn.layer setBorderWidth:1.0];
[self.selectColorBtn.layer setBorderColor:[gray CGColor]];
[self.selectColorBtn addTarget:self action:@selector(selectColorAction:) forControlEvents:UIControlEventTouchUpInside];
[self.twoView addSubview:self.selectColorBtn];
}
2.按钮点击事件
- (void)selectColorAction:(UIButton *)btn{
//将Button颜色全部修改为灰色
for (int i = 0; i < 6; i++) {
//通过tag值获取UIbutton
UIButton *btn = (UIButton *)[self.twoView viewWithTag:100 + i];
[btn.layer setBorderColor:[gray CGColor]];
}
//获取当前UIButton
UIButton *nowBtn = btn;
switch (btn.tag) {
case 100:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
case 101:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
case 102:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
case 103:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
case 104:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
case 105:
[nowBtn.layer setBorderColor:[ThemeColors CGColor]];
break;
default:
break;
}
相关文章推荐
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- 不可修补的 iOS 漏洞可能导致 iPhone 4s 到 iPhone X 永久越狱
- iOS 12.4 系统遭黑客破解,漏洞危及数百万用户
- 每日安全资讯:NSO,一家专业入侵 iPhone 的神秘公司
- [转][源代码]Comex公布JailbreakMe 3.0源代码
- 讲解iOS开发中基本的定位功能实现
- iOS中定位当前位置坐标及转换为火星坐标的方法
- js判断客户端是iOS还是Android等移动终端的方法
- iOS应用开发中AFNetworking库的常用HTTP操作方法小结
- iOS应用中UISearchDisplayController搜索效果的用法
- IOS开发环境windows化攻略
- iOS应用中UITableView左滑自定义选项及批量删除的实现
- iOS中UIAlertView警告框组件的使用教程
- 浅析iOS应用开发中线程间的通信与线程安全问题
- 检测iOS设备是否越狱的方法
- .net平台推送ios消息的实现方法
- 探讨Android与iOS,我们将何去何从?
- Android、iOS和Windows Phone中的推送技术详解