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

相关文章

UITabBarController 是 iOS 中用于管理和显示选项卡界面的一...
UITableView的重用机制避免了频繁创建和销毁单元格的开销,使...
Objective-C中,类的实例变量(instance variables)和属性(...
从内存管理的角度来看,block可以作为方法的传入参数是因为b...
WKWebView 是 iOS 开发中用于显示网页内容的组件,它是在 iO...
OC中常用的多线程编程技术: 1. NSThread NSThread是Objecti...