UISplitViewController - 分屏视图控制器

概述

UISplitViewController 是一个容器vc, 展示一个 master-detail(主-详(从))界面。 
主视图改变会驱动从视图的改变。两个视图可用同时展示,也可以只显示一个。当创建app界面的时候,UISplitViewController通常是root vc ,它没有自己的元素可展示,它展示的是它的子vc,可通过属viewControllers来设置。

主要属性及方法

preferredDisplayMode: UISplitViewControllerDisplayMode -分隔视图的期望展示方式 
通过此属性来设置splitViewController的展示方式。splitViewController会尽力以你设置的方式展示,如果没有足够的空间,会用一个不同类型的界面展示。改变此属性,splitViewController将动态的改变现在的展示模式。 
支持四中展示模式:

enum UISplitViewControllerDisplayMode : Int {
//自适应模式,splitViewController会为可用空间选用合适的展示视图方式,在ipad的竖直方向会用.PrimaryOverlay模式展示视图,在iPad水平方向将会用.AllVisible 模式展示。
case Automatic
//主视图隐藏
case PrimaryHidden
//主详视图都显示
case AllVisible
//主视图部分覆盖详细视图
case PrimaryOverlay
}
  • diplayModeButtonItem: UIBarButtonItem - 改变分隔视图显示模式的按钮

如果想显示的更改分隔视图的显示模式,那么在界面中应该包含这个按钮。点击此按钮,通过deletage的方法 
targetDisplayModeForActionInSplitViewController:最后返回的值来改变分隔视图的显示模式。

 func targetDisplayModeForActionInSplitViewController(svc: UISplitViewController)    -> UISplitViewControllerDisplayMode {
return UISplitViewControllerDisplayMode.Automatic
}

presentsWithGesture: Bool - 指定一个隐藏的视图控制器是否可以使用一个滑动手势来呈现和退出。

此属性针对iphone6s plus横屏及ipad有效,即是针对 size class 为(w:Regular)或则(height:Regular)的情况。当它的属性为true的时候,splitViewController 会添加一个手势识别器,通过delegete的方法targetDisplayModeForActionInSplitViewController返回的显示模式,来改变splitViewController的当前显示模式。如果设置为false则手势无效。

self.presentsWithGesture = true
self.delegate = self //代理方法,手势滑动改变显示模式
func targetDisplayModeForActionInSplitViewController(svc: UISplitViewController) -> UISplitViewControllerDisplayMode { //返回此模式,主从视图同时显示,滑动手势无效。
return UISplitViewControllerDisplayMode.AllVisible
//主视图隐藏,隐藏之后iPad无法再显示,iphone6s plus转到横屏,不受此属性约束,可以再显 示。
return UISplitViewControllerDisplayMode.PrimaryHidden //主视图覆盖从视图
return UISplitViewControllerDisplayMode.PrimaryOverlay
//根据设备尺寸和类型自适应
return UISplitViewControllerDisplayMode.Automatic
}

禁用手势的情况如下: 

viewControllers: [ UIViewController ] - 管理的视图控制器

当分隔视图界面展开的时候,此属性包括两个vc,当它折叠的时候,此属性包含一个vc。 数组中第一个元素称为 
primary(或 master)vc, 如果第二个元素呈现,那么它称为secondary(或 detail)vc。 
可以用此属性初始化splitViewController,但当splitViewController已经显示的时候,最好用 showDetailViewController:sender:或者showViewController:sender:来设置子vc。

 override func viewDidAppear(animated: Bool) {
super.viewDidAppear(animated)
//从 storyboard初始化一个vc
let vc = storyboard?.instantiateViewControllerWithIdentifier("detailVC") as! DetailViewController
vc.selectedIndex = self.showDetailViewController(vc, sender: self )
}

– showDetailViewController:sender: - 显示详细视图 
此方法会调用delegate的方法 splitViewController:showDetailViewController:sender:,给delegate一个显示vc的机会。如果delegate不想显示,那么 splitViewController会向前发送消息到将要被替换的vc,看看这个vc有什么要做的。例如:导航控制器会把vc放入它的导航栈中。如果没有任何对象想显示vc,那么splitViewController按照如下方法安排vc的显示:

  • 在水平正常环境(w:Regular), vc作为detail vc展示。
  • 在水平紧凑环境(w:Compact),vc以modally方式展示。

delegate: UISplitViewControllerDelegate? - 代理

协议定义了一个方法可以让你管理一个拆分视图界面的变化。使用此协议的方法来响应当前显示模式和当前界面方向的变化。当拆分视图界面折叠和展开时,或当一个新的视图控制器被添加到界面时,您还可以使用这些方法来适当地配置子视图控制器。

主要方法如下:

//当视图转换到折叠模式,通常只显示主视图,通过此方法可以定制主视图。
fun primaryViewControllerForCollapsingSplitViewController(splitViewController: UISplitViewController) -> UIViewController? { return nil
} //视图转换为折叠模式,可用实现此方法为主视图进行一些处理,或者尝试把详细视图的内容包含进新的折叠视图。此方法会回后,splitViewController会把详细视图vc从 ‘viewControllers’ 属性中移除。
返回false表示splitViewController采用默认的方式尝试在折叠视图中包含 ‘detail vc’,同时也会调用 master vc 的方法‘collapseSecondaryViewController:forSplitViewController:’对 ‘detail vc’对内容做一些处理,大部分控制器什么也不做,但当是‘UINavigationController’对时候会把
‘detail vc’放入到导航堆栈中。 返回true,表示什么也不做。 func splitViewController(splitViewController: UISplitViewController, collapseSecondaryViewController secondaryViewController: UIViewController, ontoPrimaryViewController primaryViewController: UIViewController) -> Bool { return true
} //当从水平紧凑变为水平正常模式时,调用此方法返回主控制器用来显示,可用返回特定的vc,如果返回nil将使用当前的主控制器。
func primaryViewControllerForExpandingSplitViewController(splitViewController: UISplitViewController) -> UIViewController? { return nil
}
//为拆分视图返回详细视图控制器,如果返回为nil,splitViewController将会调用主控制的方法:
separateSecondaryViewControllerForSplitViewController:来返回一个合适的vc,大部分控制器默认什么也不做,但当是UINavigationController的时候会返回导航栈顶端的元素。 func splitViewController(splitViewController: UISplitViewController, separateSecondaryViewControllerFromPrimaryViewController primaryViewController: UIViewController) -> UIViewController? { return nil }
 

