edgesForExtendedLayout | extendedLayoutIncludesOpaqueBars | automaticallyAdjustsScrollViewInsets | contentInsetAdjustmentBehavior

一个ViewController的默认布局

我们在大部分的程序布局上是一个TableViewController在上下分别是:
TabBarController和NavigationController.


屏幕快照 2018-02-24 下午2.18.13.png

在我们添加任何代码的情况下运行后的布局如下:


Simulator Screen Shot - iPhone 8 Plus - 2018-02-24 at 14.29.41.png

在iOS7之后,苹果鼓励使用这种默认的全屏模式,默认的NavigationBar和TabBar是半透明,上下滑动Table的视图会上下延伸.也就是表示TableView的Frame和显示区域都是屏幕的大小.

edgesForExtendedLayout

UIViewController包含一个edgesForExtendedLayout属性,字面意思是拓展的边距布局.

屏幕快照 2018-02-24 下午2.34.29.png

当我们设置:

self.edgesForExtendedLayout = UIRectEdgeNone;
Simulator Screen Shot - iPhone 8 Plus - 2018-02-24 at 14.31.13.png

上面代码达到的效果和设置TabBar和navigationBar的透明度达到的效果是一致的.即ViewController的主View的上下和大小发生了变换.变成了从NavigationBar的底部开始到TabBar的顶部结束.

self.navigationController.navigationBar.translucent = NO;
self.tabBarController.tabBar.translucent = NO;

这里要强调一下:edgesForExtendedLayout无论是TableViewController还是普通的ViewController影响是一致的.当设置edgesForExtendedLayout与否会直接影响主View的位置,如下:


默认不做任何设置

设置self.edgesForExtendedLayout = UIRectEdgeNone;

extendedLayoutIncludesOpaqueBars

这个属性字面意思:延伸的布局是否包括bar,这个属性只有在Bar不透明的时候有作用.默认值是NO,即不延伸.

self.navigationController.navigationBar.translucent = NO;
self.extendedLayoutIncludesOpaqueBars = NO;//默认情况
Simulator Screen Shot - iPhone 8 Plus - 2018-02-24 at 16.07.34.png
self.navigationController.navigationBar.translucent = NO;
self.extendedLayoutIncludesOpaqueBars = YES;

这个时候self.view.bounds为全屏.


Simulator Screen Shot - iPhone 8 Plus - 2018-02-24 at 16.09.21.png

综上:优先级是先看edgesForExtendedLayout,再看navigationBar是否透明,在不透明的情况下才看extendedLayoutIncludesOpaqueBars。以上这几个属性是对被添加的子视图布局产生影响,达到的效果基本相同,但还是有细微的区别。

automaticallyAdjustsScrollViewInsets

这个属性的字面意思是:自动适配滚动视图的内容,ios11之后已经弃用了.用的最新的Xcode已经无法在模拟器上重现了.
简单介绍一下,当我们设置:

self.edgesForExtendedLayout = UIRectEdgeAll;//默认值
self.automaticallyAdjustsScrollViewInsets = YES;//默认值

TableView的显示内容会从navigationBar的底部开始显示,向上滑动的时候还是会穿过透明的导航栏全屏扩展.

self.edgesForExtendedLayout = UIRectEdgeAll;//默认值
self.automaticallyAdjustsScrollViewInsets = NO;

这个时候TableView的显示内容会从全屏的左上角开始,也就是默认进入页面的时候, TableView的上面的Cell是被半透明的NavigationBar遮挡住的.

介绍了这么多都没什么用啦,因为ios11来啦.

automaticallyAdjustsScrollViewInsets在ios11上被弃用.


automaticallyAdjustsScrollViewInsets

edgesForExtendedLayout虽然没被弃用,但是在介绍里面有了替代的属性,safeArea相关的.

edgesForExtendedLayout

contentInsetAdjustmentBehavior

ios11里面使用这个属性替代了automaticallyAdjustsScrollViewInsets.
这个属性的枚举值如下:

 typedef NS_ENUM(NSInteger, UIScrollViewContentInsetAdjustmentBehavior) {
        UIScrollViewContentInsetAdjustmentAutomatic, // Similar to .scrollableAxes, but for backward compatibility will also adjust the top & bottom contentInset when the scroll view is owned by a view controller with automaticallyAdjustsScrollViewInsets = YES inside a navigation controller, regardless of whether the scroll view is scrollable
        UIScrollViewContentInsetAdjustmentScrollableAxes, // Edges for scrollable axes are adjusted (i.e., contentSize.width/height > frame.size.width/height or alwaysBounceHorizontal/Vertical = YES)
        UIScrollViewContentInsetAdjustmentNever, // contentInset is not adjusted
        UIScrollViewContentInsetAdjustmentAlways, // contentInset is always adjusted by the scroll view's safeAreaInsets
    } API_AVAILABLE(ios(11.0),tvos(11.0));
  1. automatic 和scrollableAxes一样,scrollView会自动计算和适应顶部和底部的内边距并且在scrollView 不可滚动时,也会设置内边距.
  2. scrollableAxes 自动计算内边距.
  3. never 不计算内边距
  4. always 根据safeAreaInsets 计算内边距
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,835评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,598评论 1 295
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,569评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,159评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,533评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,710评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,923评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,674评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,421评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,622评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,115评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,428评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,114评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,097评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,875评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,753评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,649评论 2 271