標籤:
一 修改導覽列顏色 導覽列在哪個頁面代碼放在那裡面
self.navigationController.navigationBar.tintColor = [UIColor colorWithRed:(21.0/255.0) green:(153.0 / 255.0) blue:(224.0 / 255.0) alpha:1]; //定義導覽列顏色
self.navigationItem.title = @"自訂"; //定義導覽列的標題
二 導覽列內建一個返回按鈕,我們需要定製它的樣式,這可以有許多辦法。比如 Hack 導覽列的視圖層次。如果你不想 Hack 導覽列,那麼你可以使用NavigationBarDelegate。問題在於,如果是導航控制器內建的NavigationBar,你將不能訪問NavigationBar(程式會Crash)。這是蘋果文檔中的說明:
Note that if you use aUINavigationController object to manage hierarchical navigation, you should notdirectly access the navigation bar object.
這裡,我們提供另一種“定製”方法。也許不能稱之為定製,因為我們實際上是將預設的返回按鈕隱藏了,並提供一個自訂的返回按鈕作為導覽列的leftButton。使用這種方法,我們不僅可以定製按鈕的樣式(標題和背景圖片),而且可以觸發自訂的方法。預設的返回按鈕動作是popViewController,我們可以修改為其他動作。
這個過程大概分為4個步驟:
1、隱藏預設返回按鈕,這是通過設定navigationItem的hidesBackButton為YES做到的:
//隱藏預設的"返回"按鈕
[self.navigationItemsetHidesBackButton:YES];
2、自訂一個BarButtonItem。首先,我們定製一個UIButton。 這個UIButton用buttonWithType:UIButtonTypeCustom方法初始化。然後用setBarckgroundImage方法定製按鈕的背景圖片,用addTarget方法指定按鈕的事件處理方法。這樣我們就獲得了一個完全定製的Button。BarButtonItem有一個initWithCustomView:的初始化方法。我們可以把一個定製的視圖(比如我們定製的Button)作為這個方法的參數,構建出一個BarButtonItem。
//自訂導覽列的"返回"按鈕
UIButton*btn = [UIButtonbuttonWithType:UIButtonTypeCustom];
btn. frame=CGRectMake(15, 5, 38, 38);
[btn setBackgroundImage:[UIImage imageNamed:@"返回.png"] forState:UIControlStateNormal];
[btn addTarget:selfaction:@selector(goBackAction)forControlEvents:UIControlEventTouchUpInside];
UIBarButtonItem*back=[[UIBarButtonItemalloc]initWithCustomView:btn];
3、把BarButtonItem 設定為 navigationItem的leftBarButton。
//設定導覽列的leftButton
self.navigationItem.leftBarButtonItem=back;
4、編寫Button的事件代碼。
-(void)goBackAction{
// 在這裡增加返回按鈕的自訂動作
[self.navigationControllerpopViewControllerAnimated:YES];
}
轉自:http://blog.sina.com.cn/s/blog_a5ef060c01013946.html
著作權聲明:本文為博主原創文章,未經博主允許不得轉載。
ios開發之自訂預設產生的導覽列 標題 顏色 返回按鈕