UISplitViewController - iPad分屏视图控制器的更多相关文章

  1. Swift - 判断设备类型开发兼容的iOS应用(iPad使用分隔视图控制器)

    1,分割视图控制器(UISplitViewController) 在iPhone应用中,使用导航控制器由上一层界面进入下一层界面. 但iPad屏幕较大,通常使用SplitViewController来 ...

  2. IPad分屏,当电脑第二显示屏

    最在在网上看到使用IPad可以做为电脑的第二个显示屏,对于我这样一个程序猿来说,这真是我的福音呀!因此在网上搜了许多关于Ipad投屏的信息,下面简单说明一下,包括怎么使用! 1.根据在网上搜索的结果, ...

  3. iOS 9 分屏多任务:入门(中文版)

    本文转载至 http://www.cocoachina.com/ios/20150714/12555.html 本文由钢铁侠般的卿哥(微博)翻译自苹果官方文档:Adopting Multitaskin ...

  4. IPAD之分割视图 SplitViewController

    转载自:http://www.w3cschool.cc/ios/att-ios-ui-splitview-htm.html 1 分割视图的使用 分割视图是 iPad 的特定视图控制器用于管理两个视图控 ...

  5. 分割视图控制器(UISplitViewController)

    这种控制器只能用于iPad,它可以在iPad屏幕中显示两个不同的场景:在横向模式下,左边显示一个表,供用户选择:用户选择表中的元素后,详细视图将显示该元素的详细信息.如果iPad被旋转到纵向模式,表将 ...

  6. Swift之分割视图控制器-UISplitViewController

    Swift之分割视图控制器-UISplitViewController UISplitViewController这种控制器只能用于iPad,它可以在iPad屏幕中显示两个不同的场景:在横向模式下,左 ...

  7. Xcode 7在支持ipad的设备中需要支持分屏!

    http://sandy.int.ru/xcode/xcode7zaizhichiipaddeshebeizhongyaozhichifenping.html 在更新APP的时候发现ERROR ITM ...

  8. 将ipad作为电脑拓展屏或分屏的简单方法

    用Ipad实现电脑分屏的方法是挺简单的,但鉴于部分小白找不到合适的门路,在此重新分享一下. 需要的装备:  ipad   电脑   数据连接线 方法:某宝上搜索 duet display ,只需1元左 ...

  9. Notepad++如何多视图(分屏)显示

    Notepad++ v6.6.7 当需要同时查阅或者编辑多个文件时,正是多视图功能大显身手的时候. 可以在你想要在另一边预览操作的文件名字(在工具栏和文件内容之间)上,单击右键,如下图所示,选择移动到 ...

随机推荐

  1. android 在线升级借助开源中国App源码

    android 在线升级借助开源中国App源码 http://www.cnblogs.com/luomingui/p/3949429.html android 在线升级借助开源中国App源码分析如下: ...

  2. iOS开发——UI基础-KVO

    KVO == Key Value Observing 作用: 可以监听某个对象属性的改变 一.使用KVO Person *p = [Person new]; p.name = @"chg&q ...

  3. BZOJ1212——L语言

    题目大意:每一个字符串都可以分解成一些个单词组成,现在给你一些单词,再给你一个字符串, dp吧,设f[i]为从0开始,到i结束的字符串前缀是否可以被分解,因为单词长度很小,所以,这就T了, (什么逻辑 ...

  4. [翻译]opengl扩展教程1

    [翻译]opengl扩展教程1 原文地址https://www.opengl.org/sdk/docs/tutorials/ClockworkCoders/extensions.php [翻译]ope ...

  5. Linux 文件rwx权限问题 chmod 777 XXX 任何人拥有最高权限

    在Unix和Linux的各种操作系统下,每个文件(文件夹也被看作是文件)都按读.写.运行设定权限.ls -l:得到-rw-r--r-- 1 apple users 2254 2006-05-20 13 ...

  6. Exception异常

    JAVA异常指的是运行期出现的错误. 观察错误的名字和行号最重要. 运用关键字try将可能出错的语句catch出来并添加友好的话 \ 在这句话中的ae代表一个自己命名的对象. 1.要捕获首先需要知道错 ...

  7. python 的dict的update 方法的一点诡秘的行为

    如下: >>> 'a%s'%a 'a{1: 0, 2: 0}' >>> for k,v in a.items(): a.update(k=v) >>&g ...

  8. svn update错误

    可以再checkout下来一份项目,重新命名,然后将该项目下的隐藏文件夹.svn替换掉原项目 注意备份

  9. 转:js清空数组

    方式1,splice 1 2 3 var ary = [1,2,3,4]; ary.splice(0,ary.length); console.log(ary); // 输出 Array[0],空数组 ...

  10. PHP使用curl替代file_get_contents

    初学php的朋友们,很容易翻一个错误,在写采集程序或者调用api接口总会有线考虑到使用file_get_contents函数来或许内容,程序的访问量不大倒是没什么影响,但是访问量提升了那非常的悲剧了, ...