cocoa編程中視圖控制器與視圖類(lèi)介紹

字號(hào):


    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];
    }