iOS中導航欄pop返回時出現(xiàn)黑塊問題的解決方法
前言
蘋果在iOS7以后給導航控制器加了一個Pop手勢,只要手指在屏幕邊緣滑動,當前的控制器的視圖就會隨著你的手指移動,當用戶松手后,系統(tǒng)會判斷手指拖動出來的大小來決定是否要執(zhí)行控制器的pop操作。
這個想法非常棒,但最近在使用中發(fā)現(xiàn)了一些問題,下面話不多說了,來一起看看詳細的介紹吧。
問題描述:
導航欄正常從A頁面push到B頁面,從B頁面pop返回A頁面時遇到過渡過程中導航欄出現(xiàn)黑塊的問題。
如截圖所示:

問題原因:
A界面導航欄被影藏,B頁面的導航欄存在。過渡的時候沒有動畫。
解決方案:
1.在A頁面中添加影藏導航過渡動畫
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
self.navigationController?.setNavigationBarHidden(true, animated: true) //避免的出現(xiàn)返回時導航欄的黑塊
}
override func viewWillDisappear(_ animated: Bool) {
super.viewWillDisappear(animated)
self.navigationController?.setNavigationBarHidden(false, animated: true)
}
注意:如果使用self.navigationController.isNavigationBarHidden = true 就會出現(xiàn)黑塊問題。 如果A頁面在tableViewController中,切換tab時就有可能導致該界面閃動。
優(yōu)點,不用在自push中再去設置每一個過渡
2.在B頁面添加過渡動畫
override func viewWillDisappear(_ animated: Bool) {
super.viewWillDisappear(animated)
self.navigationController?.setNavigationBarHidden(true, animated: true)
}
缺點:在每一個子頁面(包括子頁面的子頁面)中都需要設置
3.設置window的背景顏色為主題色,這樣就不會出現(xiàn)黑塊,但是還是會出現(xiàn)分層和界面不協(xié)調(diào)的問題。不建議使用
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
iOS App中UILabel的自定義及在Auto Layout中的使用
這篇文章主要介紹了iOS App中UILabel的自定義及在Auto Layout中的使用,示例代碼為傳統(tǒng)的Objective-C語言,需要的朋友可以參考下2016-03-03
Xcode 9下適配iPhoneX導致iOS 10不兼容問題的解決方法
這篇文章主要給大家介紹了關于Xcode 9下適配iPhoneX導致iOS 10不兼容問題的解決方法,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2018-04-04
iOS利用NSMutableAttributedString實現(xiàn)富文本的方法小結
這篇文章主要給大家介紹了關于iOS利用NSMutableAttributedString如何實現(xiàn)富文本的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-05-05
Android開發(fā)筆記之簡單基站定位程序的實現(xiàn)
這篇文章主要介紹了Android開發(fā)筆記之簡單基站定位程序的實現(xiàn),詳細的介紹了基站定位其實很簡單,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2016-11-11
IOS CoreLocation實現(xiàn)系統(tǒng)自帶定位的方法
本篇文章主要介紹了IOS Core Location實現(xiàn)系統(tǒng)自帶定位的方法,非常具有實用價值,需要的朋友可以參考下。2017-02-02

