UITabBarController
一、UITabBarController的简单使用
UITabBarController的使用步骤
1. 初始化UITabBarController
2. 设置UIWindow的rootViewController为UITabBarController
3. 根据具体情况,通过addChildViewController方法添加对应个数的子控制器
二、UITabBarController的子控制器
UITabBarController添加控制器的方式有2种
添加单个子控制器
- (void)addChildViewController:(UIViewController *)childController;
设置子控制器数组
@property(nonatomic,copy) NSArray *viewControllers;
三、UITabBar
如果UITabBarController有N个子控制器,那么UITabBar内部就会有N个UITabBarButton作为子控件
如果UITabBarController有4个子控制器,那么UITabBar的结构大致如下图所示
四、UITabBarButton
nUITabBarButton里面显示什么内容,由对应子控制器的tabBarItem属性决定
nUITabBarItem有以下属性影响着UITabBarButton的内容
Ø标题文字
@property(nonatomic,copy) NSString *title;
Ø图标
@property(nonatomic,retain) UIImage *image;
Ø选中时的图标
@property(nonatomic,retain) UIImage *selectedImage;
Ø提醒数字
@property(nonatomic,copy) NSString *badgeValue;
五、代码
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
//1.创建window
self.window = [[UIWindow alloc]initWithFrame:[UIScreen mainScreen].bounds];
self.window.backgroundColor = [UIColor whiteColor];
//2.设置window的根控制器
//2.1创建UITabBarController
UITabBarController * tbVc = [[UITabBarController alloc]init];
//2.2设置根控制器
self.window.rootViewController = tbVc;
//2.3创建并添加子控制器
//2.3.1创建子控制器
//----1-----
UIViewController * vc1 = [[UIViewController alloc]init];
vc1.tabBarItem.title = @"消息";
vc1.tabBarItem.image = [UIImage imageNamed:@"tab_recent_nor"];
vc1.tabBarItem.badgeValue = @"68M";
vc1.view.backgroundColor = [UIColor purpleColor];
//-----2---
UIViewController * vc2 = [[UIViewController alloc]init];
vc2.tabBarItem.title = @"联系人";
vc2.tabBarItem.image = [UIImage imageNamed:@"tab_buddy_nor"];
vc2.view.backgroundColor =[UIColor brownColor];
//-----3-----
UIViewController *vc3 = [[UIViewController alloc]init];
vc3.view.backgroundColor = [UIColor blueColor];
//2.3.2添加子控制器
[tbVc addChildViewController:vc1];
[tbVc addChildViewController:vc2];
[tbVc addChildViewController:vc3];
//3.显示window
[self.window makeKeyAndVisible];
return YES;
}
六、图示
七、Storyboard创建的图示