经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » iOS » 查看文章
使用Masonry对UIScrollView自动布局
来源:cnblogs  作者:路人Q  时间:2019/3/21 8:47:40  对本文有异议

之前使用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的约束其实都是一样的,记住即可

 


水平方向

  1. UIScrollView *horizontalScrollView = [[UIScrollView alloc] init];
  2. horizontalScrollView.backgroundColor = [UIColor orangeColor];
  3. horizontalScrollView.pagingEnabled =YES;
  4. // 添加scrollView添加到父视图,并设置其约束
  5. [self.view addSubview:horizontalScrollView];
  6. [horizontalScrollView mas_makeConstraints:^(MASConstraintMaker *make) {
  7. make.top.and.left.mas_equalTo(10);
  8. make.right.mas_equalTo(-10);
  9. make.height.mas_equalTo(100);
  10. }];
  11. // 创建过渡视图并设置contentSize和其约束
  12. UIView *horizontalContainerView = [[UIView alloc] init];
  13. [horizontalScrollView addSubview:horizontalContainerView];
  14. [horizontalContainerView mas_makeConstraints:^(MASConstraintMaker *make) {
  15. make.edges.equalTo(horizontalScrollView);
  16. make.height.equalTo(horizontalScrollView);#//水平滚动高度固定,这个很重要
  17. }];
  18. //过渡视图上添加子视图
  19. UIView *previousView =nil;
  20. for (int i =0; i <10; i++) {
  21. UILabel *label = [[UILabelalloc]init];
  22. label.textAlignment =NSTextAlignmentCenter;
  23. label.backgroundColor = [UIColorcolorWithHue:(arc4random() %256 / 256.0)
  24. saturation:(arc4random() %128 /256.0) +0.5
  25. brightness:(arc4random() %128 /256.0) +0.5
  26. alpha:1];
  27. label.text = [NSStringstringWithFormat:@"第 %d个视图", i];
  28. //添加到过渡视图,并设置子视图的约束
  29. [horizontalContainerView addSubview:label];
  30. [label mas_makeConstraints:^(MASConstraintMaker *make) {
  31. make.top.and.bottom.equalTo(horizontalContainerView);
  32. make.width.equalTo(horizontalScrollView);
  33. if (previousView) {
  34. make.left.mas_equalTo(previousView.mas_right);
  35. }
  36. else {
  37. make.left.mas_equalTo(0);
  38. }
  39. }];
  40. previousView = label;
  41. }
  42. #// 设置过渡视图的右距(此设置将影响到scrollView的contentSize)这个也是关键的一步
  43. [horizontalContainerView mas_makeConstraints:^(MASConstraintMaker *make) {
  44. make.right.mas_equalTo(previousView.mas_right);
  45. }];

 

垂直平方向

  1. UIScrollView *verticalScrollView = [[UIScrollView alloc] init];
  2. verticalScrollView.backgroundColor = [UIColor greenColor];
  3. verticalScrollView.pagingEnabled =YES;
  4. // 添加scrollView添加到父视图,并设置其约束
  5. [self.view addSubview:verticalScrollView];
  6. [verticalScrollView mas_makeConstraints:^(MASConstraintMaker *make) {
  7. make.left.mas_equalTo(10);
  8. make.bottom.and.right.mas_equalTo(-10.0);
  9. make.height.mas_equalTo(100);
  10. }];
  11. // 设置scrollView的子视图,即过渡视图contentSize,并设置其约束
  12. UIView *verticalContainerView = [[UIView alloc] init];
  13. [verticalScrollView addSubview:verticalContainerView];
  14. [verticalContainerView mas_makeConstraints:^(MASConstraintMaker *make) {
  15. make.top.left.bottom.and.right.equalTo(verticalScrollView);
  16. make.width.equalTo(verticalScrollView);#//垂直滚动宽度固定,这个很重要
  17. }];
  18. //过渡视图添加子视图
  19. UIView *lastView =nil;
  20. for (NSInteger index =0; index <10; index++) {
  21. UILabel *label = [[UILabelalloc]init];
  22. label.textAlignment =NSTextAlignmentCenter;
  23. label.backgroundColor = [UIColorcolorWithHue:(arc4random() %256 / 256.0)
  24. saturation:(arc4random() %128 /256.0) +0.5
  25. brightness:(arc4random() %128 /256.0) +0.5
  26. alpha:1];
  27. label.text = [NSStringstringWithFormat:@"第 %ld个视图", index];
  28. //添加到过渡视图,并设置子视图的约束
  29. [verticalContainerView addSubview:label];
  30. [label mas_makeConstraints:^(MASConstraintMaker *make) {
  31. make.left.and.right.equalTo(verticalContainerView);
  32. make.height.mas_equalTo(verticalScrollView.mas_height);
  33. if (lastView) {
  34. make.top.mas_equalTo(lastView.mas_bottom);
  35. }
  36. else {
  37. make.top.mas_equalTo(0);
  38. }
  39. }];
  40. lastView = label;
  41. }
  42. #// 设置过渡视图的底边距(此设置将影响到scrollView的contentSize)这个也是关键的一步
  43. [verticalContainerView mas_makeConstraints:^(MASConstraintMaker *make) {
  44. make.bottom.equalTo(lastView.mas_bottom);
  45. }];

 

xib对UIScrollerView的布局可以参考下面的文章
https://www.jianshu.com/p/1d3bb3cf7ee5
https://blog.csdn.net/dreams_deng/article/details/80523485

 

原文链接:http://www.cnblogs.com/lurenq/p/10567098.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号