用Maonry如何实现UIScrollView
一,使用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的更多相关文章
- 【原】Masonry+UIScrollView的使用注意事项
[原]Masonry+UIScrollView的使用注意事项 本文转载请注明出处 —— polobymulberry-博客园 1.问题描述 我想实现的使用在一个UIScrollView依次添加三个UI ...
- UIScrollView的封装
UIScrollView的封装 效果 特点 1.用法简单,尺寸大小,随意设置位置 2.可以有多个数据源的数据,可以定制不通的界面(如同上图,一个有文字,一个没有文字) 3.能够实现点击事件 用法 1. ...
- UI第十七节——UIScrollView
// 实例化一个ScrollView UIScrollView *scrollView = [[UIScrollView alloc] initWithFrame:[[UIScreen main ...
- UI控件(UIScrollView)
@implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; //创建一个scrollview UIScrollV ...
- UIScrollView的delaysContentTouches与canCencelContentTouches属性
UIScrollView有一个BOOL类型的tracking属性,用来返回用户是否已经触及内容并打算开始滚动,我们从这个属性开始探究UIScrollView的工作原理: 当手指触摸到UIScrollV ...
- iOS 视图:重绘与UIScrollView(内容根据iOS编程编写)
我们继续之前的 Hypnosister 应用,当用户开始触摸的时候,圆形的颜色会改变. 首先,在 JXHypnosisView 头文件中声明一个属性,用来表示圆形的颜色. #import " ...
- 学习笔记之-------UIScrollView 基本用法 代理使用
//contentSize.contentInset和contentOffset 是 scrollView三个基本的属性. // 滚动 self.ScrollView.contentSize =sel ...
- iOS UIScrollView的使用
一.为什么要用UIScrollView? 移动设备的屏幕大小是极其有限的,因此直接展示在用户眼前的内容也相当有限当展示的内容较多,超出一个屏幕时,用户可通过滚动手势来查看屏幕以外的内容普通的UIVie ...
- iOS之UIScrollView循环滚动
#import "ViewController.h" #define SCREEN_WIDTH [UIScreen mainScreen].bounds.size.width #d ...
随机推荐
- 技术总监和CTO的区别 浅谈CTO的作用----软件公司如何开源节流(一)[转]
我一直在思考软件公司如何开源节流.当然,老板也在思考开源节流.当然,老板思考的开源节流在公司运营层面上,而我作为CTO,我考虑的则是在产品运营角度上来思考这个问题.否则,一个软件公司,它的生存与发展就 ...
- 在 mysql 中利用 Duplicate key, 一句话实现存在的更新不存在插入功能
mysql 中可以用一个sql命令实现在插入时,如果发现唯一索引重复的记录则自动改为更新语句, 语句如下: '; 注意,radcheck 表中 username 和 attribute 列是个组合的唯 ...
- 前后台数据传输两种方式:servlet、Controller
1.Servlet: 1.1从jsp页面跳转到Servlet控制器中,通过request.getParameter()来获取参数. 1.2// 把注册成功的用户对象保存在session中 ...
- Linux程序存储结构与进程结构堆和栈的区别【转】
转自:http://www.hongkevip.com/caozuoxitong/Unix_Linux/24581.html 红客VIP(http://www.hongkevip.com):Linux ...
- FTPS加密上传
公司要求ftp接口不能以明文方式传输,所以adc系统将增加ftps方式 但是在网找了很多方式都无法实现用了方法一 FtpWebRequest request = (FtpWebRequest)WebR ...
- Linux环境变量的修改(永久,暂时)以及修改ls显示的时间格式
本文转自:http://blog.sina.com.cn/s/blog_8e21864f01014u9h.html Linux修改环境变量,很简单但很重要 一.Linux的变量种类 按变量的生存周期来 ...
- weblogic .NoClassDefFoundError: Could not initialize class sun.awt.X11Graphi
这个是常见问题,可以通过增加Weblogic的启动参数来解决: -Djava.awt.headless=true 你可以修改 startWebLogic.sh 文件. export JAVA_OPTI ...
- 20145227《Java程序设计》第10周学习总结
20145227<Java程序设计>第10周学习总结 教材学习内容总结 网络编程 就是在两个或两个以上的设备(例如计算机)之间传输数据.程序员所作的事情就是把数据发送到指定的位置,或者接收 ...
- css中transition的使用以及:before:after的使用(小样式)
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- SlickGrid example 3: 可编辑单元
<button onclick="grid.setOptions({autoEdit:true})"> 设置自动辅助编辑下一个元素. 代码: <!DOCTYP ...