iPhone X 底部适配
2017-11-09 本文已影响251人
Minoz_min
场景:UIViewController
上添加 UITableView
以下主要讲的是通过storyboard上直接对控件进行约束约束,实现方法有很多种,我一般用以下方法实现:
Xcode 9之前
data:image/s3,"s3://crabby-images/091c9/091c924df0d3c1e80bfe3e614f84e3bc29d67455" alt=""
然后直接在iPhone x上运行,效果图1:
data:image/s3,"s3://crabby-images/f3884/f38841f7049dd59bfbbcea99551c5db24d947317" alt=""
很显然效果不是我想要的,解决方法看图操作:
双击bottom约束
data:image/s3,"s3://crabby-images/2f0f2/2f0f21e4607e1e2390eee120e0218bf2f24f166b" alt=""
将
Bottom Layout Guide
改成 superView
data:image/s3,"s3://crabby-images/ceff6/ceff6771390293e356cbe861203198e6b9560e1b" alt=""
再运行结果如图2:
data:image/s3,"s3://crabby-images/0107d/0107d099a3b28e752b9d33d5f460000408940bed" alt=""
完美解决!!!
Xcode9之后
就用Safe Area Layout Guide
替代了原来的Top/Bottom Layout Guide
,前提是最低支持ios 9
版本才能用使用Safe Area Layout Guide
.
选中Main.storyboard
,然后勾选User Safe Area Layout Guide
,就可以将整个storyboard的页面都添加safe area,如下图:
data:image/s3,"s3://crabby-images/4049d/4049dac350ebc9bca758c39ea33b2b01e0e704cf" alt=""
xcode会自动帮我们转换过来,上面约束图1就变成了以下:
data:image/s3,"s3://crabby-images/6340c/6340c95ac406045c9246efb1ac52ffcb29624f15" alt=""
运行之后会发现效果跟图1是一样,再重得上面的步骤:
双击bottom约束
data:image/s3,"s3://crabby-images/c8a6d/c8a6d590d80f900f2be03e5e9a6c0fe013660759" alt=""
将
Safe Area
改成 superView
data:image/s3,"s3://crabby-images/d43a4/d43a498ee09127003c5839517978f5bebd05976e" alt=""
运行效果就跟图2一样啦!