cocoa編程中視圖控制器與視圖類介紹

字號:


    uitabbarcontroller類
    選項卡類允許用戶在多個視圖控制器之間移動并在屏幕的底部可定制該欄。向不同的視圖同時提供一次單擊訪問,向用戶選擇的屏幕和編輯底欄的屏幕同時提供more按鈕。
    選項卡類的方便之處就是 不需要象導(dǎo)航欄那樣以棧的方式推入和彈出視圖的操作,而是組建一系列的控制器(它們各自可以是uiviewcontroller、uinavigationcontroller、uitableviewcontroller或其他任何類型的視圖控制器),并通過設(shè)置欄的viewcontrollers屬性將其添加到選項卡欄,使每個選項卡對應(yīng)一個試圖控制器。
    一、創(chuàng)建uitabbarcontroller
    常見的在應(yīng)用程序委托類的applicationdidfinishlaunching:方法中創(chuàng)建,這通??蔀閼?yīng)用窗口提供根視圖。
    // 創(chuàng)建一個uitabbarcontroller對象
    代碼如下:
    uitabbarcontroller *tabbarcontroller = [[uitabbarcontroller alloc] init];
    // tabbarcontroller.delegate = self;
    // 創(chuàng)建一系列要添加到每個具體tab卡的視圖控制器
    代碼如下:
    myviewcontroller *vc1 = [[myviewcontroller alloc] init];
    myotherviewcontroller *vc2 = [[myviewcontroller alloc] init];
    // 將創(chuàng)建好的這些視圖控制器先添加到一個array對象中,再將此數(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)建了一個基于tab bar的工程項目。不過,也可以視具體情況,我們直接在一個獨(dú)立的視圖控制器中創(chuàng)建uitabbarcontroller實例對象,如自定義一個用于視圖切換的控制器類viewswitcherviewcontroller,就可在其中的viewdidload方法中創(chuàng)建所需要的tabbarcontroller。
    在實現(xiàn)uitabbarcontrollerdelegate委托的視圖控制器中重寫init方法來自定義uitabbaritem條目。
    代碼一是由initwithnibname:方法來加載具體的某個視圖控制器并自定義該控制器中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)部重寫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;
    }
    實現(xiàn)所需的委托方法,以讓uitabbarcontroller能夠正常觸發(fā)這些回調(diào)方法。
    代碼如下:
    tabbarcontroller:didselectviewcontroller: 是當(dāng)用戶選擇一個新的選項卡時,控制器會發(fā)送這個消息。
    - (void)tabbarcontroller:(uitabbarcontroller *)tabbarcontroller didselectviewcontroller:(uiviewcontroller *)viewcontroller
    {
    // 捕捉selectedindex,可確定當(dā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];
    // 選項卡圖標(biāo)項右上角紅色小紅圈數(shù)字提示
    viewcontroller.tabbaritem.badgevalue = [nsstring stringwithformat:@%d,80];
    }