此篇文章给大家描写如何写自定义九宫格,因为在开发中,这种需求也是常见不少。因此,主要利用UIButton阐述的;
实列不复杂,就两三个步骤完成:
一、定义宽度与高度(self.view)
#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))
二、定义九宫格的文字与图片
@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; }
三、循环出9个UIBtton数据,以及相关样式动态调整
-(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
四、点击按钮的事件监听
-(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.点击按钮事件触发函数;
就以上信息需要理解的逻辑,把上面的复制粘贴就可以,项目亲测可以的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。