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

前端之家收集整理的这篇文章主要介绍了ios – 当主视图控制器是UITabBarController时,自适应显示细节segue转换为模式而不是推送iPhone前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在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 UIKit

class 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的模拟器中测试,并按预期工作.

原文链接:https://www.f2er.com/iOS/336979.html

猜你在找的iOS相关文章