uitabbarcontroller類
選項(xiàng)卡類允許用戶在多個(gè)視圖控制器之間移動(dòng)并在屏幕的底部可定制該欄。向不同的視圖同時(shí)提供一次單擊訪問(wèn),向用戶選擇的屏幕和編輯底欄的屏幕同時(shí)提供more按鈕。
選項(xiàng)卡類的方便之處就是 不需要象導(dǎo)航欄那樣以棧的方式推入和彈出視圖的操作,而是組建一系列的控制器(它們各自可以是uiviewcontroller、uinavigationcontroller、uitableviewcontroller或其他任何類型的視圖控制器),并通過(guò)設(shè)置欄的viewcontrollers屬性將其添加到選項(xiàng)卡欄,使每個(gè)選項(xiàng)卡對(duì)應(yīng)一個(gè)試圖控制器。
一、創(chuàng)建uitabbarcontroller
常見(jiàn)的在應(yīng)用程序委托類的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類中創(chuàng)建uitabbarcontroller,相當(dāng)于創(chuàng)建了一個(gè)基于tab bar的工程項(xiàng)目。不過(guò),也可以視具體情況,我們直接在一個(gè)獨(dú)立的視圖控制器中創(chuàng)建uitabbarcontroller實(shí)例對(duì)象,如自定義一個(gè)用于視圖切換的控制器類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)用戶選擇一個(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)置用戶默認(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ù)專欄