UITabBarController類(lèi)
選項(xiàng)卡類(lèi)允許用戶(hù)在多個(gè)視圖控制器之間移動(dòng)并在屏幕的底部可定制該欄。向不同的視圖同時(shí)提供一次單擊訪問(wèn),向用戶(hù)選擇的屏幕和編輯底欄的屏幕同時(shí)提供More按鈕。
選項(xiàng)卡類(lèi)的方便之處就是 不需要象導(dǎo)航欄那樣以棧的方式推入和彈出視圖的操作,而是組建一系列的控制器(它們各自可以是UIViewController、UINavigationController、UITableViewController或其他任何類(lèi)型的視圖控制器),并通過(guò)設(shè)置欄的viewControllers屬性將其添加到選項(xiàng)卡欄,使每個(gè)選項(xiàng)卡對(duì)應(yīng)一個(gè)試圖控制器。
一、創(chuàng)建UITabBarController
常見(jiàn)的在應(yīng)用程序委托類(lèi)的applicationDidFinishLaunching:方法中創(chuàng)建,這通??蔀閼?yīng)用窗口提供根視圖。
// 創(chuàng)建一個(gè)UITabBarController對(duì)象
代碼如下:
UITabBarController *tabBarController = [[UITabBarController alloc] init];
// tabBarController.delegate = self;
// 創(chuàng)建一系列要添加到每個(gè)具體Tab卡的視圖控制器
代碼如下:
MyViewController *vc1 = [[MyViewController alloc] init];
MyOtherViewController *vc2 = [[MyViewController alloc] init];
// 將創(chuàng)建好的這些視圖控制器先添加到一個(gè)Array對(duì)象中,再將此數(shù)組分配給Tab Bar Controller的viewControllers屬性
代碼如下:
NSArray *controllers = [NSArray arrayWithObjects:vc1,vc2,nil];
tabBarControllers.viewControllers = controllers;
/* 也或者
NSMutableArray *controllers =[[NSMutableArray alloc] initWithCapacity:2];
[controllers addObject:vc1];
[controllers addObject:vc2];
*/
// 將TabBar控制器的當(dāng)前視圖添加到窗口
[window addSubview:tabBarController.view];
當(dāng)然在應(yīng)用程序委托AppDelegate類(lèi)中創(chuàng)建UITabBarController,相當(dāng)于創(chuàng)建了一個(gè)基于Tab Bar的工程項(xiàng)目。不過(guò),也可以視具體情況,我們直接在一個(gè)獨(dú)立的視圖控制器中創(chuàng)建UITabBarController實(shí)例對(duì)象,如自定義一個(gè)用于視圖切換的控制器類(lèi)ViewSwitcherViewController,就可在其中的viewDidLoad方法中創(chuàng)建所需要的TabBarController。
在實(shí)現(xiàn)UITabBarControllerDelegate委托的視圖控制器中重寫(xiě)init方法來(lái)自定義UITabBarItem條目。
代碼一是由initWithNibName:方法來(lái)加載具體的某個(gè)視圖控制器并自定義該控制器中TabBarItem樣式外觀等。
代碼如下:
- (id)init {
if(self = [super initWithNibName:@"MyViewController" bundle:nil]) {
self.title = @"My View Controller";
UIImage *anImage = [UIImage imageNamed:@"MyImage.png"];
UITabBarItem *theItem = [[UITabBarItem alloc] initWithTitle:@"Home" image:anImage tag:0];
self.tabBarItem = theItem;
[theItem release];
}
return self;
}
代碼二我們也可以直接在具體的視圖控制器內(nèi)部重寫(xiě)init方法。
代碼如下:
- (id)init {
if([super init] != nil) {
UITabBarItem *item = [[UITabBarItem alloc] initWithTitle:@"Home" image:[UIImage imageNamed:@"MyImage.png"] tag:0];
self.tabBarItem = item;
[item release];
}
return self;
}
實(shí)現(xiàn)所需的委托方法,以讓UITabBarController能夠正常觸發(fā)這些回調(diào)方法。
代碼如下:
tabBarController:didSelectViewController: 是當(dāng)用戶(hù)選擇一個(gè)新的選項(xiàng)卡時(shí),控制器會(huì)發(fā)送這個(gè)消息。
- (void)tabBarController:(UITabBarController *)tabBarController didSelectViewController:(UIViewController *)viewController
{
// 捕捉selectedIndex,可確定當(dāng)前所選選項(xiàng)卡
NSNumber *tabNumber = [NSNumber numberWithInt:[tabBarController selectedIndex]];
// 使用iPhone內(nèi)置用戶(hù)默認(rèn)系統(tǒng)NSUserDefaults,利用setObject:forKey:為關(guān)鍵字設(shè)定值
[[NSUserDefaults standardUserDefaults] setObject:tabNumber forKey:@"selectedTab"];
[[NSUserDefaults standardUserDefaults] synchronize];
// 選項(xiàng)卡圖標(biāo)項(xiàng)右上角紅色小紅圈數(shù)字提示
viewController.tabBarItem.badgeValue = [NSString stringWithFormat:@"%d",80];
}
更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