IOS7 导航栏适配

ios7下的app都是全屏的,意思就是所有控制器的view默认都是从 屏幕的 (0,0)开始。

这时候用到导航栏时,往往会出现view被导航栏挡住情况

最明显的是用到tableView时,第一行的数据会被导航栏遮盖。


个人总结两种处理办法:

NO.1: 

 self.navigationController.navigationBar.translucent = NO;

在控制器下设置导航控制器的导航栏的translucent(半透明)属性为NO,

translucent属性在ios6之前默认为no,

而在ios7下的导航栏默认却是半透明的,为yes,所以该属性不会占据空间。

前提是你不需要导航栏半透明效果

NO.2:

ios7,为了达到全屏效果的app,官方增加了几个属性:


@property(nonatomic,assign) UIRectEdge edgesForExtendedLayout NS_AVAILABLE_IOS(7_0); // Defaults to UIRectEdgeAll


@property(nonatomic,assign) BOOL extendedLayoutIncludesOpaqueBars NS_AVAILABLE_IOS(7_0); // Defaults to NO, but bars are translucent by default on 7_0.  

@property(nonatomic,assign) BOOL automaticallyAdjustsScrollViewInsets NS_AVAILABLE_IOS(7_0); // Defaults to YES


 属性edgesForExtendedLayout,意思大概是边缘向四周展开
edgesForExtendedLayout 值是结构体。默认值是  UIRectEdgeAll,也就是上下左右填充满整个屏幕。

 // 1. UIRectEdgeNone 不要往四周边缘展开 ( 按照非 iOS7 的传统来展示 )

 self.edgesForExtendedLayout = UIRectEdgeNone;

 设置完这一句,压入桟的控制器frame的y值就是从导航条下面开始。


 // 2. NO 代表展开的时候不要包含那个导航条

 //  self.extendedLayoutIncludesOpaqueBars = NO;

// 3. 若用到tableview

 self.automaticallyAdjustsScrollViewInsets = YES;

默认yes,实际内部改变了了scrollView 的 contentInsets (比如 group 样式的tableView 的 insets.top=64 )

所以要取消自适应,改变contentInsets的top值

  tableView.contentInset = UIEdgeInsetsMake( x -35,  0,  0,  0);

 // group 状态下, sectionFooterHeight 和 sectionHeaderHeight默认 是有值的,取消  

  tableView.sectionFooterHeight = 0;

    tableView.sectionHeaderHeight = x;





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值