欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS橫豎屏旋轉(zhuǎn)內(nèi)容總結(jié)

 更新時間:2018年01月31日 14:42:30   投稿:laozhang  
本篇文章給大家總結(jié)了iOS橫豎屏旋轉(zhuǎn)的相關(guān)內(nèi)容以及實現(xiàn)的代碼分享,有需要的朋友參考下吧。

一、前言

Swift版本 4.0

Xcode版本 9.2

以前接觸到的項目需求中,幾乎都是全豎屏展現(xiàn)界面,所以我也來得省事,直接在TARGETS中的界面方向選項中只勾選豎屏,這樣就滿足了需求。

但最近的項目中,產(chǎn)品突然增加了一個需求,需要部分界面支持旋轉(zhuǎn),這才來研究了一下屏幕旋轉(zhuǎn)的問題!

需要緊急解決問題的道友直接看3.3

二、屏幕旋轉(zhuǎn)相關(guān)知識

2.1 三個方向的理解和聯(lián)系

UIDeviceOrientation: 設(shè)備方向

public enum UIDeviceOrientation : Int {
 case unknown
 case portrait // 設(shè)備vertically方向, home鍵在下方
 case portraitUpsideDown // 設(shè)備vertically方向, home鍵在上方
 case landscapeLeft // 設(shè)備horizontally方向, home鍵在右方
 case landscapeRight // 設(shè)備horizontally方向, home鍵在左方
 case faceUp // 設(shè)備flat方向, 屏幕朝上
 case faceDown // 設(shè)備flat方向, 屏幕朝下
}

 

從設(shè)備方向的命名就能看出來這個枚舉的含義,這里指的是物理設(shè)備(即iPhone)的方向。

UIInterfaceOrientation: 界面方向

public enum UIInterfaceOrientation : Int {
 case unknown
 case portrait
 case portraitUpsideDown
 case landscapeLeft
 case landscapeRight
}

而界面方向指屏幕中顯示內(nèi)容的方向,它的方向和Home鍵的方向是一致的。仔細(xì)觀察一下屏幕旋轉(zhuǎn)就能理解UIDeviceOrientation和UIInterfaceOrientation了,我們把手機(jī)轉(zhuǎn)向左邊,可以看到界面隨之才轉(zhuǎn)向右邊。

UIInterfaceOrientationMask: 是用來控制允許轉(zhuǎn)向的方向,對應(yīng)UIInterfaceOrientation

public struct UIInterfaceOrientationMask : OptionSet {
 public init(rawValue: UInt)
 public static var portrait: UIInterfaceOrientationMask { get }
 public static var landscapeLeft: UIInterfaceOrientationMask { get }
 public static var landscapeRight: UIInterfaceOrientationMask { get }
 public static var portraitUpsideDown: UIInterfaceOrientationMask { get }
 public static var landscape: UIInterfaceOrientationMask { get }
 public static var all: UIInterfaceOrientationMask { get }
 public static var allButUpsideDown: UIInterfaceOrientationMask { get }
}

2.2 觀察屏幕旋轉(zhuǎn)并作出響應(yīng)

2.2.1 觀察設(shè)備方向并響應(yīng)

// 沒有生成通知
if !UIDevice.current.isGeneratingDeviceOrientationNotifications {
 // 生成通知
  UIDevice.current.beginGeneratingDeviceOrientationNotifications()
}
// 鎖定豎屏,依然有效,例如faceUp.
NotificationCenter.default.addObserver(self, 
          selector: #selector(handleDeviceOrientationChange(notification:)),       name:NSNotification.Name.UIDeviceOrientationDidChange,
          object: nil)
@objc private func handleDeviceOrientationChange(notification: Notification) {
 // 獲取設(shè)備方向
 let orientation = UIDevice.current.orientation
 switch orientation {
  case .landscapeRight:
   // iOS8之后,橫屏UIScreen.main.bounds.width等于豎屏?xí)r的UIScreen.main.bounds.height
   print(UIScreen.main.bounds.width)
   print("landscapeRight")
  default: break
 }
}

注銷

deinit {
 NotificationCenter.default.removeObserver(self)
 UIDevice.current.endGeneratingDeviceOrientationNotifications()
}

2.2.2 觀察界面方向并響應(yīng)

和上面類似不過觀察的name為

// 鎖定豎屏,無效,通知方法不會觸發(fā)
NSNotification.Name.UIApplicationWillChangeStatusBarOrientation
NSNotification.Name.UIApplicationDidChangeStatusBarOrientation

獲取界面方向

let statusBarOrientation = UIApplication.shared.statusBarOrientation

2.2.3 建議

這里建議監(jiān)聽界面方向,原因有二:

