根视图导航栏透明效果,跳转的页面取消导航栏透明效果

根视图导航栏透明效果,跳转的页面取消导航栏透明效果

想让导航栏透明,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];    //导航栏背景色透明
}

就可以了

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值