iOS如何去掉導航欄(UINavigationBar)下方的橫線
網(wǎng)上有很多關(guān)于隱藏的方法,設(shè)置后能夠成功,但是跳轉(zhuǎn)到其他界面的時候發(fā)現(xiàn),其他界面橫線也被隱藏了。
目前主流的方法是將shadowImage用一張空的圖片圖片替換掉
可是這種方法不能解決navigationController里面的某個界面隱藏,其他不變的問題。
[self.navigationController.navigationBar setBackgroundImage:[[UIImage alloc] init] forBarMetrics:UIBarMetricsDefault]; self.navigationController.navigationBar.shadowImage = [[UIImage alloc] init];
通過xcode查看UINavigationBar的樹形結(jié)構(gòu)發(fā)現(xiàn),可以很清楚的看出橫線就是下面的_UIBarBackground下面的UIImageView對象
樹形結(jié)構(gòu)如下
**UINavigationBar** **--[ 1] _UIBarBackground** **----[ 2] UIImageView** **----[ 2] UIVisualEffectView** **------[ 3] _UIVisualEffectBackdropView** **------[ 3] _UIVisualEffectFilterView** **--[ 1] UINavigationButton** **----[ 2] UIButtonLabel** **--[ 1] _UINavigationBarBackIndicatorView**
所以能不能遍歷UINavigationBar的所有子view然后找到橫線對應的UIImageView對象,隱藏掉呢?
遍歷UINavigationBar所有的子view獲取子view的數(shù)組。
NSArray *allSubviews(UIView *aView) { NSArray *results = [aView subviews]; for (UIView *eachView in aView.subviews) { NSArray *subviews = allSubviews(eachView); if (subviews) results = [results arrayByAddingObjectsFromArray:subviews]; } return results; }
遍歷數(shù)組找到橫線對應的UIImageView對象
@property (nonatomic, strong) UIImageView *shadowImage;
- (void)viewWillAppear:(BOOL)animated{ [super viewWillAppear:animated]; NSArray *subViews = allSubviews(self.navigationController.navigationBar); for (UIView *view in subViews) { if ([view isKindOfClass:[UIImageView class]] && view.bounds.size.height<1){ //實踐后發(fā)現(xiàn)系統(tǒng)的橫線高度為0.333 self.shadowImage = (UIImageView *)view; } } self.shadowImage.hidden = YES; }
最后在viewDidDisappear方法里面還原顯示狀態(tài)。
- (void)viewWillDisappear:(BOOL)animated{ [super viewWillDisappear:animated]; self.shadowImage.hidden = NO; }
運行后發(fā)現(xiàn)完美解決
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
iOS中使用UItableviewcell實現(xiàn)團購和微博界面的示例
這篇文章主要介紹了iOS中使用UItableviewcell實現(xiàn)團購和微博界面的示例,開發(fā)語言基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-01-01詳解iOS的UI開發(fā)中控制器的創(chuàng)建方法
這篇文章主要介紹了iOS的UI開發(fā)中控制器的創(chuàng)建方法,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-11-11