監(jiān)聽設(shè)備方向,會返回多個方向,例如portrait和faceUp不沖突。

監(jiān)聽設(shè)備方向,上面提到,先是設(shè)備旋轉(zhuǎn),隨之界面旋轉(zhuǎn),這里就有一個問題,我們操作界面時,可能界面還沒有旋轉(zhuǎn)。

三、問題解決實戰(zhàn)

需要實現(xiàn)部分界面可旋轉(zhuǎn),部分界面鎖定豎屏,首先我們需要配置TARGETS中的Device Orientation,這里是總開關(guān),默認(rèn)勾選了如圖方向:

如果你確定整個項目只有豎屏,直接只勾選Protrait完事,不過像我現(xiàn)在這樣,可能突然一個需求改變就不得不繼續(xù)適配,哈哈。

這里的配置不要和代碼控制的方向相沖突,不然會引發(fā)奔潰。

3.1 控制屏幕旋轉(zhuǎn)的函數(shù)

// 默認(rèn)為true
override var shouldAutorotate: Bool {
 return true
}
// 支持的旋轉(zhuǎn)方向
override var supportedInterfaceOrientations: UIInterfaceOrientationMask {
 return .landscapeLeft
}
// 模態(tài)切換的默認(rèn)方向
override var preferredInterfaceOrientationForPresentation: UIInterfaceOrientation {
 return .landscapeRight
}

這三個屬性都重寫的UIViewController的屬性。哎,看到模態(tài)切換,這里再給自己挖坑一個,以前研究了一會模態(tài)切換,只不過沒寫成總結(jié),后面會寫出來(:。

并且這三個方法會受到控制器層級的影響,也就是如果當(dāng)前控制器配置支持旋轉(zhuǎn),如果他的導(dǎo)航控制器,乃至Tabbar控制器不支持旋轉(zhuǎn),當(dāng)前控制器的配置也不會生效。

3.2 不同根控制器情況下的解決

核心問題: 需要旋轉(zhuǎn)的界面是少數(shù),大多界面需要鎖定豎屏。

3.2.1 根控制器為UIViewController

對應(yīng)Demo配置:

這種情況的APP可以說是非常少了,不過還是對后面的情況有所幫助。

設(shè)置BaseVC,在其中的配置鎖定豎屏:

class BaseVC: UIViewController {
 override var shouldAutorotate: Bool {
  return false
 }  
 override var supportedInterfaceOrientations: UIInterfaceOrientationMask {
  return .portrait
 }
 override var preferredInterfaceOrientationForPresentation: UIInterfaceOrientation {
  return .portrait
 }  
 override func viewDidLoad() {
  super.viewDidLoad()
 } 
}

然后其余控制器繼承BaseVC,需要旋轉(zhuǎn)的控制器單獨再次重寫方法。

3.2.2 根控制器為UINavigationController

對應(yīng)Demo配置:

我們可以獲取到當(dāng)前顯示層級的控制器,并拿出它的屬性賦給UINavigationController

class BaseNavC: UINavigationController {
 override var shouldAutorotate: Bool {
  return self.viewControllers.last?.shouldAutorotate ?? false
 }
 override var supportedInterfaceOrientations: UIInterfaceOrientationMask {
  return self.viewControllers.last?.supportedInterfaceOrientations ?? .portrait
 }
 override var preferredInterfaceOrientationForPresentation: UIInterfaceOrientation {
  return self.viewControllers.last?.preferredInterfaceOrientationForPresentation ?? .portrait
 }
 override func viewDidLoad() {
  super.viewDidLoad()
 }
}

3.2.3 根控制器為UITabBarController

對應(yīng)Demo配置:

class BaseTabBarC: UITabBarController {
 override var shouldAutorotate: Bool {
  return self.selectedViewController?.shouldAutorotate ?? false
 }
  
 override var supportedInterfaceOrientations: UIInterfaceOrientationMask {
  return self.selectedViewController?.supportedInterfaceOrientations ?? .portrait
 }
  
 override var preferredInterfaceOrientationForPresentation: UIInterfaceOrientation {
  return self.selectedViewController?.preferredInterfaceOrientationForPresentation ?? .portrait
 }
  
 override func viewDidLoad() {
  super.viewDidLoad()
 }
}

同理,我們只需要獲取當(dāng)前選中的控制器的配置賦給UITabBarController,這樣一層一層就配置好了!

3.3 最簡單的實現(xiàn)方式

對應(yīng)Demo配置:

在查詢屏幕旋轉(zhuǎn)相關(guān)資料的時候我發(fā)現(xiàn)屏幕旋轉(zhuǎn)時會最后調(diào)用Appdelegate中的:

func application(_ application: UIApplication, supportedInterfaceOrientationsFor window: UIWindow?) 
-> UIInterfaceOrientationMask {
}

然后我立馬想到一個超級簡單的方法,那就是定義一個全局變量或者緩存一個bool值來進(jìn)行判斷,如下:

func application(_ application: UIApplication, supportedInterfaceOrientationsFor window: UIWindow?) 
-> UIInterfaceOrientationMask {
 if isAllowAutorotate {
  return [.portrait, .landscapeLeft, .landscapeRight]
 }
 else {
  return .portrait
 }
}

然后默認(rèn)isAllowAutorotate這個全局變量為false,在需要旋轉(zhuǎn)的控制器中:

override func viewWillAppear(_ animated: Bool) {
  super.viewWillAppear(animated)
  isAllowAutorotate = false
 }
  
 override func viewWillDisappear(_ animated: Bool) {
  super.viewWillDisappear(animated)
  isAllowAutorotate = true
 }
}

