美文网首页
隐藏导航栏的三种方式

隐藏导航栏的三种方式

作者: cs_mark | 来源:发表于2018-10-12 17:30 被阅读0次

在项目中经常碰到首页顶部是无限轮播,需要靠最上面显示.有的设置导航栏为透明等一系列的方法或者干脆简单粗暴的直接隐藏掉导航栏. 可一般情况下当push到下一个页面的时候又需要展示导航栏的。这里给出了三种方法.

第一种做法

注意这里一定要用动画的方式隐藏导航栏,如果不这样使用滑动返回手势的时候显的非常僵硬。为了使用滑动返回手势的时候效果最好,所以我推荐用动画的方式.这样做有一个缺点就是在切换tabBar的时候有一个导航栏向上消失的动画.

- (void)viewWillAppear:(BOOL)animated {
    [super viewWillAppear:animated];

    [self.navigationController setNavigationBarHidden:YES animated:animated];
}

- (void)viewWillDisappear:(BOOL)animated {
    [super viewWillDisappear:animated];

    [self.navigationController setNavigationBarHidden:NO animated:animated];
}

第二种做法

设置self为导航控制器的代理,实现代理方法,在将要显示控制器中设置导航栏隐藏和显示,使用这种方式不仅完美切合滑动返回手势,同时也解决了切换tabBar的时候,导航栏动态隐藏的问题。

tip:记得在控制器销毁的时候把导航栏的代理设置为nil。
@interface CSViewController () <UINavigationControllerDelegate>

@end

@implementation CSViewController 

- (void)viewDidLoad {
    [super viewDidLoad];

    // 设置导航控制器的代理为self
    self.navigationController.delegate = self;
}

#pragma mark - UINavigation-Delegate
// 将要显示控制器
- (void)navigationController:(UINavigationController *)navigationController willShowViewController:(UIViewController *)viewController animated:(BOOL)animated {
    // 判断要显示的控制器是否是自己
    BOOL isShowVC = [viewController isKindOfClass:[self class]];

    [self.navigationController setNavigationBarHidden:isShowVC animated:YES];
}

- (void)dealloc {
    self.navigationController.delegate = nil;
}
第三种做法

主要是针对A隐藏Nav, A push 到B,B也需要隐藏Nav的这种情况

1、自定义UINavigationController

#import "CSNavigationController.h"
#import "ONEViewController.h"
#import "TWOViewController.h"


@interface CSNavigationController ()<UINavigationControllerDelegate, UIGestureRecognizerDelegate>

@end

@implementation CSNavigationController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    self.delegate = self;
    // 设置全屏滑动返回
    id target = self.interactivePopGestureRecognizer.delegate;
    UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc] initWithTarget:target action:@selector(handleNavigationTransition:)];
    [self.view addGestureRecognizer:pan];
    self.interactivePopGestureRecognizer.enabled = NO;
}

- (void)pushViewController:(UIViewController *)viewController animated:(BOOL)animated
{
    if (self.viewControllers.count > 0) {
        viewController.hidesBottomBarWhenPushed = YES;
    }
    [super pushViewController:viewController animated:animated];
}


#pragma mark - UINavigationControllerDelegate
- (void)navigationController:(UINavigationController *)navigationController willShowViewController:(UIViewController *)viewController animated:(BOOL)animated {
    // 判断如果是需要隐藏导航控制器的类,则隐藏
    BOOL isHideNav = ([viewController isKindOfClass:[ONEViewController class]] ||
                      [viewController isKindOfClass:[TWOViewController class]]);
    
    [self setNavigationBarHidden:isHideNav animated:YES];
}

但是注意setNavigationBarHidden:YES设置这行代码后会导致Nav的滑动返回手势失效,这也就是为什么前面我们在自定义导航的时候需要设置全屏滑动返回了。

相关文章

  • iOS导航栏的正确隐藏方式

    iOS导航栏的正确隐藏方式 iOS导航栏的正确隐藏方式

  • 隐藏导航栏的三种方式

    在项目中经常碰到首页顶部是无限轮播,需要靠最上面显示.有的设置导航栏为透明等一系列的方法或者干脆简单粗暴的直接隐藏...

  • 隐藏导航栏

    隐藏导航栏 显示导航栏

  • iOS导航栏的正确隐藏方式

    原文iOS导航栏的正确隐藏方式iOS导航栏的正确隐藏方式 简介 在项目中经常碰到首页顶部是无限轮播,需要靠最上面显...

  • Android隐藏状态栏、导航栏

    Android隐藏状态栏、导航栏 Android 动态隐藏显示导航栏,状态栏 一、导航栏: 相关: 二、状态栏: ...

  • iOS 状态栏(statusbar)导航栏(navigation

    导航栏透明 导航栏渐变 状态栏字体颜色改变 导航栏隐藏如果导航栏自定义度高,需要完全自己重写,可以隐藏原来的导航栏...

  • iOS 隐藏导航栏和有导航栏页面跳转

    大部分首页或者搜索页面都会隐藏导航栏 隐藏导航栏页面 --> 有导航栏页面 但是,不知道大家有没有发现 隐藏导航栏...

  • 隐藏导航栏

    使用导航栏代理 隐藏导航栏

  • iOS导航栏隐藏透明处理

    1: 导航栏隐藏之间跳转 & 导航栏隐藏后显示自定义导航栏(由于系统导航栏透明造成的动画问题 暂时还未找到...

  • IOS 常用小知识 1

    导航栏常用隐藏方式 系统导航栏时常会限制很对视图的处理,所以经常会用到自定义导航栏,如果自定义导航栏的时候还需要保...

网友评论

      本文标题:隐藏导航栏的三种方式

      本文链接:https://www.haomeiwen.com/subject/jtbgaftx.html