iOS 自定義狀態(tài)欄和導(dǎo)航欄詳細(xì)介紹
更新時間:2016年11月21日 14:58:15 作者:Fiona_L
這篇文章主要介紹了iOS 自定義狀態(tài)欄和導(dǎo)航欄詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下
iOS 自定義狀態(tài)欄和導(dǎo)航欄
開發(fā)IOS APP 經(jīng)常會根據(jù)需求更改狀態(tài)欄和導(dǎo)航欄,這里整理了幾種方法,大家可以看下。
導(dǎo)航欄透明
-(void)viewWillAppear:(BOOL)animated { //viewWillAppear中設(shè)置透明 [super viewWillAppear:animated]; [self.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault]; //用空圖片填充機(jī)位透明 [self.navigationBar setShadowImage:[UIImage new]];//naviBar底部的seperatorLine } -(void)viewDidDisappear:(BOOL)animated { //viewWillAppear中設(shè)置恢復(fù) [super viewDidDisappear:animated]; [self.navigationBar setBackgroundImage:nil forBarMetrics:UIBarMetricsDefault]; [self.navigationBar setShadowImage:shadowImage]; }
導(dǎo)航欄漸變
barImageView = self.navigationController.navigationBar.subviews.firstObject; -(void)scrollViewDidScroll:(UIScrollView *)scrollView { CGFloat minAlphaOffset = - 64; CGFloat maxAlphaOffset = 200; CGFloat offset = scrollView.contentOffset.y; CGFloat alpha = (offset - minAlphaOffset) / (maxAlphaOffset - minAlphaOffset); _barImageView.alpha = alpha; }
狀態(tài)欄字體顏色改變
[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleDefault;//黑色 [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;//白色
導(dǎo)航欄隱藏
如果導(dǎo)航欄自定義度高,需要完全自己重寫,可以隱藏原來的導(dǎo)航欄,并定義一個新的view
-(void)viewWillAppear:(BOOL)animated { [super viewWillAppear:animated]; self.navigationController.navigationBarHidden = YES; } -(void)viewDidDisappear:(BOOL)animated { [super viewDidDisappear:animated]; self.navigationController.navigationBarHidden = NO; } -(void)ys_initNavigationBar { self.navigationController.interactivePopGestureRecognizer.delegate = (id)self; // 保留右滑pop的手勢 _naviBar = [[UIView alloc] initWithFrame:CGRectMake(0, 0, self.view.width, 64)]; _naviBar.backgroundColor = [UIColor whiteColor]; [self.view addSubview:_naviBar]; UIView *line = [[UIView alloc] initWithFrame:CGRectMake(0, _naviBar.height-0.5, self.view.width, 0.5)]; line.backgroundColor = [UIColor colorForHex:@"f0f0f0"]; [_naviBar addSubview:line]; // 返回 backButton = [UIButton buttonWithType:UIButtonTypeCustom]; backButton.frame = CGRectMake(0, 20, 44, 44); [backButton addTarget:self action:@selector(goBack:) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:backButton]; // 標(biāo)題 naviLable = [[UIButton alloc] initWithFrame:CGRectMake(44, 20, self.view.width-44*2, 44)]; naviLable.backgroundColor = [UIColor clearColor]; naviLable.font = [UIFont systemFontOfSize:16]; naviLabel.textAlignment = NSTextAlignmentCenter; [self.view addSubview: naviLable]; } -(void)scrollViewDidScroll:(UIScrollView *)scrollView { //navigationBar change CGFloat minAlphaOffset = 0; CGFloat maxAlphaOffset = 40; CGFloat offset = scrollView.contentOffset.y; CGFloat alpha = (offset - minAlphaOffset) / (maxAlphaOffset - minAlphaOffset); _naviBar.alpha = alpha; naviLabel.alpha = alpha; }
您可能感興趣的文章:
- 詳解在iOS App中自定義和隱藏狀態(tài)欄的方法
- iOS實(shí)現(xiàn)點(diǎn)擊狀態(tài)欄自動回到頂部效果詳解
- iOS 隱藏導(dǎo)航條和狀態(tài)欄實(shí)現(xiàn)方法
- 圖文講解如何解決App的iOS 7頂部狀態(tài)欄適配問題
- iOS 設(shè)置狀態(tài)欄的背景顏色方法
- 深入理解iOS的狀態(tài)欄
- iOS在狀態(tài)欄上顯示提醒信息的功能定制
- IOS點(diǎn)擊按鈕隱藏狀態(tài)欄詳解及實(shí)例代碼
- IOS 開發(fā)狀態(tài)欄隱藏的實(shí)現(xiàn)辦法
- iOS狀態(tài)欄、導(dǎo)航欄的一些筆記分享
相關(guān)文章
iOS 監(jiān)聽回調(diào)機(jī)制KVO實(shí)例
下面小編就為大家分享一篇iOS 監(jiān)聽回調(diào)機(jī)制KVO實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01