一,使用UIScrollView 与其他View 布局不同的地方在于,

ScrollView的高度/宽度不固定;

ScrollView的高度和宽度由其内容决定(即 Scroll View 的 contentSize 所决定);

内容的大小不能依赖于Scrollview;

二,网上使用Xib/StoryBoard的做法太多,自行百度就是。

如何使用Masonry实现UIScrollView,参考见:

Masonry介绍与使用实践:快速上手Autolayout

做法:1,新建一个container  View, 其他子View都添加到container View上。

    _bottomChannelsView = [[UIScrollView  alloc]init];
[_bottomChannelsView setScrollEnabled:YES];
//_bottomChannelsView.scrollEnabled = YES;
[self addSubview:_bottomChannelsView]; container = [UIView new];
[_bottomChannelsView addSubview:container];

2,设置布局方法:

需要注意的是,container View的subView的constraints都必须依赖container,依赖scrollview和其他的view都不能达到想要的效果。

-(void)setBottomLayout
{
if (self.bottomView.count<=) {
return;
} WS(ws); [_bottomChannelsView mas_remakeConstraints:^(MASConstraintMaker *make) {
make.left.and.right.and.bottom.mas_equalTo(ws);
make.top.mas_equalTo(_topChannelsView.mas_bottom);
// make.left.and.right.mas_equalTo(ws);
}]; [container mas_remakeConstraints:^(MASConstraintMaker *make) {
make.edges.equalTo(_bottomChannelsView);
make.width.equalTo(_bottomChannelsView);
}];
[moreText mas_remakeConstraints:^(MASConstraintMaker *make) {
make.right.equalTo(container);
make.left.equalTo(container).with.offset();
make.top.equalTo(container.mas_top).with.offset();
make.height.mas_equalTo(@);
}]; //排底部channelItem CGFloat itemWidth =((kScreenWidth - )-*/)/; ChannelListItem *firstItem = (ChannelListItem *)self.bottomView[];
firstItem.hidden = NO;
[firstItem mas_remakeConstraints:^(MASConstraintMaker *make) {
make.top.equalTo(moreText.mas_bottom).with.offset();
make.left.equalTo(container.mas_left).with.offset();
make.width.equalTo(@(itemWidth));
make.height.equalTo(@);
//第一排离superview是15 vpadding
}]; ChannelListItem *lastItem = firstItem;
ChannelListItem *item ;
for (int i = ; i<self.bottomView.count; i++) {
item = (ChannelListItem *)self.bottomView[i]; [item mas_remakeConstraints:^(MASConstraintMaker *make) {
make.height.and.width.equalTo(firstItem); }]; if (i%==) {
[item mas_updateConstraints:^(MASConstraintMaker *make) {
make.left.equalTo(container.mas_left).offset(); }]; firstItem = item;
}else
{
[item mas_updateConstraints:^(MASConstraintMaker *make) {
make.left.equalTo(lastItem.mas_right).offset(); //约束冲突
make.top.mas_equalTo(firstItem);
}]; }
if(i<)
{
[item mas_updateConstraints:^(MASConstraintMaker *make) {
// make.top.equalTo(_topChannelsView.mas_top).offset(15); //第一排离superview是15 vpadding
make.top.equalTo(firstItem);
}];
}else if(i%==) {
[item mas_updateConstraints:^(MASConstraintMaker *make) {
make.top.equalTo(lastItem.mas_bottom).offset(); //非第一排
// make.top.equalTo(firstItem.mas_top);
}]; }
else {
[item mas_updateConstraints:^(MASConstraintMaker *make) {
make.top.equalTo(firstItem);
}];
}
lastItem = item;
} [container mas_makeConstraints:^(MASConstraintMaker *make) {
make.bottom.equalTo(item.mas_bottom).with.offset(20
);
}];
}

效果差不多是这样:

不尽完美,欢迎指正。感谢!

用Maonry如何实现UIScrollView的更多相关文章

  1. 【原】Masonry+UIScrollView的使用注意事项

    [原]Masonry+UIScrollView的使用注意事项 本文转载请注明出处 —— polobymulberry-博客园 1.问题描述 我想实现的使用在一个UIScrollView依次添加三个UI ...

  2. UIScrollView的封装

    UIScrollView的封装 效果 特点 1.用法简单,尺寸大小,随意设置位置 2.可以有多个数据源的数据,可以定制不通的界面(如同上图,一个有文字,一个没有文字) 3.能够实现点击事件 用法 1. ...

  3. UI第十七节——UIScrollView

    // 实例化一个ScrollView    UIScrollView *scrollView = [[UIScrollView alloc] initWithFrame:[[UIScreen main ...

  4. UI控件(UIScrollView)

    @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; //创建一个scrollview UIScrollV ...

  5. UIScrollView的delaysContentTouches与canCencelContentTouches属性

    UIScrollView有一个BOOL类型的tracking属性,用来返回用户是否已经触及内容并打算开始滚动,我们从这个属性开始探究UIScrollView的工作原理: 当手指触摸到UIScrollV ...

  6. iOS 视图:重绘与UIScrollView(内容根据iOS编程编写)

    我们继续之前的 Hypnosister 应用,当用户开始触摸的时候,圆形的颜色会改变. 首先,在 JXHypnosisView 头文件中声明一个属性,用来表示圆形的颜色. #import " ...

  7. 学习笔记之-------UIScrollView 基本用法 代理使用

    //contentSize.contentInset和contentOffset 是 scrollView三个基本的属性. // 滚动 self.ScrollView.contentSize =sel ...

  8. iOS UIScrollView的使用

    一.为什么要用UIScrollView? 移动设备的屏幕大小是极其有限的,因此直接展示在用户眼前的内容也相当有限当展示的内容较多,超出一个屏幕时,用户可通过滚动手势来查看屏幕以外的内容普通的UIVie ...

  9. iOS之UIScrollView循环滚动

    #import "ViewController.h" #define SCREEN_WIDTH [UIScreen mainScreen].bounds.size.width #d ...

随机推荐

  1. eclipse key

    让我们按照使用频率来看看我最爱用的一些热键组合.(注:以下内容在Eclipse3.02及一上版本通过测试) . Control-Shift-T: 打开类型(Open type).如果你不是有意磨洋工, ...

  2. java将数组中的零放到末尾

    package com.shb.java; /** * 将数组中的0放到数组的后边,然后原来的非零数的顺序不改变 * @author BIN * */ public class Demo2{ publ ...

  3. oracle的会话(session)

    会话(session)是oracle服务器对数据库连接用户记录的一种手段. oracle提供了v_$session的视图存储当前数据库的会话,查询时用v_$session 或v$session sql ...

  4. [php] PHPStorm8 for Yincart project

    PHPStorm8 license for Yincart project: https://github.com/yinheark/yincart2 User Name: Yincart ===== ...

  5. :root

    概述 选择该文档的根元素. 在HTML中,文档的根元素,和$(":root")选择的元素一样, 永远是<html>元素. 示例 设置<html>背景颜色为黄 ...

  6. 在CentOS 6 32/64 上安装 PPTP 方式 VPN 服务

    网上有很多步骤, 讲了很多步骤,废话, 其实不如直接看代码, 而且也能直接运行,快速安装: rm -f /etc/pptpd.conf rm -f /etc/ppp arch=`uname -m` # ...

  7. uploadify3.2.1加载时,报NetworkError 404 Not Found或NetworkError forbidden错误

    我用的uploadify的版本是3.2.1 在打开配置了uploadify的页面的时候,什么操作都没有,仅仅是打开了页面,在火狐里可以看到一行报错信息,我的uploadify页面 在"/项目 ...

  8. resultMap / resultType

    ===================resultMap:实体类的属性和通过resultMap映射后的property属性一致 <resultMap id="workerSelect& ...

  9. 【python cookbook】【字符串与文本】4.文本模式的匹配和查找

    问题:按照特定的文本模式进行匹配或查找 解决方法: 1.简单的文字匹配,只需使用str.find().str.startswith().str.endswith()或类似的函数即可: 2.复杂的匹配, ...

  10. [转]ConsumeContainerWhitespace property to remove blank space in SSRS 2008 report

    转自:http://beyondrelational.com/modules/2/blogs/115/posts/11153/consumecontainerwhitespace-property-t ...