iOS隐藏导航条1px的底部横线
2015-05-15 10:11
344 查看
默认情况下会有这条线
第一种方法:
运行后效果如下(此处原有的灰色背景色会被white.png代替):
PS:这是唯一一个隐藏这条线的官方用法,但是有一个缺陷-删除了translucency(半透明)
第二种方法:1)声明UIImageView变量,存储底部横线
2)在viewDidLoad中加入:
3)实现找出底部横线的函数
4)最后在viewWillAppear,viewWillDisappear中处理
效果如下:
PS:第二种方法可以保持bar的translucent
第一种方法:
UINavigationBar *navigationBar = self.navigationController.navigationBar; // white.png图片自己下载个纯白色的色块,或者自己ps做一个 [navigationBar setBackgroundImage:[UIImage imageNamed:@"white.png"] forBarPosition:UIBarPositionAny barMetrics:UIBarMetricsDefault]; [navigationBar setShadowImage:[UIImage new]];
运行后效果如下(此处原有的灰色背景色会被white.png代替):
PS:这是唯一一个隐藏这条线的官方用法,但是有一个缺陷-删除了translucency(半透明)
第二种方法:1)声明UIImageView变量,存储底部横线
@implementation MyViewController { UIImageView *navBarHairlineImageView; }
2)在viewDidLoad中加入:
navBarHairlineImageView = [self findHairlineImageViewUnder:navigationBar];
3)实现找出底部横线的函数
- (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; }
4)最后在viewWillAppear,viewWillDisappear中处理
- (void)viewWillAppear:(BOOL)animated { [super viewWillAppear:animated]; navBarHairlineImageView.hidden = YES; } - (void)viewWillDisappear:(BOOL)animated { [super viewWillDisappear:animated]; navBarHairlineImageView.hidden = NO; }
效果如下:
PS:第二种方法可以保持bar的translucent
相关文章推荐
- iOS隐藏导航条1px的底部横线
- iOS隐藏导航条1px的底部横线
- iOS隐藏导航条1px的底部横线
- iOS隐藏导航条、tabbar 1px的底部横线
- iOS隐藏导航条1px的底部横线
- iOS隐藏导航条1px的底部横线
- 【转】iOS隐藏导航条1px的底部横线
- iOS之旅--隐藏(去除)导航栏底部横线
- iOS之旅--隐藏(去除)导航栏底部横线
- iOS导航条底部 与self.view 的分界线怎么隐藏
- 隐藏iOS导航条底部与self.view的分界线的简单方法
- iOS导航条底部与self.view的分界线怎么隐藏 ,取消导航下边的线
- 隐藏导航条底部的横线
- iOS开发--隐藏(去除)导航栏底部横线
- 隐藏导航栏下的1px底部横线
- 设置navigationBar透明,隐藏iOS导航条底部与self.view的分界线
- 隐藏导航栏底部横线
- iOS去除导航栏和tabbar的1px横线
- iOS隐藏导航栏底部的线条& UINavigationBar小技巧
- iOS 隐藏导航栏底部线的两种方法