有關(guān)涉及iPhone X的tabbar適配
在iPhone X如果tabbar的是自定義的,那么其中必然會(huì)有自己添加的按鈕,沒有做任何適配的話,會(huì)出現(xiàn)如下的情況:
這是因?yàn)閠abbar的高度從49變成了83
之前使用的這個(gè)按鈕是居中的
composeButton.centerX = width * 0.5
composeButton.centerY = height * 0.5
這個(gè)時(shí)候需要將按鈕的y坐標(biāo)上移 (83 - 49) * 0.5, 即17
可以使用下面這個(gè)分類對(duì)手機(jī)的型號(hào)進(jìn)行判斷,然后做處理,這個(gè)分類也是借鑒的他人的,目前已經(jīng)更新到8/8plus/X的判斷
extension UIDevice {
var deviceType: String {
var systemInfo = utsname()
uname(&systemInfo)
let machineMirror = Mirror(reflecting: systemInfo.machine)
let identifier = machineMirror.children.reduce("") { identifier, element in
guard let value = element.value as? Int8, value != 0 else { return identifier }
return identifier + String(UnicodeScalar(UInt8(value)))
}
switch identifier {
case "iPod5,1": return "iPod Touch 5"
case "iPod7,1": return "iPod Touch 6"
case "iPhone3,1", "iPhone3,2", "iPhone3,3": return "iPhone 4"
case "iPhone4,1": return "iPhone 4s"
case "iPhone5,1", "iPhone5,2": return "iPhone 5"
case "iPhone5,3", "iPhone5,4": return "iPhone 5c"
case "iPhone6,1", "iPhone6,2": return "iPhone 5s"
case "iPhone7,2": return "iPhone 6"
case "iPhone7,1": return "iPhone 6 Plus"
case "iPhone8,1": return "iPhone 6s"
case "iPhone8,2": return "iPhone 6s Plus"
case "iPhone8,4": return "iPhone SE"
case "iPhone9,1": return "iPhone 7"
case "iPhone9,2": return "iPhone 7 Plus"
case "iPhone10,1", "iPhone10,4": return "iPhone 8"
case "iPhone10,2", "iPhone10,5": return "iPhone 8 Plus"
case "iPhone10,3", "iPhone10,6": return "iPhone X"
case "iPad2,1", "iPad2,2", "iPad2,3", "iPad2,4":return "iPad 2"
case "iPad3,1", "iPad3,2", "iPad3,3": return "iPad 3"
case "iPad3,4", "iPad3,5", "iPad3,6": return "iPad 4"
case "iPad4,1", "iPad4,2", "iPad4,3": return "iPad Air"
case "iPad5,3", "iPad5,4": return "iPad Air 2"
case "iPad2,5", "iPad2,6", "iPad2,7": return "iPad Mini"
case "iPad4,4", "iPad4,5", "iPad4,6": return "iPad Mini 2"
case "iPad4,7", "iPad4,8", "iPad4,9": return "iPad Mini 3"
case "iPad5,1", "iPad5,2": return "iPad Mini 4"
case "iPad6,7", "iPad6,8": return "iPad Pro"
case "AppleTV5,3": return "Apple TV"
case "i386", "x86_64": return "Simulator"
default: return identifier
}
}
}
然后代碼中加入這樣的適配
// 設(shè)置撰寫按鈕的中心點(diǎn)
composeButton.centerX = width * 0.5
// 適配iPhone X的自定義tabbar按鈕
composeButton.centerY = UIDevice.current.deviceType == "iPhone X" ? height * 0.5 - 17 : height * 0.5
注意
目前筆者只有模擬器可以跑,所以UIDevice.current.deviceType這個(gè)方法無法返回iPhone X,所以我是直接將y減去17
有關(guān)判斷設(shè)備型號(hào)的方法,大家可以看這個(gè)
UIDeviceIdentifier
更改完后,就可以了