关于navigationBar半透明属性对view布局的影响
2015-06-18 16:15
183 查看
官方文档的例图:
从iOS7开始,苹果对navigationBar进行了模糊处理,并把self.navigationController.navigationBar.translucent = YES 作为默认处理。对此苹果注释的解释为 // Default is NO on iOS 6 and earlier. Always YES if barStyle is set to UIBarStyleBlackTranslucent
这时候就会出现一个问题,当你push的控制器以ScrollView或TableView为主View时,模糊处理会使状态栏和NavigationBar挡住后面的视图,所以苹果会自动把主View的内容向下移动64px,同理,底部Tabbar会使主View向上偏移49px,Toolbar会是主View向上偏移44px
当你不想让主View自动发生偏移时:
当你不想要navigationBar进行模糊处理时:
但是,这样又会产生一个问题,由于无法看到navigationBar背后的视图,主View又会整体下移64px
,但是,注意主View的origin.y = 0!!!
如何不让主View上的整体布局下移:
注意:通过代码写布局,viewDidLoad时画好的内容的位置比较有保障。
从iOS7开始,苹果对navigationBar进行了模糊处理,并把self.navigationController.navigationBar.translucent = YES 作为默认处理。对此苹果注释的解释为 // Default is NO on iOS 6 and earlier. Always YES if barStyle is set to UIBarStyleBlackTranslucent
这时候就会出现一个问题,当你push的控制器以ScrollView或TableView为主View时,模糊处理会使状态栏和NavigationBar挡住后面的视图,所以苹果会自动把主View的内容向下移动64px,同理,底部Tabbar会使主View向上偏移49px,Toolbar会是主View向上偏移44px
当你不想让主View自动发生偏移时:
self.automaticallyAdjustsScrollViewInsets = NO;// 自动滚动调整,默认为YES
当你不想要navigationBar进行模糊处理时:
self.navigationController.navigationBar.translucent = NO;// Bar的模糊效果,默认为YES
但是,这样又会产生一个问题,由于无法看到navigationBar背后的视图,主View又会整体下移64px
,但是,注意主View的origin.y = 0!!!
如何不让主View上的整体布局下移:
//第一步调整主View的 y 值 self.edgesForExtendedLayout = UIRectEdgeNone;// iOS7及以后的版本支持,self.view.frame.origin.y会下移64像素至navigationBar下方 //第二步更改主View的 height 值 self.view.height = HHScreenH - 64;
注意:通过代码写布局,viewDidLoad时画好的内容的位置比较有保障。
相关文章推荐
- 数据库中char、varchar、varchar2、nvarchar之间的关系 分类: 数据库 varchar varchar2 nvarchar 2012-12-06 11:27 2849人阅读
- ring buffer的学习
- 大道至简 读后感02
- Java-马士兵设计模式学习笔记-工厂模式-单例及多例
- ofbiz中的实体引擎Delegator
- Objective-C中的+initialize和+load
- 隐写术:看黑客如何秘密隐藏恶意软件
- 16.三个学习原则和课程总结
- 设计模式六大原则
- WinXP正确关闭防火墙解决弹出问题
- solr新建富文本索引慢
- Intent 数据传递
- 某个地方 category 的方法不想用的解决方案
- Docker:一点思考
- js限制文本框只可以输入数字
- 修复iPhone的safari浏览器上submit按钮圆角bug
- MySQL MyISAM and Merge Tables Incompatibility – II
- KEIL升级或者版本问题导致调度Bug Ulink2问题
- ubuntu下中文输入法的配置,建议用fcitx
- SQL AlawaysOn 之三:SQL服务器加入域