ios顯示或隱藏導航欄的底線


 

 

根據產品需求要求把這個界面導航欄的底線去掉,下個控制器還需要有底線.

 

使用下面的代碼實現

 

 

//在頁面出現的時候就將黑線隱藏起來

-(void)viewWillAppear:(BOOL)animated

{

    [self.navigationController.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault];

    [self.navigationController.navigationBar setShadowImage:[UIImage new]];

    _navBarHairlineImageView.hidden = YES;

}

//在頁面消失的時候就讓navigationbar還原樣式

-(void)viewWillDisappear:(BOOL)animated{

    

    [self.navigationController.navigationBar setBackgroundImage:nil forBarMetrics:UIBarMetricsDefault];

    [self.navigationController.navigationBar setShadowImage:nil];

    //再定義一個imageview來等同於這個黑線

    //UIImageView *navBarHairlineImageView;

    _navBarHairlineImageView = [self findHairlineImageViewUnder:self.navigationController.navigationBar];

 

}

//這個方法唯一的不好就是會影響導航欄的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;

}

 

////同樣的在界面出現時候開啟隱藏

//-(void)viewWillAppear:(BOOL)animated

//{

//    _navBarHairlineImageView.hidden = YES;

//}

////在頁面消失的時候就讓出現

-(void)viewDidAppear:(BOOL)animated

{

    _navBarHairlineImageView.hidden = NO;

}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM