iOS - UISplitViewController
前言
NS_CLASS_AVAILABLE_IOS(3_2) @interface UISplitViewController : UIViewController
@available(iOS 3.2, *) public class UISplitViewController : UIViewController
大多数时候,iPhone、iPod 应用与 iPad 应用开发没有太大的区别,但是 iPad 的屏幕比 iPhone 大,设计程序时可以充分利用 iPad 的大屏幕特点,例如 TabBar 和 Navigation 的使用会减少,相应的会采用新的一种 ViewController 来代替,那就是 UISplitViewController,这个控件是 iPad 专用的视图控制器。使用 SplitViewController 导航时,横屏情况下,左边显示一个导航表,点击导航项时右边显示对应的详情。横屏情况下显示方式会有所不同,默认只显示详情面板,原来左侧的导航列表会通过浮动窗口隐藏,需要从边缘向内侧拖动来显示。
在 iPhone 应用中,使用导航控制器由上一层界面进入下一层界面,在下一层界面处理完成后,用户可以非常方便的返回上一层界面。这种方式在 iPhone 应用里非常方便,因为小屏幕通常只能显示一个界面,但对于 iPad 来说,那么大的屏幕只显示一个列表会显得不太好看,同时用户操作也不方便,所以在 iPad 中,通常使用 SplitViewController 来实现导航。iPhone 和 iPad 的系统设置就是典型的按设备区别界面的应用。
- self.splitViewController.viewControllers[0] // 表示 Master 页
- self.splitViewController.viewControllers[1] // 表示 Detail 页
1、splitViewController 的创建
Objective-C
// 初始化分割视图控制器
UISplitViewController *splitViewController = [[UISplitViewController alloc] init]; // 设置分割面板的 2 个视图控制器
splitViewController.viewControllers = @[navigationController, detailViewController]; // 添加到窗口
[self addChildViewController:splitViewController];
[self.view addSubview:splitViewController.view]; // 做为 window 的根视图控制器
self.window.rootViewController = splitViewController;
Swift
// 初始化分割视图控制器
let splitViewController = UISplitViewController() // 设置分割面板的 2 个视图控制器
splitViewController.viewControllers = [navigationController, detailViewController] // 添加到窗口
self.addChildViewController(splitViewController)
self.view.addSubview(splitViewController.view) // 做为 window 的根视图控制器
self.window.rootViewController = splitViewController
2、判断设备类型
Objective-C
// 初始化列表和详情面板 // 初始化列表面板,可以为表格视图控制器
MasterViewController *masterViewController = [[MasterViewController alloc] init]; // 初始化详情面板
DetailViewController *detailViewController = [[DetailViewController alloc] init]; // 用导航包装列表面板,显示导航条,如果是分割面板也不影响功能
UINavigationController *navigationController = [[UINavigationController alloc]
initWithRootViewController:masterViewController]; // 根据设备类型创建分割视图控制器
/*
UIUserInterfaceIdiomUnspecified = -1,
UIUserInterfaceIdiomPhone NS_ENUM_AVAILABLE_IOS(3_2), // iPhone and iPod touch style UI
UIUserInterfaceIdiomPad NS_ENUM_AVAILABLE_IOS(3_2), // iPad style UI
UIUserInterfaceIdiomTV NS_ENUM_AVAILABLE_IOS(9_0), // Apple TV style UI
UIUserInterfaceIdiomCarPlay NS_ENUM_AVAILABLE_IOS(9_0), // CarPlay style UI
*/ // 如果是 iPhone 或 iPod 则只显示列表页,如果是 iPad 则显示分割面板
if ([UIDevice currentDevice].userInterfaceIdiom == UIUserInterfaceIdiomPhone) { // 添加到窗口
[self addChildViewController:navigationController];
[self.view addSubview:navigationController.view];
}
else { // 初始化分割视图控制器
UISplitViewController *splitViewController = [[UISplitViewController alloc] init]; // 设置分割面板的 2 个视图控制器
splitViewController.viewControllers = @[navigationController, detailViewController]; // 添加到窗口
[self addChildViewController:splitViewController];
[self.view addSubview:splitViewController.view]; // 做为 window 的根视图控制器
self.window.rootViewController = splitViewController;
} // 表格点击 - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath { // 调用 DetailViewController 的方法更新详细页
[self.splitViewController.viewControllers[1] loadDetailViewController:[dataArray
objectAtIndex:indexPath.row]]; // 如果是 iPhone、iPod 则导航到详情,跳转到 detailViewController,取消选中状态
if ([UIDevice currentDevice].userInterfaceIdiom == UIUserInterfaceIdiomPhone) { [tableView deselectRowAtIndexPath:indexPath animated:YES]; [self.navigationController pushViewController:self.splitViewController.viewControllers[1]
animated:YES];
}
}
Swift
// 初始化列表和详情面板 // 初始化列表面板,可以为表格视图控制器
let masterViewController = MasterViewController() // 初始化详情面板
let detailViewController = DetailViewController() // 用导航包装列表面板,显示导航条,如果是分割面板也不影响功能
let navigationController = UINavigationController(rootViewController: masterViewController) // 根据设备类型创建分割视图控制器
/*
case Unspecified
case Phone @available(iOS 3.2, *) // iPhone and iPod touch style UI
case Pad @available(iOS 3.2, *) // iPad style UI
case TV @available(iOS 9.0, *) // Apple TV style UI
case CarPlay @available(iOS 9.0, *) // CarPlay style UI
*/ // 如果是 iPhone 或 iPod 则只显示列表页,如果是 iPad 则显示分割面板
if UIDevice.currentDevice().userInterfaceIdiom == .Phone { // 添加到窗口
self.addChildViewController(navigationController)
self.view.addSubview(navigationController.view)
}
else { // 初始化分割视图控制器
let splitViewController = UISplitViewController() // 设置分割面板的 2 个视图控制器
splitViewController.viewControllers = [navigationController, detailViewController] // 添加到窗口
self.addChildViewController(splitViewController)
self.view.addSubview(splitViewController.view) // 做为 window 的根视图控制器
self.window.rootViewController = splitViewController
} // 表格点击 func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) { // 调用 DetailViewController 的方法更新详细页
(self.splitViewController?.viewControllers[1] as! DetailViewController)
.loadDetailViewController(dataArray[indexPath.row]) // 如果是 iPhone、iPod 则导航到详情页,跳转到 detailViewController,取消选中状态
if UIDevice.currentDevice().userInterfaceIdiom == UIUserInterfaceIdiom.Phone { tableView.deselectRowAtIndexPath(indexPath, animated: true) self.navigationController?
.pushViewController((self.splitViewController?
.viewControllers[1] as! DetailViewController),
animated: true)
}
}
3、Storyboard 中设置
在 Storyboard 场景中设置
在 Storyboard 场景绑定的 Controller 中设置
// 获取 Master 页
self.splitViewController.viewControllers[0] // 获取 Detail 页
self.splitViewController.viewControllers[1]
iOS - UISplitViewController的更多相关文章
- iOS:iPad和iPhone开发的异同(UIPopoverController、UISplitViewController)
iPad和iPhone开发的异同 1.iPhone和iPad: niPhone是手机,iPad.iPad Mini是平板电脑 iPhone和iPad开发的区别 屏幕的尺寸 \分辨率 UI元素的排布 \ ...
- 分割视图控制器(UISplitViewController) 改_masterColumnWidth 导致在 IOS 10中出现闪退
默认UISplitViewController的Master和Detail的宽度是固定的,可以通过下面的方式来改变 [splitViewController setValue:[NSNumber nu ...
- iOS Programming UISplitViewController
iOS Programming UISplitViewController The iPad, on the other hand, has plenty of screen space to pr ...
- iOS:分割控制器UISplitViewcontroller
分割控制器UISplitViewController <1>功能:它也是ipad的一个新特性,在屏幕上可以同时显示两个控制器,左边一个,右边一个:左边的为主控制器,右边的为详细控制器,主控 ...
- ios之UISplitViewController
iPad的屏幕比iPhone大,所以在界面上,iPad比iPhone多一个UISplitViewController,用来实现iPad在横屏时,分两栏显示所需要的界面,可以一边是目录一边是具体的内容. ...
- iOS:UISplitViewController的创建
UISplitViewController是iPad特有的系统方法,主要效果就是呈现iPad的经典切割界面 代码创建实例: - (BOOL)application:(UIApplication *)a ...
- iOS开发学习笔记
1 常用的第三方工具 1.1 iPhone Simulator 测试程序需要模拟器iPhone Simulator 1.2 设计界面需要Interface Builder,Interface Buil ...
- iOS开发——高级篇——iPad开发、iPad开发中的modal
一.iPad简介 1.什么是iPad一款苹果公司于2010年发布的平板电脑定位介于苹果的智能手机iPhone和笔记本电脑产品之间跟iPhone一样,搭载的是iOS操作系统 2.iPhone和iPadi ...
- IOS 开发教程
http://www.raywenderlich.com/category/ios http://www.raywenderlich.com/50310/storyboards-tutorial-in ...
随机推荐
- (个人)读取A.CSV修改它的某列,写入B.CSV
#!/usr/bin/perl -wuse strict;use warnings;use Tie::File; open(IN_FILE,"<E:/Hzj_works/test1.c ...
- error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏 E:\OCX
VC项目从VS2008迁移到VS2010编怿出错. 解决方法: 对比Framework和vs的安装目录下的cvtres.exe文件版本,删除旧版本即可 C:\Windows\Microsoft.NET ...
- SQLServer学习笔记<>.基础知识,一些基本命令,单表查询(null top用法,with ties附加属性,over开窗函数),排名函数
Sqlserver基础知识 (1)创建数据库 创建数据库有两种方式,手动创建和编写sql脚本创建,在这里我采用脚本的方式创建一个名称为TSQLFundamentals2008的数据库.脚本如下: ...
- C# 插件
1.EsFrameWork框架 http://www.oraycn.com/ESFramework_download.aspx
- 设计模式之——单例模式(Singleton)的常见应用场景
单例模式(Singleton)也叫单态模式,是设计模式中最为简单的一种模式,甚至有些模式大师都不称其为模式,称其为一种实现技巧,因为设计模式讲究对象之间的关系的抽象,而单例模式只有自己一个对象,也因此 ...
- CSS选择器及其优先级
一:一些普通的选择器 <!DOCTYPE html> <html> <head lang="en"> <meta charset=&quo ...
- 实现gabor filter的滤波
实现gabor filter的滤波 图像纹理对于航空遥感图片.织物图案.复杂自然风景和动植物都适合.这里我采用遥感图片.织物图案和钢铁表面来做,并和canny图片进行一定的对比. ...
- lua注释
1. 单行注释 -- 功能等同于C++中的// 2. 多行注释 --[[ 注释的内容 ]] 功能等同于C++中的 /**/ 3. 多行注释 --[====[ 注释和内容 ]=== ...
- 2016年10月24日 星期一 --出埃及记 Exodus 19:8
2016年10月24日 星期一 --出埃及记 Exodus 19:8 The people all responded together, "We will do everything th ...
- 基于busybox和LFS的linux系统定制
自从在大学知道了Linux这玩意是可以定制的之后,一直想做出一版属于自己的Linux系统.最近工作比较闲,终于塌下心来好好学习了一下. 目前来说,我接触的定制Linux的方法主要有两种: 1. ...