iOS UIKit:TabBar Controller
1 结构剖析
IOS中的标签导航其实是一个UITabBarController对象,其也是一个Container View Controller。UITabBarController对象创建和管理了一组content View Controller,以及一个UITabBar对象(标签栏)。每个content View Controller都被占用一个tab(标签项),当用户点击其中一个tab时,Tab Bar Controller就选择那个tab并显示其相关content view controller的view对象。
1.1 UITabBarController类型
UITabBarController对象内部有一个content view controller类型的数组,并且有一个UITabBar对象(标签栏)。通过标签栏控制content view controller的显示。如图 21所示一个UITabBarController对象与其内部view controller之间的关系。图中的viewControllers数组元素表示tab的一个content view controller。

图 21 A tab bar controller and its associated view controllers
UITabBarController类除了上图这些属性外,其内容还拥有许多属性,其具体所有属性名和含义如表 21所示。
表 21 UITabBarController成员属性
|
属性名 |
类型 |
描述 |
|
viewControllers |
NSArray<UIViewController *> |
content view controller集,是显示的内容。 |
|
selectedViewController |
UIViewController |
当前标签显示的内容,即是viewControllers的其中一个元素 |
|
tabBar |
UITabBar |
导航栏对象,该属性内部也拥有许多属性 |
|
delegate |
id<UITabBarControllerDelegate> |
一个Delegate对象 |
|
customizableViewControllers |
NSArray<UIViewController *> |
|
|
selectedIndex |
NSUInteger |
当前显示视图在viewControllers数组中的位置,若选择的是More navigation controller,则该属性为NSNotFound. |
|
moreNavigationController |
UINavigationController |
1.2 UITabBar类型
UITabBarController对象将标签栏委托给了tabBar属性,该属性为UITabBar类型。标签栏中有多个标签,而这些标签是存放在UITabBar对象内部的数组中;同时UITabBar对象也有一个Delegate属性,与UINavigation类似,将Delegate指向UITabBarController对象,无法改变其指向。不过它没有UINavigationBar那么复杂,其内部主要的属性如表 22所示:
表 22 UITabBar类成员属性
|
属性名 |
类型 |
描述 |
|
items |
NSArray<UITabBarItem *> |
标签项数组,每一个元素都是UITabBarItem类型 |
|
selectedItem |
UITabBarItem* |
当前标签视图中显示的标签项 |
|
delegate |
id< UITabBarDelegate> |
标签Delegate |
|
backgroundImage |
背景图片 |
|
|
itemWidth |
标签的宽度 |
1.3 UITabBarItem类型
UITabBarItem对象是标签栏(UITabBar对象)中的一项标签,其是显示的具体内容。内部的主要属性只有两项,如表 23所示。
表 23 UITabBarItem成员属性
|
属性名 |
类型 |
描述 |
|
selectedImage |
UIImage* |
被选中时,显示的图片 |
|
badgeValue |
NSString* |
徽章显示内容,默认为nil |
2 创建界面
2.1 Storyboard方式
通过storyboard创建tab bar界面比较简单,如下是创建步骤:
1) 只需从lib中拖动一个tab bar controller控件到工作区;
2) 若需添加content view controlller为新的标签,则只需从tab bar controller的view controllers属性拖到新的标签,即可增加一个新的content view controller,如图 22所示。

图 22 添加新的标签
3) 若要修改标签项的属性,可以选中某一项标签项content view controller的底部栏,注意不是tab bar controller的底部;然后即可修改相应属性;

