详解 iOS navigationBar 的设置问题
在iOS7之后,self.navigationController.navigationBar.translucent = NO 把导航条这个属性设置为no之后,坐标怎么向下移动了64个像素点?
由于我要改变导航条的颜色,然后设置之后发现导航条的颜色设置后并不准确,于是把 self.navigationController.navigationBar.translucent = NO 这个属性设置为no,但是发现之前所有控件的坐标都往下移了,是因为导航条不透明的时候坐标的(0,0)点在屏幕(0,64)这个位置么?该怎么设置啊?难道以前两个月写的代码坐标全都改一下么?
iOS7之后由于navigationBar.translucent默认是YES,坐标零点默认在(0,0)点 当不透明的时候,零点坐标在(0,64);如果你想设置成透明的,而且还要零点从(0,64)开始,那就添加:self.edgesForExtendedLayout = UIRectEdgeNone; 但是目前的需求是:但是我想设置成不透明的,还从(0,0)开始。对于目前的需要要这样设置
self.extendedLayoutIncludesOpaqueBars = YES;就可以了。
默认navigationBar的是半透明,那么它半透明是为了什么?答案是为了可以隐约看到Bar后面的内容,iOS7以上玩多了的人应该有注意到这个问题吧。好了,默认是半透明,看官方的图片,在Bar下方的scrollviewB的frame如果从(0,0)开始,那么我们滚动的内容从即使滚动到Top的位置,还是可以隐隐约约的看到。
最后一个介绍的新属性是extendedLayoutIncludesOpaqueBars,这个属性指定了当Bar使用了不透明图片时,视图是否延伸至Bar所在区域,默认值时NO。
我设置self.navigationController.navigationBar.translucent = YES; self.view是以(0,0)为origin,然后设置scrollview的frame = self.view,但是scrollView发生了44的偏移,搞了一下午没解决,看了这篇文章后在viewWillAppear里面加了句self.automaticallyAdjustsScrollViewInsets = NO; 问题一下子就解决了。
补充下:NavigationBar的常用设置:
self.edgesForExtendedLayout = UIRectEdgeNone;
self.extendedLayoutIncludesOpaqueBars =NO;
self.modalPresentationCapturesStatusBarAppearance =NO;
self.navigationController.navigationBar.translucent =NO;
self.automaticallyAdjustsScrollViewInsets = NO
在IOS7以后 ViewController 开始使用全屏布局的,而且是默认的行为通常涉及到布局
就离不开这个属性edgesForExtendedLayout,它是一个类型为UIExtendedEdge的属性,
指定边缘要延伸的方向,它的默认值很自然地是UIRectEdgeAll,四周边缘均延伸,就是说,
如果即使视图中上有navigationBar,下有tabBar,那么视图仍会延伸覆盖到四周的区域。
因为一般为了不让tableView 不延伸到 navigationBar 下面, 属性设置为 UIRectEdgeNone
UIRectEdgeAll -- default
UIRectEdgeNone
这时会发现导航栏变灰了,处理如下就OK了
self.navigationController.navigationBar.translucent=NO;
那 automaticallyAdjustsScrollViewInsets 呢?
当 automaticallyAdjustsScrollViewInsets 为 NO 时,tableview 是从屏幕的最上边开始,也就是被
导航栏 & 状态栏覆盖
当 automaticallyAdjustsScrollViewInsets 为 YES 时,也是默认行为,表现就比较正常了,和
edgesForExtendedLayout = UIRectEdgeNone 有啥区别? 不注意可能很难觉察
设计师可能一眼就看穿。。。 automaticallyAdjustsScrollViewInsets 为YES 时,
tableView 上下滑动时,是可以穿过导航栏&状态栏的,在他们下面有淡淡的浅浅红色
extendedLayoutIncludesOpaqueBars
首先看下官方解释,默认 NO, 但是Bar 的默认属性是 透明的。。。也就是说只有在不透明下才有用
但是,测试结果很软肋,基本区别不大。。。但是对于解决一些Bug 是还是起作用的,比如说SearchBar的
跳动问题,详情见:http://www.cnblogs.com/skyming/p/4059128.html, 其他UITableView,UIScrollView 位置的
问题多数和这3属性相关。。
参考文章:
http://www.cocoachina.com/bbs/read.php?tid-298675-page-1.html
http://www.cocoachina.com/bbs/read.php?tid=280826
http://www.vinqon.com/codeblog/?detail/11109
http://www.geekcome.com/content-10-10502-1.html