很多时候,在UI设计方面同时需要使用导航控制器和标签栏控制器,这时,需要掌握如何设计结合使用这两种不同控制器。比如手机QQ,程序有三个标签 栏(分别为消息、联系人、动态),同时在选择某个联系人或者会话时,会进入聊天的子页面,因此这里同时使用到了标签栏控制器和导航控制器。

我目前所知道有以下方法可实现上述的结合使用效果。

根视图是标签栏控制器,然后每页标签栏又有一个根视图控制器为导航栏控制器的标签,如下代码所示

01.// 消息
02.MessageViewController* msg = [[MessageViewController alloc] init];
03.UINavigationController* navControloler = [[UINavigationController alloc] init];
04.[navControloler pushViewController:msg animated:YES];
05.[viewArray addObject:navControloler];
06. 
07.// 联系人
08.ContactViewController* contact = [[ContactViewController alloc] init];
09.navControloler = [[UINavigationController alloc] init];
10.[navControloler pushViewController:contact animated:YES];
11.[viewArray addObject:navControloler];
12. 
13.// 动态
14.FavoriteViewController* favorite = [[FavoriteViewController alloc] init];
15.navControloler = [[UINavigationController alloc] init];
16.[navControloler pushViewController:favorite animated:YES];
17.[viewArray addObject:navControloler];
18. 
19.// 标签栏控制器
20.UITabBarController* tabBarController = [[UITabBarController alloc] init];
21.tabBarController.viewControllers = viewArray;
22. 
23.// 修改根视图
24.AppDelegate* appDelagete = [UIApplication sharedApplication].delegate;
25.appDelagete.window.rootViewController = tabBarController;

上述代码是在ViewController.m文件中,也就是说,APP的根视图控制器可以在AppDelegete外的其他地方修改,因此,可以设计出先显示登录界面,然后再显示程序的主页面,即标签栏页面视图。注意根视图是标签栏,所以返回按钮无效,如下所示

如果上述代码的根视图是导航栏,那么返回按钮是有效的,可以用作退出登录等类似的功能,其主要实现如下,在AppDelegate里设置根视图控制器

01.- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
02.{
03.// Override point for customization after application launch.
04.self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
05. 
06.UINavigationController* navController = [[UINavigationController alloc] init];
07.[navController pushViewController:[[ViewController alloc] init] animated:YES];
08. 
09.self.window.rootViewController = navController;
10.return YES;
11.}

然后ViewController中将标签栏控制器当做导航栏控制器的子视图Push进去,代码为

01.- (void) loginSuccess
02.{
03.// 进入主界面,改变根视图
04.NSMutableArray* viewArray = [[NSMutableArray alloc] init];
05. 
06.// 导航控制器+表标签栏控制器相结合使用,
07.// 每个标签有一个根导航控制器
08. 
09.// 消息
10.MessageViewController* msg = [[MessageViewController alloc] init];
11.UINavigationController* navControloler = [[UINavigationController alloc] init];
12.[navControloler pushViewController:msg animated:YES];
13.[viewArray addObject:navControloler];
14. 
15.// 联系人
16.ContactViewController* contact = [[ContactViewController alloc] init];
17.navControloler = [[UINavigationController alloc] init];
18.[navControloler pushViewController:contact animated:YES];
19.[viewArray addObject:navControloler];
20. 
21.// 动态
22.FavoriteViewController* favorite = [[FavoriteViewController alloc] init];
23.navControloler = [[UINavigationController alloc] init];
24.[navControloler pushViewController:favorite animated:YES];
25.[viewArray addObject:navControloler];
26. 
27.// 标签栏控制器
28.UITabBarController* tabBarController = [[UITabBarController alloc] init];
29.tabBarController.viewControllers = viewArray;
30. 
31.#ifdef TABRoot
32.// 修改根视图为标签栏控制器
33.AppDelegate* appDelagete = [UIApplication sharedApplication].delegate;
34.appDelagete.window.rootViewController = tabBarController;
35.#else
36.// 把标签栏视图控制器push到导航栏控制器内
37.[self.navigationController pushViewController:tabBarController animated:YES];
38.#endif
39.}

其效果如下所示

