手机热点开启,tabbar会下移20 px

当手机热点开启并被其他设备接入时,状态栏会比普通状态下多20px,此时整个视图控制器会被向下推20px,推出屏幕,即下面的tabbar会下移20
px。如果不做相应处理必然会带来糟糕的用户体验,

基本思路:

既然是状态栏的高度变化导致的,那就监听状态栏高度的变化,每当状态栏高度发生变化就发送一个通知,通知相应的页面调整UI。

进一步思考

监听状态栏高度变化可以用KVO或者RAC。如下:

// 监听状态栏的frame变化,如接入热点时状态栏会增加20像素
[RACObserve([UIApplication sharedApplication], statusBarFrame) subscribeNext:^(id x) {
    if ([UIApplication sharedApplication].statusBarFrame.size.height > 20) {
        // 状态栏高度大于20,发送通知
    }else{


    }
}];

其实这样做完全是多余的,因为每当状态栏高度发生变化时系统都会发送通知:UIApplicationWillChangeStatusBarFrameNotification与UIApplicationDidChangeStatusBarFrameNotification,我们监听这两个通知中的一个即可。

在哪里监听状态栏高度改变的通知?

在需要调整UI的地方监听。因为状态栏高度一变可以说所有的页面都受到了影响,所以可以在基类BaseViewController(其他视图控制器都继承于这个类)里面接收通知(viewDidLoad方法里):

// 接收状态栏高度发生变化的通知
[[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(adjustStatusBar) name:@”UIApplicationDidChangeStatusBarFrameNotification” object:nil];
接收到通知后执行调整UI的方法,这个方法需要在BaseViewController的子类里根据实际情况进行重写,例如调整tableView的高度。

// 热点被接入,子类重写
- (void)adjustStatusBar{

}
接收不到通知怎么办?

通知只能发送给已经存在的对象,还没有初始化的对象是接收不到通知的。那么就是说我们需要保存一下状态栏的高度咯?其实不必,因为状态栏的高度我们随时可以获取:

[UIApplication sharedApplication].statusBarFrame.size.height
为方便使用,可以在PCH文件里写个宏定义:

// 状态栏高度大于20(热点被连接时)


#define STATUS_BAR_BIGGER_THAN_20 [UIApplication sharedApplication].statusBarFrame.size.height > 20

你可以翻译一下STATUS_BAR_BIGGER_THAN_20
好了现在来说未初始化的页面怎么处理:
方法一:初始化的时候根据状态栏高度搭建UI(赶紧重构代码呵呵哒)
方法二:不改变以前的代码,在UI搭建完成后调用调整UI的方法(重写的BaseViewController的那个方法)。
显然方法二是简单切实可行的。

接下来怎么办?

方法都告诉你了,接下来你就慢慢添加代码了,虽然有点多有点痛苦,可以说每个页面都要调整。类似于下面的这段代码几乎在我所有的视图控制器中都有:

#pragma mark - 接入热点
- (void)adjustStatusBar{
if (STATUS_BAR_BIGGER_THAN_20) {
_shopTotalView.maxY = screenHeight - 69;
}else{
_shopTotalView.maxY = screenHeight - 49;
}
}

总结

热点适配需注意两点:

监听状态栏高度改变的通知用来及时调整UI
接收不到通知的,在UI搭建完成后做相应调整
小技巧

基类接收通知,子类重写方法

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值