图 23 修改标签栏属性
注意:
若往tab bar controller对象中的viewControllers数组添加的元素超过5元素,那么tab bar controller将自动插入一个特殊view controller(称为"More view controller"),用其显示超过的元素。这个More view controller提供一个定制的接口来显示过多的view controller,并且它不能被自定义。它的显示是自动的,并与content view controller对象分开。但可通过UITabBarController对象的moreNavigationController属性获得More view controller对象的引用。
2.2 Program方式
通过程序创建标签控制器比较麻烦,而且由于UITabBarController对象内部的tabBar属性无法直接修改,又增加了一些困难。如下是一种创建过程:
a) 创建若干个UITabBarItem对象;
b) 创建若干个Content View Controller对象,并对每个对象的tabBarItem属性进行初始化为上述的某个UITabBarItem对象;从而组成一个Content View Controller类型的数组;
c) 创建UITabBarController对象,并对其viewControllers属性进行初始化为上述创建的Content View Controller类型的数组;
d) 将UITabBarController对象添加到其父view controller,同时将UITabBarController对象的view添加到其父view中。
如下所示的创建过程:
1 - (void)viewDidLoad {
2 [super viewDidLoad];
3
4 UITabBarItem* theItem1 = [[UITabBarItem alloc] initWithTitle:@"Home" image:nil tag:0];
5 UITabBarItem* theItem2 = [[UITabBarItem alloc] initWithTitle:@"low" image:nil tag:0];
6
7 tabViewController* vc1 = [self.storyboard instantiateViewControllerWithIdentifier:@"tabViewController"];
8 tabViewController* vc2 = [self.storyboard instantiateViewControllerWithIdentifier:@"tabViewController"];
9 vc1.tabBarItem = theItem1;
10 vc2.tabBarItem = theItem2;
11
12 UITabBarController *_tabBarController = [[UITabBarController alloc] init];
13 NSArray* controllers = [NSArray arrayWithObjects:vc1, vc2, nil];
14 _tabBarController.viewControllers = controllers;
15
16 [self addChildViewController:_tabBarController];
17 [self.view addSubview:_tabBarController.view];
18 }
注意:
由于UITabBarController对象内部的tabBar属性无法直接修改,不能通过获得tabBar属性,然后修改内部的tabBarItem对象;只能通过content view controller对象来修改其tabBarItem对象,这点与storyboard方式类似,只能通过content view controller来修改标签信息。
3 管理tab
在创建了UITabBarController对象后,可以在运行状态下对其进行多种更改操作。其中除了不能直接通过UITabBarController对象来修改tabBar属性及内部成员外,其它UITabBarController成员属性都可改变。若希望改变tabBar属性,只能通过content view controller对象进行修改了。
3.1 增加或删除content VC
UITabBarController对象内部有个viewControllers属性(数组),可以修改这个数组,从而改变标签控制的显示内容。可以通过UITabBarController的setViewControllers:animated:方法修改viewControllers数组。
如下所示:
1 - (IBAction)processUserInformation:(id)sender
2 {
3 if ([self userDataIsValid])
4 {
5 NSMutableArray* newArray = [NSMutableArray arrayWithArray:self.tabBarController.viewControllers];
6 [newArray removeObject:self];
7 [self.tabBarController setViewControllers:newArray animated:YES];
8 }
9 }
3.2 阻止tab被选
可将标签栏的某个标签置为不可选状态,即当点击不可选标签时,无法进行content view controller切换。此时可以通过其委托对象Delegate的tabBarController:shouldSelectViewController:方法来实现。当用户点击标签栏的某个标签时,那么就会触发该方法,其中的shouldSelectViewController参数就是被触发标签项的content view controller引用。若该方法返回NO时,则不能切换到用户选择的标签项。
如下所示把所有标签都置为不可选,并当用户选择其中一个标签时,把相应的下标输出:
1 -(BOOL)tabBarController:(UITabBarController *)tabBarController shouldSelectViewController:(UIViewController *)viewController
2 {
3 NSArray* controllers = tabBarController.viewControllers;
4 for (int i=0; i<controllers.count; i++) {
5 if(controllers[i] == viewController)
6 {
7 NSLog(@"%d",i);
8 }
9 }
10 return NO;
11 }
3.3 更改tabBar信息
要修改tabBar信息,只能通过content view controller的tabBarItem属性进行更改。其中可以更改tabBarItem的徽章、标题、图像等信息。如下所示:
1 - (IBAction)btnDown:(id)sender {
2 _tabBarController.selectedViewController.tabBarItem.badgeValue = @"33";
3 [ _tabBarController.selectedViewController.tabBarItem setTitle:@"hello"];
4 }
4 参考文献
[1] View Controller Catalog for IOS
iOS UIKit:TabBar Controller的更多相关文章
- iOS UIKit:viewController之动画(5)
当弹出一个view controller时,UIKit提供了一些标准转换动画,并且也支持用户自定义的动画效果. 1 UIView动画 UIView是自带动画实现功能,其中有两种方式实现: ...
- iOS UIKit:Navigation Controllers
navigation controller是一种层次结构的container view controller,即其通过一个view controllers栈来管理内部的content view con ...
- iOS UIKit:TableView之单元格配置(2)
Table View是UITableView类的实例对象,其是使用节(section)来描述信息的一种滚动列表.但与普通的表格不同,tableView只有一行,且只能在垂直方向进行滚动.tableVi ...
- iOS UIKit:viewController之定义(2)
@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/c ...
- iOS UIKit:viewController之层次结构(1)
ViewController是iOS应用程序中重要的部分,是应用程序数据和视图之间的重要桥梁.且应用程序至少有一个view controller.每个view controller对象都负责和管理一个 ...
- iOS UIKit:view
@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css); @import url(/ ...
- iOS UIKit:App
1.App生命周期 IOS架构是由许多设计模式实现,如model-view-controller 和 delegation模式. 1.1 main函数 与其它框架类似,IOS框架的入口也是从main函 ...
- iOS UIKit:TableView之表格创建(1)
Table View是UITableView类的实例对象,其是使用节(section)来描述信息的一种滚动列表.但与普通的表格不同,tableView只有一行,且只能在垂直方向进行滚动.tableVi ...
- iOS UIKit:CollectionView之设计 (1)
collection view(UICollectionView对象)使用灵活和可扩展的布局来描述有序的数据项,其一般情况下以网格的形式来展示内容,但并非一定如此. 1 基础 为了将数据展示在屏幕中, ...
随机推荐
- 构建简单的 C++ 服务组件,第 1 部分: 服务组件体系结构 C++ API 简介
构建简单的 C++ 服务组件,第 1 部分: 服务组件体系结构 C++ API 简介 熟悉将用于 Apache Tuscany SCA for C++ 的 API.您将通过本文了解该 API 的主要组 ...
- 【GDOI 2011 DAY2 T3】零什么的最讨厌了 (快速求阶乘、中国剩余定理)
问题描述: 林记在做数学习题的时候,经常遇到这种情况:苦思冥想了很久终于把问题解出来,结果发现答案是0,久而久之林记在得到习题答案是0的时候就没有了做出一道难题的成就感.于是林记决定:以后出题,答案一 ...
- 【BZOJ 2820】 YY的GCD (莫比乌斯+分块)
YY的GCD Description 神犇YY虐完数论后给傻×kAc出了一题 给定N, M,求1<=x<=N, 1<=y<=M且gcd(x, y)为质数的(x, y)有多少 ...
- POP3、SMTP和IMAP之间的区别和联系
POP3 POP3是Post Office Protocol 3的简称,即邮局协议的第3个版本,它规定怎样将个人计算机连接到Internet的邮件服务器和下载电子邮件的电子协议.它是因特网电子邮件的第 ...
- Excel列表部分列表隐藏与取消隐藏
Excel列表部分列表隐藏与取消隐藏 2014-2-19 隐藏:选中需要隐藏的列(选中A.B.C....),右键单击所选部分,选择"隐藏"即可. 取消隐藏:从A选中至所见表格最后的 ...
- just so you're clear
The Google Resume的第一句话是: Just so you're clear: it was not my idea to give a talk to Microsoft Resear ...
- 【HDOJ】4585 Shaolin
Set可解,Treap也可解.(1) Treap /* */ #include <iostream> #include <string> #include <map> ...
- Electrification Plan(最小生成树)
http://acm.sdut.edu.cn:8080/vjudge/contest/view.action?cid=50#problem/D 最小生成树模板,注意的是这里有k个发电站,它们不再需要连 ...
- mybatis源码分析(3)——SqlSessionManager类
从上图可能看出,在 mybatis中,SqlSession的实现类有两个,其中SqlSessionManager类不但实现了SqlSession接口,同时也实现了SqlSessionFactory接口 ...
- 【转】Xcode7.1环境下上架iOS App到AppStore 流程 -- 不错!!
原文网址:http://www.jianshu.com/p/a8bd16be122f 1.官网地址 Apple Developer 地址:https://developer.apple.com/mem ...