這樣就不用麻煩的去搞那些繼承什么的了!

四、后記和Demo

https://github.com/swordjoy/ScreenRotationDemo

以上就是本次小編整理的全部內(nèi)容,感謝大家的支持,如果還有任何相關(guān)問題可以在下方的留言區(qū)討論。

相關(guān)文章

  • iOS路由(MGJRouter)的實現(xiàn)

    iOS路由(MGJRouter)的實現(xiàn)

    這篇文章主要介紹了iOS路由(MGJRouter)的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • 探究iOS多線程究竟不安全在哪里?

    探究iOS多線程究竟不安全在哪里?

    iOS多線程安全的概念在很多地方都會遇到,為什么不安全,不安全又該怎么去定義,其實是個值得深究的話題。那么通過下面這篇文章小編和大家一起來探究了iOS多線程究竟不安全在哪里?需要的朋友可以參考學(xué)習(xí)。
    2017-02-02
  • 設(shè)計模式中的迭代器模式在Cocoa Touch框架中的使用

    設(shè)計模式中的迭代器模式在Cocoa Touch框架中的使用

    這篇文章主要介紹了設(shè)計模式中的迭代器模式在Cocoa Touch框架中的使用,示例代碼為傳統(tǒng)的Objective-C,需要的朋友可以參考下
    2016-03-03
  • 詳解IOS UITableViewCell 的 imageView大小更改

    詳解IOS UITableViewCell 的 imageView大小更改

    這篇文章主要介紹了詳解IOS UITableViewCell 的 imageView大小更改的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • ios基于UITableViewController實現(xiàn)列表

    ios基于UITableViewController實現(xiàn)列表

    這篇文章主要介紹了ios基于UITableViewController實現(xiàn)列表的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • iOS touch事件區(qū)分單擊雙擊響應(yīng)的方法

    iOS touch事件區(qū)分單擊雙擊響應(yīng)的方法

    如果您的 iPhone 應(yīng)用里有個 view,既有單擊操作又有雙擊操作。用戶雙擊 view 時,總是先執(zhí)行一遍單擊的操作再執(zhí)行雙擊的操作。所以直接判斷時就會發(fā)現(xiàn)不能直接進(jìn)入雙擊操作。下面是區(qū)分 touch 事件是單擊還是雙擊的方法,需要的朋友可以參考下
    2016-10-10
  • 詳解iOS webview加載時序和緩存問題總結(jié)

    詳解iOS webview加載時序和緩存問題總結(jié)

    本篇文章主要介紹了iOS webview加載時序和緩存問題總結(jié) ,這兩天學(xué)習(xí)了Vue.js 感覺組件這個地方知識點挺多的,而且很重要,所以,今天添加一點小筆記。
    2017-09-09
  • iOS中排列組合算法的使用小結(jié)

    iOS中排列組合算法的使用小結(jié)

    這篇文章主要給大家介紹了關(guān)于iOS中排列組合算法使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09
  • iOS開發(fā)之topLayoutGuide和bottomLayoutGuide的使用小技巧分享

    iOS開發(fā)之topLayoutGuide和bottomLayoutGuide的使用小技巧分享

    這篇文章主要給大家介紹了關(guān)于iOS開發(fā)之topLayoutGuide和bottomLayoutGuide使用的一些小技巧,需要的朋友可以參考下
    2017-11-11
  • iOS多線程應(yīng)用開發(fā)中使用NSOperation類的基本方法

    iOS多線程應(yīng)用開發(fā)中使用NSOperation類的基本方法

    這篇文章主要介紹了iOS多線程應(yīng)用開發(fā)中使用NSOperation類的基本方法,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下
    2015-11-11

最新評論