我正在使用swift中的应用程序,需要在4S以后的所有iPhone型号上运行,但我希望在4S上的布局非常不同,所以我想引导应用程序加载到完全不同的故事板在4S。 我知道这可以在信息选项卡中为iPad完成,但设置主故事板文件基本名称(iPad),但我找不到为不同的iPhone型号执行此操作的方法。 任何帮助将不胜感激
答案 0 :(得分:2)
按照@HAS here的非常好的答案,您可以了解设备的型号。让我们制作一个名为DeviceModel
的快速文件,以保持扩展部分的分开。
<强> DeviceModel.swift 强>
import UIKit
private let DeviceList = [
/* iPod 5 */ "iPod5,1": "iPod Touch 5",
/* iPhone 4 */ "iPhone3,1": "iPhone 4", "iPhone3,2": "iPhone 4", "iPhone3,3": "iPhone 4",
/* iPhone 4S */ "iPhone4,1": "iPhone 4S",
/* iPhone 5 */ "iPhone5,1": "iPhone 5", "iPhone5,2": "iPhone 5",
/* iPhone 5C */ "iPhone5,3": "iPhone 5C", "iPhone5,4": "iPhone 5C",
/* iPhone 5S */ "iPhone6,1": "iPhone 5S", "iPhone6,2": "iPhone 5S",
/* iPhone 6 */ "iPhone7,2": "iPhone 6",
/* iPhone 6 Plus */ "iPhone7,1": "iPhone 6 Plus",
/* iPad 2 */ "iPad2,1": "iPad 2", "iPad2,2": "iPad 2", "iPad2,3": "iPad 2", "iPad2,4": "iPad 2",
/* iPad 3 */ "iPad3,1": "iPad 3", "iPad3,2": "iPad 3", "iPad3,3": "iPad 3",
/* iPad 4 */ "iPad3,4": "iPad 4", "iPad3,5": "iPad 4", "iPad3,6": "iPad 4",
/* iPad Air */ "iPad4,1": "iPad Air", "iPad4,2": "iPad Air", "iPad4,3": "iPad Air",
/* iPad Air 2 */ "iPad5,1": "iPad Air 2", "iPad5,3": "iPad Air 2", "iPad5,4": "iPad Air 2",
/* iPad Mini */ "iPad2,5": "iPad Mini", "iPad2,6": "iPad Mini", "iPad2,7": "iPad Mini",
/* iPad Mini 2 */ "iPad4,4": "iPad Mini", "iPad4,5": "iPad Mini", "iPad4,6": "iPad Mini",
/* iPad Mini 3 */ "iPad4,7": "iPad Mini", "iPad4,8": "iPad Mini", "iPad4,9": "iPad Mini",
/* Simulator */ "x86_64": "Simulator", "i386": "Simulator"
]
public extension UIDevice {
var modelName: String {
var systemInfo = utsname()
uname(&systemInfo)
let machine = systemInfo.machine
let mirror = reflect(machine) // Swift 1.2
// let mirror = Mirror(reflecting: machine) // Swift 2.0
var identifier = ""
// Swift 1.2 - if you use Swift 2.0 comment this loop out.
for i in 0..<mirror.count {
if let value = mirror[i].1.value as? Int8 where value != 0 {
identifier.append(UnicodeScalar(UInt8(value)))
}
}
// Swift 2.0 and later - if you use Swift 2.0 uncomment his loop
// for child in mirror.children where child.value as? Int8 != 0 {
// identifier.append(UnicodeScalar(UInt8(child.value as! Int8)))
// }
return DeviceList[identifier] ?? identifier
}
}
然后在您AppDelegate.swift
内的didFinishLaunchingWithOptions
内,您可以实例化有关设备型号的故事板,如下所示:
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
var storyboard: UIStoryboard
// instantiate the `UIWindow`
self.window = UIWindow(frame: UIScreen.mainScreen().bounds)
// Get the model name based in the extension.
let modelName = UIDevice.currentDevice().modelName
// If the modelName variable contains the string "iPhone 6" inside.
if (modelName.rangeOfString("iPhone 6") != nil) {
storyboard = UIStoryboard(name: "iPhone6Storyboard", bundle: nil)
self.window!.rootViewController = storyboard.instantiateInitialViewController() as! iPhone6ViewController
}
else if (modelName.rangeOfString("iPad") != nil) {
storyboard = UIStoryboard(name: "iPadStoryboard", bundle: nil)
self.window!.rootViewController = storyboard.instantiateInitialViewController() as! iPadViewController
}
self.window!.makeKeyAndVisible()
return true
}
如果您添加了UIStoryboard
所需的UIStoryboard
,请使用Interface Builder(如果您不想要的话)为每个UIViewController
初始UIViewController
设置上述代码。要使用Interface Builder设置初始UIViewController
,您可以非常轻松地找到如何以编程方式设置初始Info
,但我使用Interface Builder的目的很简单。
当然,您需要在应用的设置中转到目标和Main storyboard file base name
标签。清楚General
的价值。在DeviceModel.swift
选项卡上,清除主界面的值。您可以在这个答案Programmatically set the initial view controller using Storyboards中阅读更多相关信息。
你需要注意两件事:
Invoke-Expression
中的代码正确使用设备名称以匹配不同的名称。为了简洁起见,我只在上面放了两个设备,但无论如何你需要根据名字匹配你想要的任何设备型号。
我希望这对你有所帮助。
答案 1 :(得分:1)
您好我认为您可以通过以编程方式加载基于iPhone模型的不同故事板来实现此目的
您可以将故事板用于任何设备型号,而不仅仅是iPad或通用iPhone。
首先查看此链接how to determine device type
这是第一个想到搜索的想法,你可以找到它,它不会让我知道会发布代码
然后您可以加载设备特定的故事板,如下所示
let storyboard: UIStoryboard
If 4s {
storyboard = UIStoryboard(name:"Main_4s.storyboard", bundle: NSBundle.mainBundle())
} else {
storyboard = UIStoryboard(name:"Main_default.storyboard", bundle: NSBundle.mainBundle())
}
let nc = storyboard.instantiateViewControllerWithIdentifier("navController")
然后将导航控制器设置为主UI窗口中的根视图控制器
UIApplication.sharedApplication().keyWindow?.rootViewContoller = nc
注意:我还没有尝试过这个!