15-UIKit(view布局、Autoresizing)
目录:
1. 纯代码布局
纯代码布局分VC下和V下
[MX1-layout-code]
在VC下覆盖viewDidLayoutSubviews方法,在方法中写布局,一般会把要布局的控件拉成属性
当界面大小发生改变时(竖屏变横屏, 出现工具栏或各种bar....), 调用此方法。注意这个方法在运行之后就会调用,只是在界面发生变化后会再次调用,最终的布局在这里起作用。
此方法的调用在Storyboard布局后。
注意关掉AutoLayout
1.1 计算坐标
1> 两个按钮等宽
2> ImageView:
上下左右永远保持70, 50, 20, 20
3>三个小按钮(20x20), 永远保持在右下角:
// 当界面大小发生改变时(竖屏变横屏, 出现工具栏或各种bar....), 调用此方法。注意这个方法在运行之后就会调用,只是在界面发生变化后会再次调用。
-(void)viewDidLayoutSubviews{
[super viewDidLayoutSubviews];
// NSLog(@"11111");
CGRect frame = self.button1.frame;
CGFloat buttonWidth = (self.view.bounds.size.width - * - ) / ;
frame.size.width = buttonWidth;
self.button1.frame = frame;
frame.origin.x += buttonWidth + ;
self.button2.frame = frame;
frame = CGRectZero;
frame.origin = CGPointMake(, );
frame.size = CGSizeMake(self.view.bounds.size.width - - , self.view.bounds.size.height - - );
self.imageView.frame = frame;
frame.size = CGSizeMake(, );
frame.origin.x = self.view.bounds.size.width - - - - * ;
frame.origin.y = self.view.bounds.size.height - - ;
self.btn1.frame = frame;
frame.origin.x = self.view.bounds.size.width - - - * ;
self.btn2.frame = frame;
frame.origin.x = self.view.bounds.size.width - - ;
self.btn3.frame = frame;
NSLog(@"调用了viewDidLayoutSubviews方法");
}
1.2 各种Bar的影响
[MX2-Bar-Code]
从iOS7开始,任何一个VC类都拥有两个属性:
.topLayoutGuide
.bottomLayoutGuide
这两属性保存了VC上面和下面各种Bar所占用的空间。
这两属性都是遵守了UILayoutSupport协议的对象,此协议规定了一个属性:length, 用来表示Bar所占的空间。
一般的,这两属性用于VC渗透到上下各种Bar下面的情况下,计算Bar所占用的空间
可以在Xcode中设置VC不渗透到Bar下面去(在第四个检查器勾掉under bottom bars)。此时.topLayoutGuide和.bottomLayoutGuider的length都为0.
所以,不管VC是否渗透到Bar的下面,坐标上都加入这两属性是没错的。
补充:
可以设置VC属性:
.edgesForExtendedLayout = ….
来设置VC是否渗透到Bar下面
-(void)viewDidLayoutSubviews{
[super viewDidLayoutSubviews];
// 上下都不渗透延伸
self.edgesForExtendedLayout = UIRectEdgeNone;
CGRect frame = self.button.frame;
frame.origin.x = self.view.bounds.size.width - - frame.size.width;
frame.origin.y = ;// 因为在该视图的第三个检查器设置关掉了使用top bars
self.button.frame = frame;
}
1.3 自己绘制的图形
当界面大小发生变化,自动绘制的图形也会有布局问题。
[MX3-Redraw]
view视图有一个属性:contentMode,这个属性决定着当view的大小改变时,做出什么反应。
默认是Scale To Fill 左右上下全拉伸
如果ImageView 一般会选择Aspect Fit /Aspect Fill
如果是自定义的绘制图形,应该设置成Redraw, 这样,当view大小发生改变时,会重绘图形。
// 设置该view的mode为Redraw,那么当界面发生变化时会重新调用这个进行重绘
- (void)drawRect:(CGRect)rect
{
// Drawing code
CGContextRef context = UIGraphicsGetCurrentContext();
CGContextSaveGState(context);
UIBezierPath *path = [UIBezierPath bezierPath];
[path moveToPoint:CGPointMake(, )];
[path addLineToPoint:CGPointMake(, )];
[path addLineToPoint:CGPointMake(, )];
[path closePath];
[[UIColor redColor] setStroke];
[path stroke];
CGContextRestoreGState(context);
}
2. 在View中进行代码布局
2.1 View类中有一个方法:layoutSubviews, 给view中所有子view布局。
当视图的大小改变时,以下三个方法会被自动依次调用
1> VC: viewWillLayoutSubviews
2> V: layoutSubviews
3> VC: viewDidLayoutSubviews
View:
drawRect: 绘制 setNeedsDisplay
layoutSubviews: 布局 setNeedsLayout
[MX4-ViewLayout] 自定义一个视图(Cell) 用代码进行布局
// 当界面大小改变时或setNeedsLayout调用此方法,这是手动布局,注意关掉自动布局
-(void)layoutSubviews{
[super layoutSubviews];
CGFloat x = self.downLoadedIcon.frame.origin.x;
if (self.music.downloaded) {
x += ;
}
CGRect frame;
if (self.music.highQuality) {
frame = self.highQualityIcon.frame;
frame.origin.x = x;
self.highQualityIcon.frame = frame;
x += ;
}
frame = self.subLabel.frame;
frame.origin.x = x;
self.subLabel.frame = frame;
}
3. Autoresizing
3.1 什么是Autoresizing
是老的布局技术,以前叫spring/struct布局
操作简单, 功能有限,现在依然有效
还可以和AutoLayout技术一起使用。
3.2 工作原理
根据父视图的变化,按父视图变化的比例改变子视图的大小,或者其他计算式来确定子视图的frame.
3.3 怎么用
[MX5-Autoresizing]
外边四条红线约束子视图离边界的间距
里边的两条线用来指示子视图是否可以随父视图的变化而伸缩
[MX6-Autoresizing]
3.4 和代码结合使用
如果Autoresizing技术无法满足需求时,可以用代码补充
3.5 用纯代码方式使用Autoresizing
每个视图都有一个属性:autoresizingMask, 用来描述Autoresizing的设置
- (void)viewDidLoad
{
[super viewDidLoad]; self.button.autoresizingMask = UIViewAutoresizingFlexibleLeftMargin | UIViewAutoresizingFlexibleBottomMargin | UIViewAutoresizingFlexibleWidth;
}
附:
OC语言中的枚举定义常见用法:
typedef NS_OPTIONS(NSUInteger, UIViewAutoresizing) {
UIViewAutoresizingNone = 0, //0
UIViewAutoresizingFlexibleLeftMargin = 1 << 0, //1
UIViewAutoresizingFlexibleWidth = 1 << 1, //2
UIViewAutoresizingFlexibleRightMargin = 1 << 2, //4
UIViewAutoresizingFlexibleTopMargin = 1 << 3, //8
UIViewAutoresizingFlexibleHeight = 1 << 4, //16
UIViewAutoresizingFlexibleBottomMargin = 1 << 5 //32
};
1 << 1 :
0000 0001 << 1 : 0000 0010 (2)
1 << 2 :
0000 0001 << 2 : 0000 0100 (4)
UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleRightMargin | UIViewAutoresizingFlexibleHeight
0000 0010
0000 0100
0001 0000
-------------
0001 0110 6
作业:
1. 参考H01资源包, 实现播放界面,用代码布局
2. 图片涂鸦
参考PhotoDraw项目
15-UIKit(view布局、Autoresizing)的更多相关文章
- iOS系列译文:自定义Collection View布局
原文出处: Ole Begemann 译文出处: 黄爱武(@answer-huang).欢迎加入技术翻译小组. UICollectionView在iOS6中第一次被介绍,也是UIKit视图类中的一 ...
- IOS UIView 03- 自定义 Collection View 布局
注:本人是翻译过来,并且加上本人的一点见解. 前言 UICollectionView 在 iOS6 中第一次被引入,也是 UIKit 视图类中的一颗新星.它和 UITableView 共享一套 API ...
- 自定义 Collection View 布局
自定义 Collection View 布局 answer-huang 29 Mar 2014 分享文章 UICollectionView 在 iOS6 中第一次被引入,也是 UIKit 视图类中的一 ...
- 自定义Collection View布局
转自answer-huang的博客 原文出自:Custom Collection View Layouts UICollectionView在iOS6中第一次被介绍,也是UIKit视图类中的一颗 ...
- Android View框架总结(五)View布局流程之Layout
转载请注明出处:http://blog.csdn.net/hejjunlin/article/details/52216195 View树的Layout流程 View的Layout时序图 View布局 ...
- Android View框架总结(四)View布局流程之Measure
View树的measure流程 View的measures时序图 View布局流程之measure measure过程 View的measure过程 ViewGroup的measure过程 Frame ...
- Android GUI之View布局
在清楚了View绘制机制中的第一步测量之后,我们继续来了解分析View绘制的第二个过程,那就是布局定位.继续跟踪分析源码,根据之前的流程分析我们知道View的绘制是从RootViewImpl的perf ...
- 转载:微信小程序view布局
https://www.cnblogs.com/sun8134/p/6395947.html
- Android 在程序中动态添加 View 布局或控件
有时我们需要在程序中动态添加布局或控件等,下面用程序来展示一下相应的方法: 1.addView 添加View到布局容器 2.removeView 在布局容器中删掉已有的View 3.LayoutPar ...
随机推荐
- Spark学习体系
底理解Spark,能够分为以下几个层次. 1 Spark基础篇 1.1 Spark生态和安装部署 在安装过程中,理解其基本操作步骤. 安装部署 Spark安装简单介绍 Spark的源代码编译 Spar ...
- HDU Computer Transformation1041 题解
Problem Description A sequence consisting of one digit, the number 1 is initially written into a com ...
- if语句判断身高体重是否标准
1.判断身高,体重是否标准 Console.WriteLine("请输入您的身高:"); int sg = Convert.ToInt32(Console.ReadLine()); ...
- Redis初始化配置及增删改查
package com.calc.tools import redis.clients.jedis.JedisPool import redis.clients.jedis.Jedis import ...
- jacksonall的使用,解析json
转自:http://www.cnblogs.com/lee0oo0/archive/2012/08/23/2652751.html , Jackson可以轻松的将Java对象转换成json对象和xml ...
- Android 开发笔记 “广播组件使用”
在Activity中,注册广播的一个Demo. 总共分3步 第一步:定义一个BroadcastReceiver广播接收类: private BroadcastReceiver mBroadcastRe ...
- geoserver图层属性查询及查询结果转换为arcgis js api能使用的格式
一个项目使用了ArcGIS JS API开发GIS展示层,但GIS服务使用了Geoserver,这时加载Geoserver数据和查询数据就和之前完全不一样了,以下介绍下我使用ArcGIS JS API ...
- 《算法导论》读书笔记之排序算法—Merge Sort 归并排序算法
自从打ACM以来也算是用归并排序了好久,现在就写一篇博客来介绍一下这个算法吧 :) 图片来自维基百科,显示了完整的归并排序过程.例如数组{38, 27, 43, 3, 9, 82, 10}. 在算法导 ...
- chrome developer tool 调试技巧2
我大概是从 08.09 年从 Firebug 转入 Chrome Developer Tool,一直用到现在,越用越喜欢.我平时调错时常用的功能有: 代码格式化可以将被压缩的代码自动展开 实时代码编辑 ...
- 工程脚本插件方案 - c集成Python基础篇(VC++嵌入Python)
序: 为什么要集成脚本,怎么在工程中集成Python脚本. 在做比较大型的工程时,一般都会分核心层和业务层.核心层要求实现高效和稳定的基础功能,并提供调用接口供业务层调用的一种标准的框架划分.在实际中 ...