【IOS】自定義UINavigationController看這篇就夠了

這篇文章足以應(yīng)對90%的APP應(yīng)用定制化的需求了.

首先我們創(chuàng)建一個(gè)類JDCustomNavigationController繼承UINavigationController

需要?jiǎng)?chuàng)建UINavigationController的時(shí)候只要用JDCustomNavigationController代替即可

默認(rèn)導(dǎo)航欄應(yīng)該是這個(gè)樣子的:


1.修改背景顏色:
在.m中實(shí)現(xiàn)如下方法

+ (void)initialize {
    //appearance方法返回一個(gè)導(dǎo)航欄的外觀對象
    //修改了這個(gè)外觀對象珍德,相當(dāng)于修改了整個(gè)項(xiàng)目中的外觀
    UINavigationBar *navigationBar = [UINavigationBar appearance];
    //設(shè)置導(dǎo)航欄背景顏色
    [navigationBar setBarTintColor:JDRGBColor(55,207,240,1)];
}

導(dǎo)航欄將會變成這樣:


2.設(shè)置導(dǎo)航欄標(biāo)題顏色

   //設(shè)置標(biāo)題欄顏色
    navigationBar.titleTextAttributes = @{NSForegroundColorAttributeName:[UIColor whiteColor],NSFontAttributeName : [UIFont systemFontOfSize:18]};
    

3.設(shè)置導(dǎo)航欄按鈕顏色

    //設(shè)置NavigationBarItem文字的顏色
  [navigationBar setTintColor:[UIColor whiteColor]];

導(dǎo)航欄就變成這個(gè)樣子了:


但是我們push其他頁面的時(shí)候?qū)Ш綑谑沁@樣個(gè)樣子的


怎么修改返回按鈕的文字呢?

-只需要重寫下邊的方法:

//重寫push后返回按鈕的文字,文字可以為空字符串.
- (void)pushViewController:(UIViewController *)viewController animated:(BOOL)animated
{
    //修改返回文字
    viewController.navigationItem.backBarButtonItem = [[UIBarButtonItem alloc] initWithTitle:@"返回" style:UIBarButtonItemStyleDone target:nil action:nil];
  
    [super pushViewController:viewController animated:animated];
}

就會變成這樣子了:


那如果我們連文字都不想要,想要完全的一個(gè)返回箭頭或者其他圖片怎么辦呢?
1.你可以將上邊的返回文字改為@"",這樣雖然可以,但是返回箭頭偏左,不太美觀,如下圖:



那怎么辦呢?
干脆重寫返回按鈕
但是要注意我的寫法:

- (void)pushViewController:(UIViewController *)viewController animated:(BOOL)animated
{
    //全部修改返回按鈕,但是會失去右滑返回的手勢
    if (viewController.navigationItem.leftBarButtonItem ==nil && self.viewControllers.count >=1) {
        
        viewController.navigationItem.leftBarButtonItem = [self creatBackButton];
    }
    
    [super pushViewController:viewController animated:animated];
}


-(UIBarButtonItem *)creatBackButton
{
    return [[UIBarButtonItem alloc]initWithImage:[[UIImage imageNamed:@"back"] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal]style:UIBarButtonItemStylePlain target:self action:@selector(popSelf)];
    
}
-(void)popSelf
{
    [self popViewControllerAnimated:YES];
}

用的是leftBarButtonItem而不是backBarButtonItem哦,具體區(qū)別請看這里
leftBarButtonItem與backBarButtonItem的區(qū)別

if (viewController.navigationItem.leftBarButtonItem ==nil && self.viewControllers.count >=1) 

這個(gè)判斷是為了最底層的viewcontroller不至于加上我們自定義的按鈕
運(yùn)行之后的效果:

但是有個(gè)我們,我發(fā)現(xiàn)系統(tǒng)的右滑返回失效了,怎么辦呢?
別著急,只要在viewDidload中添加以下方法即可

//重寫了leftbarItem之后,需要添加如下方法才能重新啟用右滑返回
    if ([self respondsToSelector:@selector(interactivePopGestureRecognizer)]) {
        self.interactivePopGestureRecognizer.delegate = nil;
    }

這樣足夠使用了吧.

