ios – 当主视图控制器是UITabBarController时,自适应显示细节segue转换为模式而不是推送iPhone

ios – 当主视图控制器是UITabBarController时,自适应显示细节segue转换为模式而不是推送iPhone,第1张

概述在XCode 6中,如果您根据“主 – 详细应用”模板创建一个新项目,您将获得一个通用的故事板,该脚本应该对所有设备都有好处. 在主视图中选择单元格时,通过自适应“显示详细信息”更新细节视图.在iPhone 4,5,6或6的纵向,这个segue将采取按预期的形式.在iPad或iPhone 6的横向上,这将导致细节视图按预期更新. 现在,如果插入一个UITabBarController作为主视图控制 在XCode 6中,如果您根据“主 – 详细应用”模板创建一个新项目,您将获得一个通用的故事板,该脚本应该对所有设备都有好处.

在主视图中选择单元格时,通过自适应“显示详细信息”更新细节视图.在iPhone 4,5,6或6的纵向,这个segue将采取按预期的形式.在iPad或iPhone 6的横向上,这将导致细节视图按预期更新.

现在,如果插入一个UITabbarController作为主视图控制器,该主控制器具有一个选项卡到原始主视图控制器,则在主视图中选择单元格时发生的自适应电阻在iPhones上的行为不会如预期的那样.而不是得到一个推动转换,你现在得到一个模态转换.我该如何解决?似乎这是默认情况下不支持的.

我发现以下帖子有用:iOS8 TabbarController inside a UISplitviewController Master
但是当使用建议的方法时,当我按一下纵向旋转到风景时,我不会在iPhone 6 Plus上获得正确的行为.详细信息视图的内容显示在主视图中,这并不奇怪,因为这是建议的解决方案.

谢谢!

解决方法 重新看WWDC14的视频我想我已经找到一个更好的答案.

>使用自定义UISplitVIEwController(子类)
>覆盖showDetailVIEwController *** 作
>使用traitCollection来确定UISplitVIEwController的类
>如果水平类是Compact,请获取navigationController来调用showVIEwController

以下是自定义UISplitVIEwController的代码:

import UIKitclass CustomSplitVIEwController: UISplitVIEwController {    overrIDe func showDetailVIEwController(vc: UIVIEwController!,sender: AnyObject!) {        if (self.traitCollection.horizontalSizeClass == UIUserInterfaceSizeClass.Compact) {            if let tabbarController = self.vIEwControllers[0] as? UITabbarController {                if let navigationController = tabbarController.selectedVIEwController as? UINavigationController {                    navigationController.showVIEwController(vc,sender: sender)                    return                }            }        }        super.showDetailVIEwController(vc,sender: sender)    }}

不要忘记在故事板中设置自定义类.

在iPhone 6,iPhone 6和iPad Air的模拟器中测试,并按预期工作.

总结

以上是内存溢出为你收集整理的ios – 当主视图控制器是UITabBarController时,自适应显示细节segue转换为模式而不是推送iPhone全部内容,希望文章能够帮你解决ios – 当主视图控制器是UITabBarController时,自适应显示细节segue转换为模式而不是推送iPhone所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1112406.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-29
下一篇 2022-05-29

发表评论

登录后才能评论

评论列表(0条)

保存