导航栏控制器和标签栏控制器(UINavigationController和UITabBarController)混用的更多相关文章

  1. iOS结合导航控制器和标签栏控制器

    <span style="font-family: Arial, Helvetica, sans-serif;"></span><pre name=& ...

  2. iOS:自定义工具栏、导航栏、标签栏

    工具栏为UIToolBar,导航栏UINavigationBar,标签栏UITabBar.它们的样式基本上时差不多的,唯一的一点区别就是,工具栏一般需要自己去创建,然后添加到视图中,而导航栏和标签栏不 ...

  3. iOS: 状态栏、导航栏、标签栏、工具栏

    三种项目栏总结: 工具栏:UIToolBar 导航栏:UINavigationBar 标签栏:UITabBar   UIToolBar的按钮单元为:UIBarButtonItem UINavigati ...

  4. UINavigationController与UITabBarController相关问题

    UINavigationController与UITabBarController相关问题 UINavigationController与UITabBarController混用是非常常见的,有时候会 ...

  5. iOS:视图切换的第二种方式:UINavigationController导航栏控制器

    UINavigationController:一个以栈的形式管理多视图的容器,负责子控制器之间的跳转.由于以栈的方式管理视图,各个视图的切换就是压栈和出栈操作,所以出栈后的视图会立即销毁. 介绍: & ...

  6. [Xcode 实际操作]三、视图控制器-(6)UINavigationController导航栏样式

    目录:[Swift]Xcode实际操作 本文将演示对导航栏进行样式设置,以及更改导航顶部的提示区. 选择编辑第一个视图控制器文件. import UIKit class FirstSubViewCon ...

  7. [Xcode 实际操作]三、视图控制器-(4)使用UINavigationController导航栏和工具栏

    目录:[Swift]Xcode实际操作 本文将演示如何显示和隐藏导航视图的导航栏和工具栏 打开第一个视图控制器 import UIKit class FirstSubViewController: U ...

  8. swift - 指定VC隐藏导航栏 - 禁用tabbar的根控制器手势,防止两个tabbar跳转 手势冲突

    1. viewdidload 设置代理 self.navigationController?.delegate = self 2.代理里面指定VC 隐藏 //MARK: - 导航栏delegate e ...

  9. IOS 导航控制器基本使用(UINavigationController代码创建方式)

    ● UINavigationController的使用步骤 ➢ 初始化UINavigationController ➢ 设置UIWindow的rootViewController为UINavigati ...

随机推荐

  1. cf459E Pashmak and Graph

    E. Pashmak and Graph time limit per test 1 second memory limit per test 256 megabytes input standard ...

  2. redhat5安装jdk6、eclipse和tomcat6

    redhat5安装jdk6.eclipse和tomcat6 1.安装jdk6 首先下载jdk(jdk-6u13-linux-i586.bin),对于redhat5,本人强烈建议不要安装jdk7,因为有 ...

  3. Dollar Dayz(大数母函数,高低位存取)

    Dollar Dayz Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5655   Accepted: 2125 Descr ...

  4. js仿百度文库文档上传页面的分类选择器_第二版

    仿百度文库文档上传页面的多级联动分类选择器第二版,支持在一个页面同一时候使用多个分类选择器. 此版本号把HTML,CSS,以及图片都封装到"category.js"中.解决因文件路 ...

  5. 【矩阵乘法经典应用】【ZOJ3497】【Mistwa】

    题意:给定一个有向图(最多25个节点,每个节点的出度最多为4),给定起点和终点,然后从起点开始走,走到终点就停止,否则一直往下走,问能不能P步到达终点.也就是说从起点出发,走一条长度为P的路径,路径中 ...

  6. RequiredFieldValidator验证下拉列表框

    <asp:DropDownList ID="DropDownList1" runat="server" CssClass="style01&qu ...

  7. random background

    function roll(){ var bg = document.getElementById("loginbg"); var rnd = Math.floor(Math.ra ...

  8. JQ第一篇

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  9. CoreLocation导航Demo

    CoreLocation实现定位和导航功能还是非常简单的,基本思路是: 1.导入<CoreLocation/CoreLocation.h>头文件 2.使用该框架内的导航管理者,创建该导航管 ...

  10. Linux下进程的文件访问权限

    本文转自 http://blog.csdn.net/chosen0ne/article/details/10581883 对进程校验文件访问权限包括两个部分,一是确定进程的角色(属于哪个用户或者组), ...