ios 找出导航栏下面的黑线(可隐藏,改变样式等)
2016-04-28 10:01
501 查看
根据UI的设计,navigationbar需要跟界面一体化,但是下面这根黑线是比较烦的问题,可能界面一需要隐藏,界面二就要出现,也可能需要改变粗细之类的,又因为navigationbar会影响接下来的推栈,所以需要做一点小改动. 方法1:直接隐藏: //在页面出现的时候就将黑线隐藏起来 -(void)viewWillAppear:(BOOL)animated { [self.navigationController.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault]; [self.navigationController.navigationBar setShadowImage:[UIImage new]]; } //在页面消失的时候就让navigationbar还原样式 -(void)viewWillDisappear:(BOOL)animated{ [self.navigationController.navigationBar setBackgroundImage:nil forBarMetrics:UIBarMetricsDefault]; [self.navigationController.navigationBar setShadowImage:nil]; } 这个方法唯一的不好就是会影响导航栏的translucent(透明)属性 方法2:找出黑线,再做处理: //通过一个方法来找到这个黑线(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; } //再定义一个imageview来等同于这个黑线 UIImageView *navBarHairlineImageView; navBarHairlineImageView = [self findHairlineImageViewUnder:self.navigationController.navigationBar]; 同样的在界面出现时候开启隐藏 -(void)viewWillAppear:(BOOL)animated { navBarHairlineImageView.hidden = YES; } //在页面消失的时候就让出现 -(void)viewWillAppear:(BOOL)animated { navBarHairlineImageView.hidden = NO; } 如果想要做一些更好的处理,比如说改变粗细,颜色之类的也在界面出现的时候写就行了. 推荐使用第二种方法,因为整个项目都在使用导航栏推栈,出栈,很可能因为改变了样式,导致后面的属性混乱起来.
这个要用自定义的view 才能设置:方法如下//设置标题// self.title = @"title1";//修改title 会改变navigationItem。title ,但反之不会,一般设置title用此方法就好了// self.navigationController.title = @"title2";////自定义标题// UIView *view = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 100, 44)];// view.backgroundColor = [UIColor redColor];UILabel *title = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, 100, 44)];title.text = @"title3";title.textAlignment = NSTextAlignmentCenter;title.textColor = [UIColor redColor];self.navigationItem.titleView = title;
相关文章推荐
- css新特性 box-flex/flex 弹性盒状模型
- DIV+CSS颜色边框背景等样式
- 使用 stylelint检查CSS_StyleLint
- css3和js实现重力感应(经测试,andriod4.2支持)
- CSS3新特性,兼容性,兼容方法总结
- CI 里去掉index.php 并 识别css js 文件 技巧
- 《CSS设计指南》笔记--HTML标记与文档结构
- CSS3 input 输入框蓝光特效
- 初识scss(1)
- 使用 stylelint检查CSS_StyleLint
- css 定位 float属性
- css div float属性
- css 定位
- 即将要被淘汰的兼容之--CSS Hack
- setStyleSheet来设定窗口部件的样式(前景色,背景图片)
- Footer固定在页面底部(CSS)
- CSS实现特殊背景效果
- CSS--百度百科
- Css文本
- Css框模型