另外附隱藏某個(gè)導(dǎo)航欄背景透明的方法

 - (void)viewWillAppear:(BOOL)animated
 {
   [super viewWillAppear:animated];
   //設(shè)置導(dǎo)航欄背景圖片為一個(gè)空的image爆存,這樣就透明了
   [self.navigationBar setBackgroundImage:[[UIImage alloc] init]     forBarMetrics:UIBarMetricsDefault];
   //去掉透明后導(dǎo)航欄下邊的黑邊
   [self.navigationBar setShadowImage:[[UIImage alloc] init]];
 }
 
 - (void)viewWillDisappear:(BOOL)animated{
 
   //如果不想讓其他頁面的導(dǎo)航欄變?yōu)橥该?需要重置
   [self.navigationController.navigationBar setBackgroundImage:nil forBarMetrics:UIBarMetricsDefault];
   [self.navigationController.navigationBar setShadowImage:nil];
 }

其他小知識點(diǎn):

    //設(shè)置導(dǎo)航欄文字的主題
     NSShadow *shadow = [[NSShadow alloc]init];
     [shadow setShadowOffset:CGSizeZero];
     [navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName : [UIColor whiteColor],NSShadowAttributeName : shadow}];
     [navigationBar setBackgroundImage:[UIImage imageNamed:@"ic_cell_bg_selected"] forBarMetrics:UIBarMetricsDefault];
     //修改所有UIBarButtonItem的外觀
     UIBarButtonItem *barButtonItem = [UIBarButtonItem appearance];
     
     // 修改item的背景圖片
     //[barItem setBackgroundImage:[UIImage imageNamed:@"navigationbar_button_background.png"] forState:UIControlStateNormal barMetrics:UIBarMetricsDefault];
     //[barItem setBackgroundImage:[UIImage imageNamed:@"navigationbar_button_background_pushed.png"] forState:UIControlStateHighlighted barMetrics:UIBarMetricsDefault];
     //修改item上面的文字樣式
     NSDictionary *dict =@{NSForegroundColorAttributeName : [UIColor whiteColor],NSShadowAttributeName : shadow};
     [barButtonItem setTitleTextAttributes:dict forState:UIControlStateNormal];
     [barButtonItem setTitleTextAttributes:dict forState:UIControlStateHighlighted];
     //修改返回按鈕樣式
     [barButtonItem setBackButtonBackgroundImage:[UIImage imageNamed:NAVIGATION_BAR_BACK_ICON_NAME] forState:UIControlStateNormal barMetrics:UIBarMetricsCompact];
     //設(shè)置狀態(tài)欄樣式
     [[UIApplication sharedApplication]setStatusBarStyle:UIStatusBarStyleLightContent];

Demo地址:https://github.com/yuying2012/WJDStudyLibrary
這是一個(gè)大工程,請從工程中尋找相關(guān)模塊代碼.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市搔弄,隨后出現(xiàn)的幾起案子贫母,更是在濱河造成了極大的恐慌文兑,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件腺劣,死亡現(xiàn)場離奇詭異绿贞,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)橘原,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進(jìn)店門籍铁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來涡上,“玉大人,你說我怎么就攤上這事拒名》岳ⅲ” “怎么了?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵靡狞,是天一觀的道長耻警。 經(jīng)常有香客問我,道長甸怕,這世上最難降的妖魔是什么甘穿? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮梢杭,結(jié)果婚禮上温兼,老公的妹妹穿的比我還像新娘。我一直安慰自己武契,他們只是感情好募判,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著咒唆,像睡著了一般届垫。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上全释,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天装处,我揣著相機(jī)與錄音,去河邊找鬼浸船。 笑死妄迁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的李命。 我是一名探鬼主播登淘,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼封字!你這毒婦竟也來了黔州?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤周叮,失蹤者是張志新(化名)和其女友劉穎辩撑,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體仿耽,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡合冀,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了项贺。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片君躺。...
    茶點(diǎn)故事閱讀 39,834評論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡峭判,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出棕叫,到底是詐尸還是另有隱情林螃,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布俺泣,位于F島的核電站疗认,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏伏钠。R本人自食惡果不足惜横漏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望熟掂。 院中可真熱鬧缎浇,春花似錦、人聲如沸赴肚。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽誉券。三九已至指厌,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間踊跟,已是汗流浹背仑乌。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留琴锭,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓衙传,卻偏偏與公主長得像决帖,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子蓖捶,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評論 2 354

推薦閱讀更多精彩內(nèi)容