在写透明导航栏的时候,如果没有侧滑手势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;
}
但是有一个问题,使用侧滑手势返回时会出现导航栏alpha值突变,导致一下从不透明->透明。
如果要处理这种情况:
方法1:隐藏系统NavigationBar,自己实现一个类似NavigationBar的View(类似网易云侧滑返回)。
方法2:在push到下一个界面前对屏幕进行截图保存,侧滑手势,在侧滑的时候拿到保存的图片添加到UIWindow上。手势完成后再移除图片(类似斗鱼侧滑返回)。