學習iOS自定義導航控制器UINavigationController
自定義導航控制器: 將導航控制器中通用的部分拿出來統(tǒng)一設置
1、一般導航條標題的字體setTitleTextAttribute和背景顏色setBackgroundImage都是統(tǒng)一的,可以在load方法中使用appearanceWhenContainedIn統(tǒng)一設置
2、一般導航條的返回按鈕需要自定義,一般除了棧底控制器有導航條,其他控制器都需要隱藏底部的條,可以重寫pushViewController:animated:方法,在該方法中實現(xiàn)該功能
3、導航控制器右滑返回效果(觸摸屏幕的任意一點,向右滑動返回)
UIViewController
--navigationItem
leftBarButtonItem | leftBarButtonItems
NSString title | UIView titleView
rightBarButtonItem | rightBarButtonItems
backBarButtonItem
#import "BWNavigationController.h" #import "UIBarButtonItem+Item.h" @interface BaseNavigationController () <UIGestureRecognizerDelegate> @end @implementation BWNavigationController + (void)load { [super load]; UINavigationBar *navigationBar = [UINavigationBar appearanceWhenContainedIn:self, nil]; NSMutableDictionary *dict = [NSMutableDictionary dictionary]; dict[NSFontAttributeName] = [UIFont boldSystemFontOfSize:20]; [navigationBar setTitleTextAttributes:dict]; [navigationBar setBackgroundImage:[UIImage imageNamed:@"navigationbarBackgroundWhite"] forBarMetrics:UIBarMetricsDefault]; } - (void)viewDidLoad { [super viewDidLoad]; // 屏幕邊緣滑動(只能在屏幕的邊緣才能觸發(fā)該手勢,不能在屏幕的任意一點觸發(fā)該手勢) UIScreenEdgePanGestureRecognizer *edgePanGestureRecognizer = (UIScreenEdgePanGestureRecognizer *)self.interactivePopGestureRecognizer; // 滑動手勢(禁用系統(tǒng)自帶的屏幕邊緣滑動手勢,使用自定義的滑動手勢目的就是達到觸摸屏幕上的任意一點向右滑動都能實現(xiàn)返回的效果) UIPanGestureRecognizer *panGestureRecognizer = [[UIPanGestureRecognizer alloc] initWithTarget:edgePanGestureRecognizer.delegate action:@selector(handleNavigationTransition:)]; panGestureRecognizer.delegate = self; [self.view addGestureRecognizer:panGestureRecognizer]; // 禁用系統(tǒng)的屏幕邊緣滑動手勢 edgePanGestureRecognizer.enabled = NO; } // 是否允許觸發(fā)手勢,如果是根視圖控制器則不需要 - (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldReceiveTouch:(UITouch *)touch { return self.childViewControllers.count > 1; } - (void)pushViewController:(UIViewController *)viewController animated:(BOOL)animated { // 統(tǒng)一設置返回按鈕 NSInteger count = self.childViewControllers.count; if (count > 0) { viewController.hidesBottomBarWhenPushed = YES; viewController.navigationItem.leftBarButtonItem = [UIBarButtonItem backBarButtonItemWithImage:[UIImage imageNamed:@"navigationButtonReturn"] highlightImage:[UIImage imageNamed:@"navigationButtonReturnClick"] tagert:self action:@selector(back) title:@"返回"]; } [super pushViewController:viewController animated:animated]; } - (void)back { [self popViewControllerAnimated:YES]; } @end
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- 實例講解iOS中的UIPageViewController翻頁視圖控制器
- iOS開發(fā)中導航控制器的基本使用教程
- 詳解iOS開發(fā)中使用storyboard創(chuàng)建導航控制器的方法
- iOS應用開發(fā)中UITabBarController標簽欄控制器使用進階
- iOS開發(fā)中的ViewController轉場切換效果實現(xiàn)簡介
- iOS AVPlayer切換播放源實現(xiàn)連續(xù)播放和全屏切換的方法
- iOS使用pageViewController實現(xiàn)多視圖滑動切換
- 比較IOS開發(fā)中常用視圖的四種切換方式
- iOS 頁面滑動與標題切換顏色漸變的聯(lián)動效果實例
- iOS實現(xiàn)多控制器切換效果
相關文章
iOS使用GCDSocketManager實現(xiàn)長連接的方法
下面想就為大家分享一篇iOS使用GCDSocketManager實現(xiàn)長連接的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12iOS開發(fā)WebViewJavascriptBridge通訊原理解析
這篇文章主要為大家介紹了iOS開發(fā)WebViewJavascriptBridge通訊原理示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11圖文講解如何解決App的iOS 7頂部狀態(tài)欄適配問題
至今很多iOS App還要照顧到iOS 7進行最低的版本適配,而iOS7開始status bar的實際屏幕占用情況與iOS 6等不盡相同,這里我們就來以圖文講解如何解決App的iOS 7頂部狀態(tài)欄適配問題2016-06-06iOS基于UIScrollView實現(xiàn)滑動引導頁
這篇文章主要為大家詳細介紹了iOS基于UIScrollView實現(xiàn)滑動引導頁的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01iOS開發(fā)中使用UIDynamic來捕捉動畫組件的重力行為
這篇文章主要介紹了iOS開發(fā)中使用UIDynamic來捕捉動畫組件的重力行為的方法,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-12-12