UISplitViewController - iPad分屏视图控制器
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分屏视图控制器的更多相关文章
- Swift - 判断设备类型开发兼容的iOS应用(iPad使用分隔视图控制器)
1,分割视图控制器(UISplitViewController) 在iPhone应用中,使用导航控制器由上一层界面进入下一层界面. 但iPad屏幕较大,通常使用SplitViewController来 ...
- IPad分屏,当电脑第二显示屏
最在在网上看到使用IPad可以做为电脑的第二个显示屏,对于我这样一个程序猿来说,这真是我的福音呀!因此在网上搜了许多关于Ipad投屏的信息,下面简单说明一下,包括怎么使用! 1.根据在网上搜索的结果, ...
- iOS 9 分屏多任务:入门(中文版)
本文转载至 http://www.cocoachina.com/ios/20150714/12555.html 本文由钢铁侠般的卿哥(微博)翻译自苹果官方文档:Adopting Multitaskin ...
- IPAD之分割视图 SplitViewController
转载自:http://www.w3cschool.cc/ios/att-ios-ui-splitview-htm.html 1 分割视图的使用 分割视图是 iPad 的特定视图控制器用于管理两个视图控 ...
- 分割视图控制器(UISplitViewController)
这种控制器只能用于iPad,它可以在iPad屏幕中显示两个不同的场景:在横向模式下,左边显示一个表,供用户选择:用户选择表中的元素后,详细视图将显示该元素的详细信息.如果iPad被旋转到纵向模式,表将 ...
- Swift之分割视图控制器-UISplitViewController
Swift之分割视图控制器-UISplitViewController UISplitViewController这种控制器只能用于iPad,它可以在iPad屏幕中显示两个不同的场景:在横向模式下,左 ...
- Xcode 7在支持ipad的设备中需要支持分屏!
http://sandy.int.ru/xcode/xcode7zaizhichiipaddeshebeizhongyaozhichifenping.html 在更新APP的时候发现ERROR ITM ...
- 将ipad作为电脑拓展屏或分屏的简单方法
用Ipad实现电脑分屏的方法是挺简单的,但鉴于部分小白找不到合适的门路,在此重新分享一下. 需要的装备: ipad 电脑 数据连接线 方法:某宝上搜索 duet display ,只需1元左 ...
- Notepad++如何多视图(分屏)显示
Notepad++ v6.6.7 当需要同时查阅或者编辑多个文件时,正是多视图功能大显身手的时候. 可以在你想要在另一边预览操作的文件名字(在工具栏和文件内容之间)上,单击右键,如下图所示,选择移动到 ...
随机推荐
- [POJ3295]Tautology
[POJ3295]Tautology 试题描述 WFF 'N PROOF is a logic game played with dice. Each die has six faces repres ...
- 在Fedora 20 上安装Mysql并初始化root密码
[root@localhost ~]# yum -y install community-mysql-server #安装数据库 已加载插件:langpacks, refresh-packagekit ...
- hiho #1284 机会渺茫
#1284 : 机会渺茫 时间限制:5000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi最近在追求一名学数学的女生小Z.小Z其实是想拒绝他的,但是找不到好的说辞,于是提出了这样的要 ...
- android中paint的setXfermode属性
本文前半部分来自于:http://www.cnblogs.com/rayray/p/3670120.html 1.下面的Xfermode子类可以改变这种行为: AvoidXfermode 指定了一个 ...
- 1.4---字符串空格变成20%(CC150)
import CtCILibrary.AssortedMethods; public class Question { // Assume string has sufficient free spa ...
- PyQt4自定义事件
listview控件与updateText 相关联 self.listview.updateText.connect(self.viewlist) updateText = QtCore.pyqt ...
- Tomcat异常 Multiple Contexts have a path of "/qqshl".解决方法
Tomcat异常 Multiple Contexts have a path of "/qqshl".解决方法 找到tomcat映射文件Service.xml,将文件中的conte ...
- gjd
#include <cstdio> #include <cstring> #include <malloc.h> #define radix (1u<< ...
- 同级兄弟元素之间的CSS控制
为了实现这个导航效果:选中菜单中某一项,隐藏掉自身的左边背景线条,同时让他的下一个兄弟元素也隐藏掉线条. 有一种选择器就叫兄弟元素选择器,分为临近兄弟和普通兄弟. 临近兄弟:用 + 表示,只匹配该元素 ...
- 比较NHibernate和Entity Framework
葡萄牙的一位开发者 Ricardo Peres 最近发布了一篇文章,以看起来无偏见的形式对领先的两种 .NET ORM:NHibernate 和 Entity Framework 进行了比较. 我们建 ...