Masonry 九宫格方式排列

今天项目有用到九宫格方式排列,就记录一下。

效果图

代码如下:


CGFloat gridWidth = 80;//格子的宽度
   CGFloat gridHeight = 30;//格子的高度
   NSInteger rowNumber = 3;//每行几个
   //间距x,y
   CGFloat marginX = ([UIScreen mainScreen].bounds.size.width - gridWidth * rowNumber) / (rowNumber + 1);
   CGFloat marginY = 20;
   for ( int  i = 0; i < 12 ; i++) {
       
       UIView *subv = [[UIView alloc] init];
       [self.view addSubview:subv];
       subv.backgroundColor = [UIColor colorWithHue:( arc4random() % 256 / 256.0 )
                                         saturation:( arc4random() % 128 / 256.0 ) + 0.5
                                         brightness:( arc4random() % 128 / 256.0 ) + 0.5
                                              alpha:1];
       
       [subv mas_makeConstraints:^(MASConstraintMaker *make){
           make.left.mas_equalTo(marginX + i % rowNumber * (gridWidth + marginX));
           make.top.mas_equalTo(marginY + i / rowNumber * (gridHeight + marginY));
           make.width.mas_equalTo(gridWidth);
           make.height.mas_equalTo(gridHeight);
       }];
   }

希望对新手朋友有点帮助,有问题可以留言。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,046评论 25 709
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 14,194评论 4 61
  • 呼,写字也看心情。 脑袋里面蹦出来的西乱的词句。
    简小取阅读 1,833评论 16 3
  • 这是琳姐送给我们的一本书。 谢谢琳姐么么哒~ 《一生的计划》 建立自己的成功体系: 1.成功的定义是:事先设立的、...
    是一溪云儿阅读 3,240评论 0 0
  • 生活有些改变,从让儿子参加萨提亚成长夏令营开始。事先没有告诉儿子和老公,偷偷的报了名,交了钱,逼了自己一...
    何小一i阅读 1,839评论 3 1