纯代码搭建iOS三级结构(UITabbarController+UINavigationController+UIViewController)

声明:这里所指的三级结构不是网上百度中所经常提及的三级框架或者MVC模式,而是指UITabbarController+UINavigationController+UIViewController。

效果图

效果图

技术要点

       三者其实是层层包含的关系,以tabbar为起点(接下来就不写类名全程了,看官们看懂就好),一个tabbar对应多个navigation,每个navigation对应着1个viewcontroller(当然实际上是可以多个的,在这里用不上而已),这样一来整个视图看起来就成了可以切换不同导航栏标题的多个视图。
技术要点

tabbar的设置

       tabbar设置可以很简单,但是这里我们搞复杂点,利用自定义的button放入tabbar中,当然在此之前,我们需要将原有tabbar中的UITabBarButton类型的所有`UITabBarButton类型的视图给删除即可。

#pragma mark 删除tabbar原始的item
- (void)removePreItem
{
    for (UIView *view in self.tabBar.subviews) {
        if ([view isKindOfClass:NSClassFromString(@"UITabBarButton")]) {
            [view removeFromSuperview];
        }
    }
#pragma mark 即将读取视图
- (void)viewWillAppear:(BOOL)animated
{
    [self removePreItem];
    [super viewWillAppear:animated];
}

       有一点要提示的是删除原有tabbar中item的方法要在viewWillAppear中执行,在viewDidLoad中执行则不会删除。
删除原有item方法无法执行
       删除完了之后,增加我们想要添加的按钮并设置点击事件——切换视图控制器。在tabbar中,切换视图控制器其实很简单,只需要self.selectedIndex = i;即可。

CGFloat itemOffsetX;
CGFloat itemOffsetY;
#pragma mark 增加自定义item
- (void)createItems
{
    //求图标宽度
    CGFloat tabbarWidth = self.tabBar.bounds.size.width;
    CGFloat itemWidth = (tabbarWidth - itemOffsetX * 5) / 4;

    //求图标高度
    CGFloat tabbarHeight = self.tabBar.bounds.size.height;
    CGFloat itemHeight = tabbarHeight - itemOffsetY * 2;

    //新建button

    for(int i = 0; i < 4; i ++)
    {
        UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom];
        btn.tag = i;
        [btn addTarget:self action:@selector(actItem:) forControlEvents:UIControlEventTouchUpInside];
        btn.frame = CGRectMake(itemOffsetX * (i+1) + itemWidth * i, 0, itemWidth, itemHeight);
        [btn setTitle:[NSString stringWithFormat:@"%d",i+1] forState:UIControlStateNormal];
        [btn setTitleColor:REDCOLOR forState:UIControlStateNormal];
        [btn setTitleColor:YELLOWCOLOR forState:UIControlStateHighlighted];
        [self.tabBar addSubview:btn];
    }
}
#pragma mark tabbar中item点击事件
- (void)actItem:(UIButton *)sender
{
    NSLog(@"click %@ button",sender.titleLabel.text);
    self.selectedIndex = sender.tag % 10;
}

       接下来是给tabbar添加视图,这些子视图应该是navigation,然后navigation中才把对应的viewcontroller收入囊中。navigation除了能像表层看到的那样能提供导航栏之外,实际上像栈那样push和pop栈中的viewcontroller。

#pragma mark 添加4个MainNavViewController到视图中
- (void)addNavViewController
{
    MainNavViewController *nav1 = [[MainNavViewController alloc]init];
    nav1.viewControllers = @[[[FirstViewController alloc]init]];
    MainNavViewController *nav2 = [[MainNavViewController alloc]init];
    nav2.viewControllers = @[[[SecondViewController alloc]init]];
    MainNavViewController *nav3 = [[MainNavViewController alloc]init];
    nav3.viewControllers = @[[[ThirdViewController alloc]init]];
    MainNavViewController *nav4 = [[MainNavViewController alloc]init];
    nav4.viewControllers = @[[[FourthViewController alloc]init]];
    NSArray *navViewControllers = @[nav1,
                                   nav2,
                                   nav3,
                                   nav4];
    self.selectedIndex = 0;
    self.viewControllers = navViewControllers;
}

       要修改导航栏标题不是在navigation更不是在tabbar,而是在navigation中的viewcontroller中修改,修改很简单,关键是要理解修改导航栏标题的语句是放在navigation中的viewcontroller里面。

//在viewcontroller中设置
self.navigationItem.title = @"第四";

代码下载链接:http://download.csdn.net/detail/ecjtuacm_yuewei/9806036

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值