開(kāi)發(fā)app時(shí)經(jīng)常用到的一個(gè)基本布局框架就是tabbar+navigation,也就是下方tabbar分模塊,然后在各個(gè)模塊中使用導(dǎo)航欄深入到各個(gè)界面。

成都創(chuàng)新互聯(lián)公司是一家以重慶網(wǎng)站建設(shè)公司、網(wǎng)頁(yè)設(shè)計(jì)、品牌設(shè)計(jì)、軟件運(yùn)維、seo優(yōu)化排名、小程序App開(kāi)發(fā)等移動(dòng)開(kāi)發(fā)為一體互聯(lián)網(wǎng)公司。已累計(jì)為成都食品包裝袋等眾行業(yè)中小客戶提供優(yōu)質(zhì)的互聯(lián)網(wǎng)建站和軟件開(kāi)發(fā)服務(wù)。
有時(shí)候我們需要在跳轉(zhuǎn)到某些界面時(shí)隱藏下方的tabbar,怎么做呢,很簡(jiǎn)單:
這樣就可以了,其實(shí)最后一行不要也能行。
只要在對(duì)某個(gè)界面設(shè)置隱藏后,從這個(gè)界面繼續(xù)深入往下的界面也是會(huì)自動(dòng)隱藏的,不需要對(duì)每個(gè)都設(shè)置。
這里的bottombar不單單作用于tabbar,其他的bar也是可以的。但一般常用的還是tabbar。
查看作者首頁(yè)
UITabBarController是IOS中很常用的一個(gè)viewController,例如系統(tǒng)的鬧鐘程序,ipod程序等。UITabBarController通常作為整個(gè)程序的rootViewController,而且不能添加到別的container viewController中。
首先我們看一下它的view層級(jí)圖:
一、手動(dòng)創(chuàng)建UITabBarController
最常見(jiàn)的創(chuàng)建UITabBarController的地方就是在application delegate中的 applicationDidFinishLaunching:方法,因?yàn)閁ITabBarController通常是作為整個(gè)程序的rootViewController的,我們需要在程序的window顯示之前就創(chuàng)建好它,具體步驟如下:
1、創(chuàng)建一個(gè)UITabBarController對(duì)象
2、創(chuàng)建tabbarcontroller中每一個(gè)tab對(duì)應(yīng)的要顯示的對(duì)象
3、通過(guò)UITabBarController的viewController屬性將要顯示的所有content viewcontroller添加到UITabBarController中
4、通過(guò)設(shè)置UITabBarController對(duì)象為window.rootViewController,然后顯示window
下面看一個(gè)簡(jiǎn)單的例子:
復(fù)制代碼
復(fù)制代碼
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];
// Override point for customization after application launch.
SvTabBarFirstViewController *viewController1, *viewController2;
viewController1 = [[SvTabBarFirstViewController alloc] initWithNibName:nil bundle:nil];
viewController1.title = @"First";
viewController2 = [[SvTabBarFirstViewController alloc] initWithNibName:nil bundle:nil];
viewController2.title = @"Second";
self.tabBarController = [[[UITabBarController alloc] init] autorelease];
self.tabBarController.delegate = self;
self.tabBarController.viewControllers = [NSArray arrayWithObjects:viewController1, viewController2, nil];
[viewController1 release];
[viewController2 release];
self.window.rootViewController = self.tabBarController;
[self.window makeKeyAndVisible];
return YES;
}
復(fù)制代碼
復(fù)制代碼
二、UITabBarItem
UITabBar上面顯示的每一個(gè)Tab都對(duì)應(yīng)著一個(gè)ViewController,我們可以通過(guò)設(shè)置viewcontroller.tabBarItem屬性來(lái)改變tabbar上對(duì)應(yīng)的tab顯示內(nèi)容。否則系統(tǒng)將會(huì)根據(jù)viewController的title自動(dòng)創(chuàng)建一個(gè),該tabBarItem只顯示文字,沒(méi)有圖像。當(dāng)我們自己創(chuàng)建UITabBarItem的時(shí)候,我們可以顯示的指定顯示的圖像和對(duì)應(yīng)的文字描述。當(dāng)然還可以通過(guò)setFinishedSelectedImage:withFinishedUnselectedImage:方法給選中狀態(tài)和飛選中狀態(tài)指定不同的圖片。下面看個(gè)自己創(chuàng)建UITabBarItem的小例子:
UITabBarItem *item = [[UITabBarItem alloc] initWithTitle:@"Second" image:nil tag:2];
[item setFinishedSelectedImage:[UIImage imageNamed:@"second.png"]
withFinishedUnselectedImage:[UIImage imageNamed:@"first.png"]];
viewController2.tabBarItem = item;
[item release];
此外UITabBarItem還有一個(gè)屬性badgeValue,通過(guò)設(shè)置該屬性可以在其右上角顯示一個(gè)小的角標(biāo),通常用于提示用戶有新的消息,使用很簡(jiǎn)單,后面有例子。
三、moreNavigationController
UITabBar上最多可以顯示5個(gè)Tab,當(dāng)我們往UITabBarController中添加超過(guò)的viewController超過(guò)5個(gè)時(shí)候,最后一個(gè)一個(gè)就會(huì)自動(dòng)變成,按照設(shè)置的viewControlles的順序,顯示前四個(gè)viewController的tabBarItem,后面的tabBarItem將不再顯示。當(dāng)點(diǎn)擊more時(shí)候?qū)?huì)彈出一個(gè)標(biāo)準(zhǔn)的navigationViewController,里面放有其它未顯示的的viewController,并且?guī)в幸粋€(gè)edit按鈕,通過(guò)點(diǎn)擊該按鈕可以進(jìn)入類(lèi)似與ipod程序中設(shè)置tabBar的編輯界面。編輯界面中默認(rèn)所有的viewController都是可以編輯的,我們可以通過(guò)設(shè)置UITabBarController的customizableViewControllers屬性來(lái)指定viewControllers的一個(gè)子集,即只允許一部分viewController是可以放到tabBar中顯示的。但是這塊兒要注意一個(gè)問(wèn)題就是每當(dāng)UITabBarController的viewControllers屬性發(fā)生變化的時(shí)候,customizableViewControllers就會(huì)自動(dòng)設(shè)置成跟viewControllers一致,即默認(rèn)的所有的viewController都是可以編輯的,如果我們要始終限制只是某一部分可編輯的話,記得在每次viewControlles發(fā)生改變的時(shí)候,重新設(shè)置一次customizableViewControllers。
四、UITabBarController的Rotation
UITabBarController默認(rèn)只支持豎屏,當(dāng)設(shè)備方向放生變化時(shí)候,它會(huì)查詢viewControllers中包含的所有ViewController,僅當(dāng)所有的viewController都支持該方向時(shí),UITabBarController才會(huì)發(fā)生旋轉(zhuǎn),否則默認(rèn)的豎向。
此處需要注意當(dāng)UITabBarController支持旋轉(zhuǎn),而且發(fā)生旋轉(zhuǎn)的時(shí)候,只有當(dāng)前顯示的viewController會(huì)接收到旋轉(zhuǎn)的消息。
五、UITabBar
UITabBar自己有一些方法是可以改變自身狀態(tài),但是對(duì)于UITabBarController自帶的tabBar,我們不能直接去修改其狀態(tài)。任何直接修改tabBar的操作將會(huì)拋出異常,下面看一個(gè)拋出異常的小例子:
復(fù)制代碼
復(fù)制代碼
self.tabBarController = [[[UITabBarController alloc] init] autorelease];
self.tabBarController.delegate = self;
self.tabBarController.viewControllers = [NSArray arrayWithObjects:viewController1, viewController2, viewController3, nil];
self.window.rootViewController = self.tabBarController;
[self.window makeKeyAndVisible];
self.tabBarController.tabBar.selectedItem = nil;
復(fù)制代碼
復(fù)制代碼
上面代碼的最后一行直接修改了tabBar的狀態(tài),運(yùn)行程序回得到如下結(jié)果:
六、Change Selected Viewcontroller
改變UITabBarController中當(dāng)前顯示的viewController,可以通過(guò)一下兩種方法:
1、selectedIndex屬性
通過(guò)該屬性可以獲得當(dāng)前選中的viewController,設(shè)置該屬性,可以顯示viewControllers中對(duì)應(yīng)的index的viewController。如果當(dāng)前選中的是MoreViewController的話,該屬性獲取出來(lái)的值是NSNotFound,而且通過(guò)該屬性也不能設(shè)置選中MoreViewController。設(shè)置index超出viewControllers的范圍,將會(huì)被忽略。
2、selectedViewController屬性
通過(guò)該屬性可以獲取到當(dāng)前顯示的viewController,通過(guò)設(shè)置該屬性可以設(shè)置當(dāng)前選中的viewController,同時(shí)更新selectedIndex。可以通過(guò)給該屬性賦值
tabBarController.moreNavigationController可以選中moreViewController。
3、viewControllers屬性
設(shè)置viewControllers屬性也會(huì)影響當(dāng)前選中的viewController,設(shè)置該屬性時(shí)UITabBarController首先會(huì)清空所有舊的viewController,然后部署新的viewController,接著嘗試重新選中上一次顯示的viewController,如果該viewController已經(jīng)不存在的話,會(huì)接著嘗試選中index和selectedIndex相同的viewController,如果該index無(wú)效的話,則默認(rèn)選中第一個(gè)viewController。
七、UITabBarControllerDelegate
通過(guò)代理我們可以監(jiān)測(cè)UITabBarController的當(dāng)前選中viewController的變化,以及moreViewController中對(duì)編輯所有viewController的編輯。通過(guò)實(shí)現(xiàn)下面方法:
- (BOOL)tabBarController:(UITabBarController *)tabBarController shouldSelectViewController:(UIViewController *)viewController;
該方法用于控制TabBarItem能不能選中,返回NO,將禁止用戶點(diǎn)擊某一個(gè)TabBarItem被選中。但是程序內(nèi)部還是可以通過(guò)直接setSelectedIndex選中該TabBarItem。
下面這三個(gè)方法主要用于監(jiān)測(cè)對(duì)moreViewController中對(duì)view controller的edit操作
- (void)tabBarController:(UITabBarController *)tabBarController willBeginCustomizingViewControllers:(NSArray *)viewControllers;
- (void)tabBarController:(UITabBarController *)tabBarController willEndCustomizingViewControllers:(NSArray *)viewControllers changed:(BOOL)changed;
- (void)tabBarController:(UITabBarController *)tabBarController didEndCustomizingViewControllers:(NSArray *)viewControllers changed:(BOOL)changed;
修改?TabBar?的?subview?的?frame?就可以了。其中,TabBar?的subview?共有兩個(gè),一個(gè)叫UITabBar,另一個(gè)叫UITranstionview。將UITabBar的?y?向下移49個(gè)單位,把UITranstionview 的?hight?加長(zhǎng) 49 個(gè)單位。但是有時(shí)候這樣隱藏tabbar后,原來(lái)的viewcontroller上的view就會(huì)被拉長(zhǎng)。解決方法是修改viewcontroller上的view?的autosizing。
以下是具體代碼,另加上了動(dòng)畫(huà)效果:
for?(UIView?*v?in?[self.tabBarController.view?subviews])?{
if?([v?isKindOfClass:[UITabBar?class]])?{
[UIView?animateWithDuration:kDuration?delay:0.0f?options:UIViewAnimationOptionCurveEaseOut?animations:^(){
CGRect?frame?=?v.frame;
frame.origin.y?+=?49.0f;
v.frame?=?frame;
}?completion:^(BOOL?complete)
{
isAnimating?=?NO;
}];
}?else?{
isAnimating?=?YES;
[UIView?animateWithDuration:kDuration?delay:0.0f?options:UIViewAnimationOptionCurveEaseOut?animations:^(){
CGRect?frame?=?v.frame;
frame.size.height?+=?49.0f;
v.frame?=?frame;
}?completion:nil];
}
}
如果使用系統(tǒng)的tabBar 最多只能顯示5個(gè),所以想要展示超過(guò)5個(gè) 就只能自己想辦法弄嘍!我用的辦法是:
1:先把系統(tǒng)的tabBar 隱藏掉 ?[ self .tabBar setHidden: YES ]; ? ps:在繼承了UITabBarController 的tabBar控制器里面!?
2:自定義個(gè)view添加到自定義的tabBar控制器里面,上面創(chuàng)建你想要的個(gè)數(shù)的按鈕!然后放在tabBar的位置上!
3:按鈕點(diǎn)擊的時(shí)候切換 tabBar 控制器的 selectIndex !至于按鈕的圖片文字之類(lèi)的 使用按鈕的系統(tǒng)類(lèi)型UIButtonTypeCustom 設(shè)置普通和選中的圖片以及文字 文字顏色等!
如圖:
網(wǎng)站欄目:ios開(kāi)發(fā)tabbar,IOS開(kāi)發(fā)者模式
當(dāng)前URL:http://chinadenli.net/article6/dsedcog.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、微信小程序、網(wǎng)站營(yíng)銷(xiāo)、商城網(wǎng)站、網(wǎng)站策劃、虛擬主機(jī)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)