IOS导航栏透明渐变效果一

在写透明导航栏的时候,如果没有侧滑手势pop控制器倒是一件简单的事。如我之前的项目一样,直接设置就行了,也不应考虑过渡动画。但是后来在自己练习代码的时候发现,这侧滑从不透明到透明界面,导航栏的突变实在是让人感觉很不爽。于是就想解决一下:

设置导航栏全透明可以通过下面代码设置:

self.navigationController.navigationBar.translucent = YES;
self.navigationController.navigationBar.subviews[0].alpha = 0;

如要实现拖动一个tableView的时候导航栏能够从透明变为不透明则需要通过监听tableView的滑动来完成一些操作:

监听scrollView滑动
- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    if (scrollView == self.tableView) {
        CGFloat offsetY = scrollView.contentOffset.y;
        [self setNavigationBarColorWithOffsetY:offsetY];
    }
}
// 界面滑动时导航栏随偏移量 实时变化
- (void)setNavigationBarColorWithOffsetY:(CGFloat)offsetY {
    UIImageView *backView = self.navigationController.navigationBar.subviews[0];
    if (offsetY <= 0) {
        backView.alpha = 0;
    } else if (offsetY > 0 && offsetY < 64) {
        backView.alpha = offsetY / 64;
    } else if (offsetY >= 64 ) {//&& offsetY <= NavBar_HEIGHT + 30
        backView.alpha = 1;
    }
}

主体功能实现代码很简单,就是上面部分。还有一个需要注意的点是:UINavigationController下只有一个的UINavigationBar,push\pop时,需要额外设置导航栏

- (void)viewWillAppear:(BOOL)animated {
    [super viewWillAppear:animated];
    // 设置导航栏为透明,并根据当前tableView的偏移量设置对应的 alpha
    self.navigationController.navigationBar.translucent = YES;
    [self setNavigationBarColorWithOffsetY:self.tableView.contentOffset.y];
}

- (void)viewWillDisappear:(BOOL)animated {
    [super viewWillDisappear:animated];
    // 设置导航栏 为不透明
    self.navigationController.navigationBar.translucent = NO;
    self.navigationController.navigationBar.subviews[0].alpha = 1.0;
}
导航栏渐变.gif

但是有一个问题,使用侧滑手势返回时会出现导航栏alpha值突变,导致一下从不透明->透明。
如果要处理这种情况:

方法1:隐藏系统NavigationBar,自己实现一个类似NavigationBar的View(类似网易云侧滑返回)。

方法2:在push到下一个界面前对屏幕进行截图保存,侧滑手势,在侧滑的时候拿到保存的图片添加到UIWindow上。手势完成后再移除图片(类似斗鱼侧滑返回)。

方法3:运用runtime交换系统监听侧滑手势正在滑动、取消、完成的事件,对导航栏进行操作

你可能感兴趣的:(IOS导航栏透明渐变效果一)