IOS導覽列的使用方法,IOS導覽列使用方法
本文是使用純程式碼實現一個導覽列的效果。單擊按鈕並且產生事件。基本思路是:
1.建立一個導覽列(UINavigationBar對象)
2.建立一個導覽列集合(UINavigationItem對象)
3.建立一個左邊按鈕、一個右邊按鈕(UIBarButtonItem對象),並實現對應的事件方法
4.將導覽列集合添加到導覽列中,設定動畫關閉
5.把左右兩個按鈕添加到導覽列集合中去
6.在視圖中顯示當前建立的導覽列
具體的實現代碼如下:
ViewController.h檔案中的代碼不用改變,如下所示:
[cpp] view plaincopy
- #import <UIKit/UIKit.h>
-
- @interface ViewController : UIViewController
-
- @end
ViewController.m檔案中的代碼:
[cpp] view plaincopy
- #import "ViewController.h"
-
- @interface ViewController ()
-
- @end
-
- @implementation ViewController
-
- - (void)viewDidLoad
- {
- [super viewDidLoad];
- // Do any additional setup after loading the view, typically from a nib.
-
- //建立一個導覽列
- UINavigationBar *navBar = [[UINavigationBar alloc] initWithFrame:CGRectMake(0, 0, 320, 44)];
- //建立一個導覽列集合
- UINavigationItem *navItem = [[UINavigationItem alloc] initWithTitle:nil];
- //在這個集合Item中添加標題,按鈕
- //style:設定按鈕的風格,一共有三種選擇
- //action:@selector:設定按鈕的點擊事件
- //建立一個左邊按鈕
- UIBarButtonItem *leftButton = [[UIBarButtonItem alloc] initWithTitle:@"左邊" style:UIBarButtonItemStyleBordered target:self action:@selector(clickLeftButton)];
- //建立一個右邊按鈕
- UIBarButtonItem *rightButton = [[UIBarButtonItem alloc] initWithTitle:@"右邊" style:UIBarButtonItemStyleDone target:self action:@selector(clickRightButton)];
-
- //設定導覽列的內容
- [navItem setTitle:@"淩淩漆"];
-
- //把導覽列集合添加到導覽列中,設定動畫關閉
- [navBar pushNavigationItem:navItem animated:NO];
-
- //把左右兩個按鈕添加到導覽列集合中去
- [navItem setLeftBarButtonItem:leftButton];
- [navItem setRightBarButtonItem:rightButton];
-
- //將標題列中的內容全部添加到主視圖當中
- [self.view addSubview:navBar];
-
- //最後將控制項在記憶體中釋放掉,以避免記憶體泄露
- [navItem release];
- [leftButton release];
- [rightButton release];
- }
-
- -(void)showDialog:(NSString *)str
- {
- UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"這是一個對話方塊" message:str delegate:self cancelButtonTitle:@"確定" otherButtonTitles: nil];
- [alert show];
- [alert release];
- }
-
- -(void) clickLeftButton
- {
- [self showDialog:@"點擊了導覽列左邊按鈕"];
- }
-
- -(void) clickRightButton
- {
- [self showDialog:@"點擊了導覽列右邊按鈕"];
- }
-
- - (void)viewDidUnload
- {
- [super viewDidUnload];
- // Release any retained subviews of the main view.
- }
-
- - (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
- {
- return (interfaceOrientation != UIInterfaceOrientationPortraitUpsideDown);
- }
-
- @end
什iOS 應用的導覽列(nav bar)設計特別且出色優秀?
整體風格非常簡潔,和 Metro 一樣,細細的字型在 Jetsetter 的導航裡也扮演了很重要的角色。他的導覽列巧妙地結合了產品的 Logo (各欄目首頁時顯示)、載入時的菊花(轉場時顯示)以及返回欄目首頁的按鈕,全都是黑色的圓圈為背景,並且過渡的時候有平滑的翻轉動效。500px一直不太喜歡下拉框這個控制項,把功能隱藏在一個未知菜單裡面給我的感覺不是很好。但在 500px 這個 App 的導覽列上使用下拉框我卻覺得是個很好的設計。因為他抓住了使用者進這個 App 就是看圖為主的需求,把繁雜但又不是特別必須的導航都放到了頂部比較細的導覽列,點擊後以下拉框的形式出現,比起傳統的導覽列加 Tab bar 要稍微節省一點空間,保證了使用者一開啟 App 就是撲面而來的美圖。而這個導覽列的形式(Logo / 返回 + 當前頁類型表徵圖 / 頭像 + 標題文本)在後面的詳細頁面也貫徹得很統一。
Linkedin最大的特色是「小三角」,不管在哪一級頁面,只要認準了 Logo 或者標題下面這個小三角,按一下就能回首頁。
SparrowSparrow 的導覽列裡也有小三角的設計,不過這是在有對話的郵件介面標題下方,功能也和 Linkedin 不一樣,他是用來切換當前郵件介面和該對話記錄列表的。而在郵件清單介面也就是首頁裡,導覽列支援橫滑的手勢 / 點擊切換 Inbox、Unread 和 Starred。初看的時候覺得 Inbox 下面那三個小點太過小了,實在看不清,但一想就明白了,總共就三項,不擔心使用者找不到自己在哪裡,更主要的功能反而是讓習慣了這種形式的使用者知道標題列這裡是支援手勢滑動的。
Gmail這貨的導覽列特別之處是。。。能讓你有一種用 iPhone 跑 Android 應用的趕腳,你以為你個小樣從本來的三個點到現在套一件三角馬甲我就不認識你了嗎?哈哈哈
ios613的地圖怎使用導航
你說的什麼導航 內建的地圖導航還是第三方的