根视图导航栏透明效果,跳转的页面取消导航栏透明效果
想让导航栏透明,self.navigationController.navigationBar.barTintColor
这个方法设置了clearColor之后只会让导航栏变黑并不会有透明的显示self.view的效果,因为self.view是在viewController中,viewController又被压入到了导航栏的栈中,属于NAV的子控制器,所以导航栏透明只会显示底部的self.window。
那么我们可以设置给导航栏一个空图片,相当于镂空效果
[self.navigationController.navigationBar setBackgroundImage:[[UIImage alloc]init] forBarMetrics:UIBarMetricsCompact]; //导航栏背景色透明
这样可以实现导航栏透明,但是还会有一条导航栏底部的黑线,要去掉有两种方法
第一种:
[self.navigationController.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault];
[self.navigationController.navigationBar setShadowImage:[UIImage new]];
这个方法最好放在viewWillAppear上,可以在出现时就隐藏掉。但是有个弊端,这种方法会导致跳转了一些页面的导航栏出现相应的变化,具体变化还要看代码如何实现。
第二种:
找到这条黑线,hidden掉
navBarHairlineImageView = [self findHairlineImageViewUnder:self.navigationController.navigationBar];
navBarHairlineImageView.hidden = YES;
//通过一个方法来找到这个黑线(findHairlineImageViewUnder):
- (UIImageView *)findHairlineImageViewUnder:(UIView *)view {
if ([view isKindOfClass:UIImageView.class] && view.bounds.size.height <= 1.0) {
return (UIImageView *)view;
}
for (UIView *subview in view.subviews) {
UIImageView *imageView = [self findHairlineImageViewUnder:subview];
if (imageView) {
return imageView;
}
}
return nil;
}
推荐使用第二种
那现在回到标题要的效果,获取黑线,hidden掉,接着添加
-(void)viewWillDisappear:(BOOL)animated
{
[self.navigationController.navigationBar setBackgroundImage:nil forBarMetrics:UIBarMetricsCompact]; //取消导航栏透明
}
- (void)viewDidAppear:(BOOL)animated
{
[self.navigationController.navigationBar setBackgroundImage:[[UIImage alloc]init] forBarMetrics:UIBarMetricsCompact]; //导航栏背景色透明
}
就可以了