iOS NavigationBar系统导航栏影藏问题都在这!

需求1:只有在首页或者某一个页面隐藏navigationController,其他页面全部正常(系统导航栏,不包括自定义导航栏).

不怎么完美的解决办法1:
1.设置透明图片....
[self.navigationController.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault];
self.navigationController.navigationBar.shadowImage = [UIImage new];
2.直接设置透明度...
- (void)viewWillAppear:(BOOL)animated{
       [super viewWillAppear:animated];
       [[self.navigationController.navigationBar subviews] objectAtIndex:0].alpha = 0;
}
- (void)viewWillDisappear:(BOOL)animated{
       [super viewWillDisappear:animated];
       [[self.navigationController.navigationBar subviews] objectAtIndex:0].alpha = 1;
}
不怎么完美的解决办法2:

此方法在返回时(手势,返回按钮)会有64的白条出现

- (void)viewWillAppear:(BOOL)animated {
    [self.navigationController setNavigationBarHidden:YES animated:NO];
    [super viewWillAppear:animated];
}

- (void)viewWillDisappear:(BOOL)animated {
    [self.navigationController setNavigationBarHidden:NO animated:NO];
    [super viewWillDisappear:animated];
}
解决办法3:

此方法是调用了系统动画的方式在方法1的基础上改进

- (void)viewWillAppear:(BOOL)animated {
    [self.navigationController setNavigationBarHidden:YES animated:animated];
    [super viewWillAppear:animated];
}

- (void)viewWillDisappear:(BOOL)animated {
    [self.navigationController setNavigationBarHidden:NO animated:animated];
    [super viewWillDisappear:animated];
}
解决办法4:

导航栏代理方法,将需要影藏的控制器导航栏代理设置为self,然后调用代理方法,一个代理方法,一行代码搞定

- (void)navigationController:(UINavigationController *)navigationController willShowViewController:(UIViewController *)viewController animated:(BOOL)animated {
    [self.navigationController setNavigationBarHidden:[viewController isKindOfClass:[self class]] animated:YES];
}

需求2: navigationBar随着scrollview偏移量改变透明度

不怎么完美的解决办法1:

此方法即在界面出现的变化的时候刷新自己的导航栏

- (void)viewWillAppear:(BOOL)animated{
    [super viewWillAppear:animated];
    if(self.tableView.y == 0){
        self.navigationController.navigationBar.alpha = 1;
    }
}
- (void)viewWillDisappear:(BOOL)animated{
    [super viewWillDisappear:animated];
    self.navigationController.navigationBar.alpha = 1;
}
- (void)viewDidAppear:(BOOL)animated
{
    [super viewDidAppear:animated];
    [self refreshNavAlpha];
}
- (void)refreshNavAlpha{
    float alpha = _lastY / 64;
    alpha = alpha > 1 ? 1 : alpha;
    if (alpha < 0) {
        alpha = 0;
    }
    self.navigationController.navigationBar.alpha = alpha;
}
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    _lastY = scrollView.contentOffset.y;
    [self refreshNavAlpha];
}
相对完美的解决办法:

寻找了很多APP,发现手机QQ6.7.1版本的导航栏,是采取渐变的方式,个人认为,导航栏渐变还是需要自己处理好viewWillAppear方法中进入时刷新navigationBar,可以根据方法1中的方法进行改进,将navigationBar.alpha的透明度变化,增加一个渐变动画即可,很简单,即可和手机QQ的效果一样!

- (void)refreshNavAlpha{
    float alpha = _lastY / 64;
    alpha = alpha > 1 ? 1 : alpha;
    if (alpha < 0) {
        alpha = 0;
    }
    [UIView animateWithDuration:0.2 animations:^{
        self.navigationController.navigationBar.alpha = alpha;
    }];
}

此Demo以及在后面补上

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,241评论 4 61
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,316评论 25 708
  • 今天晨读资料分享的书籍是——《美在举手投足间》,对于三个分享内容,我概括为——行为、对己、待人。 花的美丽在于绽放...
    5070黑土阅读 333评论 10 4
  • 牛大力昨天晚上喝大了,头痛欲裂,醒来时已经早上十点半了。昨天的衬衫就这么绷在身上睡了一夜,浑身酸臭味还痛。牛大力伸...
    田螺姑娘FZ阅读 486评论 0 0
  • 今天下午看到一句话:你有freestyle吗?这句话貌似已经看到好几次了,想想应该是什么网络流行语吧,出于好奇,百...
    我就是哈哈哈阅读 848评论 4 3