美文网首页
IOS导航栏透明渐变效果一

IOS导航栏透明渐变效果一

作者: 损失了成吨智商的小海Jy | 来源:发表于2017-07-19 11:44 被阅读0次

    在写透明导航栏的时候,如果没有侧滑手势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导航栏透明渐变效果一

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