格而知之2:UIView的autoresizingMask属性探究
UIView的autoresizingMask属性,是用在当一个UIView实例的父控件的尺寸发生变化时,来自动调整UIView实例在父控件中的位置与尺寸的。autoresizingMask属性是一个枚举值,它的枚举成员如下:
它通过使UIView的上、下、左、右、宽度或高度自动变化来调整。下面分几种情况来讨论这个属性,假设父控件为backgroundView,子控件为subView:
1、当没有使用autoresizingMask属性或autoresizingMask属性的值为UIViewAutoresizingNone的时候,autoresizingMask属性不起作用。此时当backgroundView变化的时候,subView并没有任何反应(frame不变),如下图:
2、当设置subView. autoresizingMask=UIAutoresizingFlexibleBottomMargin或设置subView. autoresizingMask=UIAutoresizingFlexibleRightMargin的时候,发现效果和没有设置一样;
3、当设置subView. autoresizingMask=UIAutoresizingFlexibleLeftMargin的时候,效果如下图:
4、当设置subView. autoresizingMask=UIAutoresizingFlexibleTopMargin的时候,效果如下图:
5、然后看一看组合的情况,多个autoresizingMask属性可以通过“|”组合起来,共同作用。比如当subView. autoresizingMask=UIAutoresizingFlexibleLeftMargin | UIAutoresizingFlexibleTopMargin的时候,效果如下图:
可以看到subView在不断改变left和top方向上和backgroundView的距离,出现了subView一直紧跟着backgroundView右下角的效果;
6、当subView. autoresizingMask=UIAutoresizingFlexibleTopMargin | UIAutoresizingFlexibleBottomMargin的时候,效果如下图:
可以看到subView在不断改变top和bottom方向上和backgroundView的距离,出现了subView一直在垂直方向上居中的效果;
7、如果同时使用4个margin属性,会有以下效果:
可以看到subView在不断改变4个方向上和backgroundView的距离,出现了subView一直居中的效果;
8、由此可知:使用margin类的枚举成员的时候,subView对应方向的边会自动灵活调整和backgroundView相应边的距离,但是subView的尺寸是不变的。所以,在这个过程中,subView的frame.origin可能会变化,而frame.size不变;
9、接下来当subView. autoresizingMask=UIAutoresizingFlexibleWidth的时候,效果如下图:
10、当subView. autoresizingMask=UIAutoresizingFlexibleHeight的时候,效果如下图:
11、共同使用width和height两个枚举成员的这种组合方式是非常常见的,它的效果如下图:
可以看到,subView在不断改变自己的尺寸,保持4个方向上和backgroundView的距离不变,出现了subView一直居中并跟着backgroundView变化的效果;
12、由此可知:使用width和height两个枚举成员的时候,subView会通过变换尺寸来使对应方向上的边与backgroundView的距离保持不变。即是在这个过程中,subView的frame.origin不变,而frame.size会改变;
13、我们还可以将margin和width、height组合起来使用,当subView. autoresizingMask=UIAutoresizingFlexibleWidth |UIAutoresizingFlexibleTopMargin | UIAutoresizingFlexibleBottomMargin的时候,效果如下图:
可以看到subView组合了三个属性,它不断改变自己的宽度(width)保持和backgroundView的左右两边距离不变,同时不断改变上、下两个方向(top、bottom)和backgroundView的距离保持垂直方向上的居中;
14、最后再来看一看一些情况,当组合使用left和width的时候,出现了以下的效果:
我们已经知道,left是要让左边距灵活变化,而width是要保持左右边距不变,这两个似乎相互矛盾的特性使得subView的左边距出现了不规则的变化。为了更清楚了解这种组合的效果,我们同时使用left、right和width,出现了如下效果:
通过这个试验,我们发现,subView在水平方向上不断改变frame.origin和frame.size,达到了随着backgroundView等比例变化的效果。
如果我们同时使用除了none之外的所有的特性,还会出现以下效果:
subView随着backgroundView的变化自动等比例变化,边距、尺寸保持着和backgroundView的固定比例不变。
15、最后,还可以使用数字来指定autoresizingMask属性,从autoresizingMask属性的定义可以看到,每个特性对应着一个二进制数的某个数位。根据这个定义,由于十进制数63等于二进制数B111111,当指定subView. autoresizingMask=63时,则相当于六个数位全部指定为1,所有的特性都会起作用,即是最后一张图的效果。
如果要做出和subView. autoresizingMask=UIAutoresizingFlexibleTopMargin | UIAutoresizingFlexibleBottomMargin相同的效果,查阅autoresizingMask的定义可知,指定subView. autoresizingMask=40即可(40=B101000,两个1对应位置的特性会起作用)。
16、通过以上的测试,我们可以得到以下结论:
(1)、margin类的特性会改变对应边与父控件的边距、不改变尺寸,即是会影响到frame.origin,不会影响到frame.size;
(2)、width和height特性不会改变相应边与父控件的边距、但会改变尺寸,即是会影响到frame.size,不会影响到frame.origin;
(3)、多个特性可以组合使用,共同发生作用;
(4)、有重叠作用的特性组合使用,会有等比例变化的效果;
(5)、可以使用数字来指定autoresizingMask属性,数字转换成二进制数后,由最后六位数字决定哪些特性起作用。
格而知之2:UIView的autoresizingMask属性探究的更多相关文章
- 关于UIView 的autoresizingMask属性,即UIViewAutoresizing
enum { UIViewAutoresizingNone = 0, UIViewAutoresizingFlexibleLeftMargin = 1 &l ...
- UIView 的 autoresizingMask 属性 详解。
转载自:liubo0_0的专栏 链接网址:http://blog.csdn.net/liubo0_0/article/details/7085935 在 UIView 中有一个autoresizin ...
- UIView 的autoresizingMask属性
autoresizingMask属性的意思就是自动调整子控件与父控件中间的位置,宽高,定义如下: typedef NS_OPTIONS(NSUInteger, UIViewAutoresizing) ...
- 关于UIView的AutoresizingMask属性的研究
在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. 1 2 3 4 5 6 7 8 9 enum ...
- 关于UIView的autoresizingMask属性的研究【转】
在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. 1 2 3 4 5 6 7 8 9 enum ...
- UIView的autoresizingMask属性
今天做相册列表的时候,发现有些 UITableViewController 属性不好记忆,然后就查找了一些资料.做一下备份. 在 UIView 中有一个autoresizingMask的属性,它对应的 ...
- ios开发之--关于UIView的autoresizingMask属性的研究
在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. enum { UIViewAutoresizi ...
- UIView的autoresizingMask属性研究
在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. 1 2 3 4 5 6 7 8 9 enum ...
- 转-关于UIView的autoresizingMask属性的研究
在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. 1 2 3 4 5 6 7 8 9 enum ...
随机推荐
- LeeCode-Remove Element
Given an array and a value, remove all instances of that value in place and return the new length. T ...
- 开源安卓播放器:Dolphin Player 简单分析
Dolphin播放器(Dolphin Player)是一款开源的音频和视频播放器,它支持大多数的音频和视频文件模式,也支持大部分的字幕文件格式.它是基于ffmpeg的. 项目主页:http://cod ...
- 【转】C++实现RTMP协议发送H.264编码及AAC编码的音视频
RTMP(Real Time Messaging Protocol)是专门用来传输音视频数据的流媒体协议,最初由Macromedia 公司创建,后来归Adobe公司所有,是一种私有协议,主要用来联系F ...
- Python常用模块(time, datetime, random, os, sys, hashlib)
time模块 在Python中,通常有这几种方式来表示时间: 时间戳(timestamp) : 通常来说,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量.我们运 ...
- 【C语言】输入一组整数,求出这组数字子序列和中最大值
//输入一组整数.求出这组数字子序列和中最大值 #include <stdio.h> int MAxSum(int arr[],int len) { int maxsum = 0; int ...
- [英国][记录][战争中的世界:二战全史(26集)][BD-MKV/58G][中英双字][经典收藏]
[英国][记录][战争中的世界:二战全史(26集)][BD-MKV/58G][中英双字][经典收藏] 原片名:The World at War 中文名:战争中的世界 导 演:Ted Childs, ...
- [裸KMP][HDU1711][Number Sequence]
题意 找到子串在母串出现的第一个位置 解法 裸的KMP 特别的地方 第一次不看模板自己敲的KMP #include<stdio.h> const int maxn=100000; cons ...
- asp.net中Repeart选中整行操作
<asp:Repeater runat="server" ID="rpt_Student"> <HeaderTemplate> < ...
- 常用SQL Server分页方式
假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页查询每页30条,查询第1500页(即第45001-45030条数据),字段ID聚集索引,YE ...
- Mysql查询高速缓存区
为了提高查询速度,Mysql会维护一个内存区域(官方文档指出,大小至少41984B)对查询结果进行缓存,当查询时发现缓存区里有数据则直接返回结果而不用去执行sql语句. 查询命中的条件 每个缓存查询至 ...