Как я могу программно получить высоту строки состояния в Swift?
В Objective-C это так:
[UIApplication sharedApplication].statusBarFrame.size.height.
Ответы:
Есть ли проблемы со Swift 2.x :
UIApplication.sharedApplication().statusBarFrame.size.height
Swift 3 или Swift 4 :
UIApplication.shared.statusBarFrame.height
Убедитесь, что UIKit
импортирован
import UIKit
В iOS 13 вы получите предупреждение об устаревании "
'statusBarFrame' устарел в iOS 13.0: вместо этого используйте свойство statusBarManager сцены окна.
Чтобы исправить это:
let height = view.window?.windowScene?.statusBarManager?.statusBarFrame.height ?? 0
size
В Swift 3 можно опустить : UIApplication.shared.statusBarFrame.height
достаточно.
view.window?
наUIApplication.shared.keyWindow?
Обновленный ответ, поддерживающий iOS 13+ и более ранние версии iOS для Swift 5
func getStatusBarHeight() -> CGFloat {
var statusBarHeight: CGFloat = 0
if #available(iOS 13.0, *) {
let window = UIApplication.shared.windows.filter {$0.isKeyWindow}.first
statusBarHeight = window?.windowScene?.statusBarManager?.statusBarFrame.height ?? 0
} else {
statusBarHeight = UIApplication.shared.statusBarFrame.height
}
return statusBarHeight
}
Удачного кодирования!
Вот что я использую:
struct Screen {
static var width: CGFloat {
return UIScreen.main.bounds.width
}
static var height: CGFloat {
return UIScreen.main.bounds.height
}
static var statusBarHeight: CGFloat {
return UIApplication.shared.statusBarFrame.size.height
}
}
Тогда вы сможете:
Screen.statusBarHeight
Это как в Objective-C:
var screenStatusBarHeight: CGFloat {
return UIApplication.sharedApplication().statusBarFrame.height
}
Он включен как стандартная переменная в:
Переделанный ответ Ибрагима:
extension UIApplication {
static var statusBarHeight: CGFloat {
var statusBarHeight: CGFloat = 0
if #available(iOS 13.0, *) {
let window = shared.windows.filter { $0.isKeyWindow }.first
statusBarHeight = window?.windowScene?.statusBarManager?.statusBarFrame.height ?? 0
} else {
statusBarHeight = shared.statusBarFrame.height
}
return statusBarHeight
}
}
В моем проекте swiftUI это сработало.
import UIKit
import SwiftUI
class SceneDelegate: UIResponder, UIWindowSceneDelegate {
var window: UIWindow?
func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) {
let contentView = ContentView()
if let windowScene = scene as? UIWindowScene {
let window = UIWindow(windowScene: windowScene)
if let statusBarHeight = window.windowScene?.statusBarManager?.statusBarFrame.height {
SceneDelegateDataGetter.shared.height = statusBarHeight
}
window.rootViewController = HostingController(rootView: contentView)
self.window = window
window.makeKeyAndVisible()
}
}
class SceneDelegateDataGetter {
static let shared = SceneDelegateDataGetter()
public fileprivate(set) var height: CGFloat = 0
}
При использовании
SceneDelegateDataGetter.shared.height
UIApplication.shared.statusBarFrame.size.height