setStatusBarHidden(_:withAnimation:) устарела в iOS 9
Я вижу это в iOS 9 setStatusBarHidden(_:withAnimation:)
в настоящее время устарела и документация говорит об использовании [UIViewController prefersStatusBarHidden]
вместо этого, но какая альтернатива в iOS 9, если я все еще хочу скрыть строку состояния с анимацией слайдов?
5 ответов
Ссылаться на preferredStatusBarUpdateAnimation
,
Gif
Код
class ViewController: UIViewController {
var isHidden:Bool = false{
didSet{
UIView.animate(withDuration: 0.5) { () -> Void in
self.setNeedsStatusBarAppearanceUpdate()
}
}
}
@IBAction func clicked(sender: AnyObject) {
isHidden = !isHidden
}
override var preferredStatusBarUpdateAnimation: UIStatusBarAnimation{
return .slide
}
override var prefersStatusBarHidden: Bool{
return isHidden
}
}
Свифт 3
- Вычисляемые переменные заменили некоторые функции
- Функция animate имеет обновленный синтаксис
class ViewController: UIViewController {
var isHidden:Bool = false
@IBAction func clicked(sender: AnyObject) {
isHidden = !isHidden
UIView.animate(withDuration: 0.5) { () -> Void in
self.setNeedsStatusBarAppearanceUpdate()
}
}
override var preferredStatusBarUpdateAnimation: UIStatusBarAnimation {
return UIStatusBarAnimation.slide
}
override var prefersStatusBarHidden: Bool {
return isHidden
}
}
Я немного исправил удивительный ответ Лео, переместив обновление в didSet
(СинтаксисSwift 3).
class ViewController: UIViewController {
@IBAction func clicked(sender: AnyObject) {
statusBarHidden = !statusBarHidden
}
var statusBarHidden = false {
didSet {
UIView.animate(withDuration: 0.5) { () -> Void in
self.setNeedsStatusBarAppearanceUpdate()
}
}
}
override var prefersStatusBarHidden: Bool {
return statusBarHidden
}
override var preferredStatusBarUpdateAnimation: UIStatusBarAnimation {
return .slide
}
}
Если вы кодируете с целью c, вот решение:)(версия Leo's Objective C:P, спасибо, человек!!!)
объявить переменную
bool isHidden;
isHidden = false;//in viewDidload()
а затем добавить этот код, когда вы хотите, чтобы скрыть строку состояния
isHidden = true;
[UIView animateWithDuration:0.6 animations:^{
[self performSelector:@selector(setNeedsStatusBarAppearanceUpdate)];
}];
после этого добавьте этот два метода
-(UIStatusBarAnimation) preferredStatusBarUpdateAnimation
{
return UIStatusBarAnimationFade;
}
-(BOOL) prefersStatusBarHidden
{ return isHidden;}
Надеюсь, что ваша проблема будет решена (улыбается)
- SWIFT 3 АЛЬТЕРНАТИВНЫЙ
Привет, ребята, вы нашли более аккуратный способ сделать это для Swift 3, используя частную пару var с каждым из переопределений. Мой оригинальный пост: /questions/33001110/predpochitaemoe-ignorirovanie-statusbarupdateanimation/33001131#33001131
но вот суть этого:
Вот фрагмент:
override var preferredStatusBarUpdateAnimation: UIStatusBarAnimation {
get {
return .slide
}
}
private var statusBarStyle : UIStatusBarStyle = .default
override var preferredStatusBarStyle: UIStatusBarStyle {
get {
return statusBarStyle
}
}
private var statusBarStatus : Bool = false
override var prefersStatusBarHidden: Bool {
get {
return statusBarStatus
}
}
который я затем мог бы вызвать в функции следующим образом: (это один из моих примеров, поэтому не обращайте внимания на пользовательскую функцию).
func sliderView(sliderView: SliderView, didSlideToPlace: CGFloat, within: CGFloat) {
let val = (within - (didSlideToPlace - sliderView.upCent))/(within)
print(val)
//Where you would change the private variable for the color, for example.
if val > 0.5 {
statusBarStyle = .lightContent
} else {
statusBarStyle = .default
}
UIView.animate(withDuration: 0.5, animations: {
sliderView.top.backgroundColor = UIColor.black.withAlphaComponent(val)
self.coverLayer.alpha = val
self.scroll.backgroundColor = colors.lightBlueMainColor.withAlphaComponent(val)
}, completion: {
value in
//If you do not call setNeedsStatusBarAppearanceUpdate() in an animation block, the animation variable won't be called it seems.
UIView.animate(withDuration: 0.4, animations: {
self.animating = true
//Where you set the status for the bar (your part of the solution)
self.statusBarStatus = false
//Then you call for the refresh
self.setNeedsStatusBarAppearanceUpdate()
})
})
}