iPhoneX状态条的隐藏与显示

此文写于iPhoneX上市前,里面的代码未经真机测试,只在模拟器测试过!!!!!!!

继iPhoneX和我的刘海同款之尴尬后,我遇到了iPhoneX横屏下状态条无法显示之尴尬。终于,给我显示出来了:
1
原因是需要实现-(void)setNeedsStatusBarAppearanceUpdate这个方法。
不信你看,当你点击-(BOOL)prefersStatusBarHidden这个方法看它的quick help:
1
具体代码如下:

#import "ViewController.h"

@interface ViewController ()

@property BOOL isStatusBarHidden;

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    _isStatusBarHidden = NO;
    UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
    [button setBackgroundColor:[UIColor grayColor]];
    [button setTitle:@"button" forState:UIControlStateNormal];
    [button addTarget:self action:@selector(buttonClicked:) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:button];
}

-(void)buttonClicked: sender {
    _isStatusBarHidden = !_isStatusBarHidden;
    UIDeviceOrientation *orientation = [UIDevice currentDevice].orientation;
    if (orientation == UIDeviceOrientationPortrait) {
        NSLog(@"Portrait");
        [super setNeedsStatusBarAppearanceUpdate];
    }else {
        NSLog(@"Landscape");
        [self setNeedsStatusBarAppearanceUpdate];
    }
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

-(void)setNeedsStatusBarAppearanceUpdate {
    NSLog(@"---self setNeedsStatusBarAppearanceUpdate---");
}

-(BOOL)prefersStatusBarHidden {
    return _isStatusBarHidden;
}

@end

不过这个方法有个弊端,就是状态条的属性(显示与否、字体颜色等)只能在竖屏情况进行设置更换,横屏下的状态条只能维持竖屏下的状态条的样子。从这个demo上直观看的效果就是:竖屏下点击button更换状态条状态,横屏下状态条维持竖屏状态条状态,横屏下点击button更换状态条状态无效。

也许会问,为什么要[self setNeedsStatusBarAppearanceUpdate];,那是因为iPhoneX里的setNeedsStatusBarAppearanceUpdate方法横屏无效!!!我的天,所以只能重写。。。但是这个方法是不公开的。。。于是只能这样很挫很挫的半实现这个效果。如果你有更好的方法,望告知!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值