Много способов сделать это в Swift :
Мы проверим модель ниже (мы можем только выполнить поиск с учетом регистра здесь):
class func isUserUsingAnIpad() -> Bool {
let deviceModel = UIDevice.currentDevice().model
let result: Bool = NSString(string: deviceModel).containsString("iPad")
return result
}
Мы проверяем модель ниже (мы можем выполнить поиск с учетом регистра / без учета здесь):
class func isUserUsingAnIpad() -> Bool {
let deviceModel = UIDevice.currentDevice().model
let deviceModelNumberOfCharacters: Int = count(deviceModel)
if deviceModel.rangeOfString("iPad",
options: NSStringCompareOptions.LiteralSearch,
range: Range<String.Index>(start: deviceModel.startIndex,
end: advance(deviceModel.startIndex, deviceModelNumberOfCharacters)),
locale: nil) != nil {
return true
} else {
return false
}
}
UIDevice.currentDevice().userInterfaceIdiom
ниже возвращает только iPad, если приложение для iPad или Universal. Если это приложение для iPhone, запущенное на iPad, то оно не будет. Поэтому вы должны вместо этого проверить модель. :
class func isUserUsingAnIpad() -> Bool {
if UIDevice.currentDevice().userInterfaceIdiom == UIUserInterfaceIdiom.Pad {
return true
} else {
return false
}
}
Этот фрагмент ниже не компилируется, если класс не наследует UIViewController
, иначе он работает просто отлично. Независимо от того, UI_USER_INTERFACE_IDIOM()
только возвращает iPad, если приложение для iPad или Universal. Если это приложение для iPhone, запущенное на iPad, то оно не будет. Поэтому вы должны вместо этого проверить модель. :
class func isUserUsingAnIpad() -> Bool {
if (UI_USER_INTERFACE_IDIOM() == UIUserInterfaceIdiom.Pad) {
return true
} else {
return false
}
}
UI_USER_INTERFACE_IDIOM()
эквивалентно([[UIDevice currentDevice] respondsToSelector:@selector(userInterfaceIdiom)] ? [[UIDevice currentDevice] userInterfaceIdiom] : UIUserInterfaceIdiomPhone)
. Вы могли бы быть лучше кэшировать результат где - то:BOOL iPad = UI_USER_INTERFACE_IDIOM() == UIUserInterfaceIdiomPad; … if (iPad) …
.