使用Masonry对UIScrollView自动布局
程序员文章站
2022-03-13 09:13:46
之前使用Masonry对UIScrollView进行过约束,当时是遇到了问题的,怎么约束都不对,因为赶进度直接改用frame了也没有对问题深究。就这样过了很久.........,直到前一段换工作的时候面试官问到,使用Masonry对UIScrollView自动布局应该注意些什么?额....,犹豫了一 ......
之前使用masonry对uiscrollview进行过约束,当时是遇到了问题的,怎么约束都不对,因为赶进度直接改用frame了也没有对问题深究。就这样过了很久.........,直到前一段换工作的时候面试官问到,使用masonry对uiscrollview自动布局应该注意些什么?额....,犹豫了一段时间我只能搪塞说我一般都是用frame进行设置的,暂时没有遇到什么问题。虽然这么回答也没什么,但是感觉终归不是很好。出来混迟早是要还的!刚好最近公司不忙,想起了这个问题,那么就研究记录一下吧!
对uiscrollview的约束有很多方式,我只讲其中一种易懂、直观的方式
uiscrollview约束的关键是设置它的contentsize的大小,否则无法进行滚动显示。
给uiscrollview添加一个过渡视图containerview,这个containerview作为所有子控件的父视图,然后再设置containerview相对于uiscrollview的约束constraint和子控件相对于containerview的约束constraint。
最后再将最后一个子视图的右边距,或底边距设置成containerview的右边距,或底边距,以此来设置scrollview的contentsize在水平方向,或垂直方向的大小。
uiscrollview竖向滑动时,就把containerview的width固定
uiscrollview横向滑动时,就把containerview的height固定
如果看完上面的描述还没有明白,那直接看下面的代码,uiscrollview的约束其实都是一样的,记住即可
水平方向
uiscrollview *horizontalscrollview = [[uiscrollview alloc] init]; horizontalscrollview.backgroundcolor = [uicolor orangecolor]; horizontalscrollview.pagingenabled =yes; // 添加scrollview添加到父视图,并设置其约束 [self.view addsubview:horizontalscrollview]; [horizontalscrollview mas_makeconstraints:^(masconstraintmaker *make) { make.top.and.left.mas_equalto(10); make.right.mas_equalto(-10); make.height.mas_equalto(100); }]; // 创建过渡视图并设置contentsize和其约束 uiview *horizontalcontainerview = [[uiview alloc] init]; [horizontalscrollview addsubview:horizontalcontainerview]; [horizontalcontainerview mas_makeconstraints:^(masconstraintmaker *make) { make.edges.equalto(horizontalscrollview); make.height.equalto(horizontalscrollview);#//水平滚动高度固定,这个很重要 }]; //过渡视图上添加子视图 uiview *previousview =nil; for (int i =0; i <10; i++) { uilabel *label = [[uilabelalloc]init]; label.textalignment =nstextalignmentcenter; label.backgroundcolor = [uicolorcolorwithhue:(arc4random() %256 / 256.0) saturation:(arc4random() %128 /256.0) +0.5 brightness:(arc4random() %128 /256.0) +0.5 alpha:1]; label.text = [nsstringstringwithformat:@"第 %d个视图", i]; //添加到过渡视图,并设置子视图的约束 [horizontalcontainerview addsubview:label]; [label mas_makeconstraints:^(masconstraintmaker *make) { make.top.and.bottom.equalto(horizontalcontainerview); make.width.equalto(horizontalscrollview); if (previousview) { make.left.mas_equalto(previousview.mas_right); } else { make.left.mas_equalto(0); } }]; previousview = label; } #// 设置过渡视图的右距(此设置将影响到scrollview的contentsize)这个也是关键的一步 [horizontalcontainerview mas_makeconstraints:^(masconstraintmaker *make) { make.right.mas_equalto(previousview.mas_right); }];
垂直平方向
uiscrollview *verticalscrollview = [[uiscrollview alloc] init]; verticalscrollview.backgroundcolor = [uicolor greencolor]; verticalscrollview.pagingenabled =yes; // 添加scrollview添加到父视图,并设置其约束 [self.view addsubview:verticalscrollview]; [verticalscrollview mas_makeconstraints:^(masconstraintmaker *make) { make.left.mas_equalto(10); make.bottom.and.right.mas_equalto(-10.0); make.height.mas_equalto(100); }]; // 设置scrollview的子视图,即过渡视图contentsize,并设置其约束 uiview *verticalcontainerview = [[uiview alloc] init]; [verticalscrollview addsubview:verticalcontainerview]; [verticalcontainerview mas_makeconstraints:^(masconstraintmaker *make) { make.top.left.bottom.and.right.equalto(verticalscrollview); make.width.equalto(verticalscrollview);#//垂直滚动宽度固定,这个很重要 }]; //过渡视图添加子视图 uiview *lastview =nil; for (nsinteger index =0; index <10; index++) { uilabel *label = [[uilabelalloc]init]; label.textalignment =nstextalignmentcenter; label.backgroundcolor = [uicolorcolorwithhue:(arc4random() %256 / 256.0) saturation:(arc4random() %128 /256.0) +0.5 brightness:(arc4random() %128 /256.0) +0.5 alpha:1]; label.text = [nsstringstringwithformat:@"第 %ld个视图", index]; //添加到过渡视图,并设置子视图的约束 [verticalcontainerview addsubview:label]; [label mas_makeconstraints:^(masconstraintmaker *make) { make.left.and.right.equalto(verticalcontainerview); make.height.mas_equalto(verticalscrollview.mas_height); if (lastview) { make.top.mas_equalto(lastview.mas_bottom); } else { make.top.mas_equalto(0); } }]; lastview = label; } #// 设置过渡视图的底边距(此设置将影响到scrollview的contentsize)这个也是关键的一步 [verticalcontainerview mas_makeconstraints:^(masconstraintmaker *make) { make.bottom.equalto(lastview.mas_bottom); }];
xib对uiscrollerview的布局可以参考下面的文章
推荐阅读
-
jQuery Masonry瀑布流布局神器使用详解
-
iOS 自动布局框架 – Masonry 详解
-
使用shell脚本每天对MySQL多个数据库自动备份的讲解
-
如何使用Playwright对Java API实现自动视觉测试
-
使用第三方《UITableView+FDTemplateLayoutCell》自动计算UITableViewCell高度(Masonry约束)
-
VS2015怎么使用表格对页面进行布局?
-
自动布局之autoresizingMask使用详解(Storyboard&Code)
-
如何使用appium对高版本的ios手机进行自动化
-
使用Masonry对UIScrollView自动布局
-
使用Rider中搭建specflow+xunit+selenium对web页面进行自动化功能测试环境