iOS監(jiān)聽屏幕旋轉的幾種方式

1. 使用viewWillTransitionToSize:withTransitionCoordinator: 監(jiān)聽屏幕旋轉:

iOS9之前,最常用的監(jiān)聽函數(shù)是如下兩個:

//轉屏前回調函數(shù)
- (void)willAnimateRotationToInterfaceOrientation:(UIInterfaceOrientation)toInterfaceOrientation duration:(NSTimeInterval)durationNS_DEPRECATED_IOS(3_0,8_0,"Implement viewWillTransitionToSize:withTransitionCoordinator: instead")__TVOS_PROHIBITED;
 
//轉屏后回調函數(shù)
- (void)didRotateFromInterfaceOrientation:(UIInterfaceOrientation)fromInterfaceOrientationNS_DEPRECATED_IOS(2_0,8_0)__TVOS_PROHIBITED;

但這兩個協(xié)議方法已經(jīng)在iOS9之后廢棄了(雖然也可以繼續(xù)調用,但官方不建議使用了)
文檔提示,改用如下函數(shù):

- (void)viewWillTransitionToSize:(CGSize)size withTransitionCoordinator:(id<UIViewControllerTransitionCoordinator>)coordinator;

轉屏前后的監(jiān)聽如下:

- (void)viewWillTransitionToSize:(CGSize)size withTransitionCoordinator:(id <UIViewControllerTransitionCoordinator>)coordinator
{
    [coordinator animateAlongsideTransition:^(id<UIViewControllerTransitionCoordinatorContext> context){
        NSLog(@"轉屏前調入");
    } completion:^(id<UIViewControllerTransitionCoordinatorContext> context){
        NSLog(@"轉屏后調入");
    }];
    [super viewWillTransitionToSize:size withTransitionCoordinator:coordinator];
}

但這個監(jiān)聽方法有個局限性,這個協(xié)議方法來自于<UIContentContainer>腹缩,而查看官方代碼可知,只有UIViewController及其子類,才能遵循并實現(xiàn)這個協(xié)議方法如绸。即只有UIViewController才能夠使用這個方法監(jiān)聽到 (且UIViewController是以一個類實例存在的)。

2. 通過 UIDeviceOrientationDidChangeNotification 通知監(jiān)聽:
-(void)viewDidAppear:(BOOL)animated{
    [super viewDidAppear:animated];
    //開始生成 設備旋轉 通知
    [[UIDevice currentDevice] beginGeneratingDeviceOrientationNotifications];
 
    //添加 設備旋轉 通知
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(orientChange:)  name:UIDeviceOrientationDidChangeNotification object:nil];
}
 
-(void)viewDidDisappear:(BOOL)animated{
    [super viewDidDisappear:animated];
    //銷毀 設備旋轉 通知
    [[NSNotificationCenter defaultCenter] removeObserver:self
                                                    name:UIDeviceOrientationDidChangeNotification
                                                  object:nil
     ];
 
    //結束 設備旋轉通知
    [[UIDevice currentDevice] endGeneratingDeviceOrientationNotifications];
}
 
/**屏幕旋轉的通知回調*/
- (void)orientChange:(NSNotification *)noti {
    UIDeviceOrientation  orient = [UIDevice currentDevice].orientation;
    switch (orient) {
        case UIDeviceOrientationPortrait:
            NSLog(@"豎直屏幕");
            break;
        case UIDeviceOrientationLandscapeLeft:
            NSLog(@"手機左轉");
            break;
        case UIDeviceOrientationPortraitUpsideDown:
            NSLog(@"手機豎直");
            break;
        case UIDeviceOrientationLandscapeRight:
            NSLog(@"手機右轉");
            break;
        case UIDeviceOrientationUnknown:
            NSLog(@"未知");
            break;
        case UIDeviceOrientationFaceUp:
            NSLog(@"手機屏幕朝上");
            break;
        case UIDeviceOrientationFaceDown:
            NSLog(@"手機屏幕朝下");
            break;
        default:
            break;
    }
}

這里監(jiān)聽的是屏幕方向旭贬。UIDeviceOrientation除了橫豎屏4個方向以外怔接,還包括“屏幕朝上”、“屏幕朝下”這兩個方向稀轨,處理業(yè)務邏輯時需要注意著兩個方向的特殊性扼脐。
因為通知的便利性,所以監(jiān)聽不需要局限于UIViewController里奋刽,而是任意位置瓦侮。但注意要及時移除掉通知。

3. 通過 UIApplicationDidChangeStatusBarOrientationNotification 通知監(jiān)聽:
- (void)viewDidAppear:(BOOL)animated
{
    [super viewDidAppear:animated];
    //添加 設備旋轉 通知
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(orientChange:) name:UIApplicationDidChangeStatusBarOrientationNotification object:nil];
}
 
-(void)viewDidDisappear:(BOOL)animated{
    [super viewDidDisappear:animated];
    //銷毀 設備旋轉 通知
    [[NSNotificationCenter defaultCenter] removeObserver:self
                                                    name:UIApplicationDidChangeStatusBarOrientationNotification
                                                  object:nil];
}
 
/**屏幕旋轉的通知回調*/
- (void)orientChange:(NSNotification *)noti {
    UIInterfaceOrientation orientation = [[UIApplication sharedApplication] statusBarOrientation];
    switch (orientation) {
        case UIInterfaceOrientationUnknown:
            NSLog(@"未知");
            break;
        case UIInterfaceOrientationPortrait:
            NSLog(@"豎直");
            break;
        case UIInterfaceOrientationPortraitUpsideDown:
            NSLog(@"屏幕倒立");
            break;
        case UIInterfaceOrientationLandscapeLeft:
            NSLog(@"手機水平佣谐,home鍵在左邊");
            break;
        case UIInterfaceOrientationLandscapeRight:
            NSLog(@"手機水平肚吏,home鍵在右邊");
            break;
        default:
            break;
    }
}

整體同理于方法2,但有一些區(qū)別狭魂。獲取到的方向是UIInterfaceOrientation罚攀,即界面方向党觅,只有“上下左右”4個方向。

PS:[UIApplication sharedApplication].statusBarOrientation在iOS13之后會被廢棄掉坞生,官方建議使用window的方向仔役。即如下:
[UIApplication sharedApplication].windows.firstObject.windowScene.interfaceOrientation

但這個API也只能在iOS13之后才能使用。

參考文檔:

【1】IOS9開始如何處理轉屏

【2】UIApplication

【3】iOS開發(fā)之屏幕旋轉

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末是己,一起剝皮案震驚了整個濱河市又兵,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌卒废,老刑警劉巖沛厨,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異摔认,居然都是意外死亡逆皮,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門参袱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來电谣,“玉大人,你說我怎么就攤上這事抹蚀〗宋” “怎么了?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵环壤,是天一觀的道長晒来。 經(jīng)常有香客問我,道長郑现,這世上最難降的妖魔是什么湃崩? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮接箫,結果婚禮上攒读,老公的妹妹穿的比我還像新娘。我一直安慰自己列牺,他們只是感情好整陌,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著瞎领,像睡著了一般泌辫。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上九默,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天震放,我揣著相機與錄音,去河邊找鬼驼修。 笑死殿遂,一個胖子當著我的面吹牛诈铛,可吹牛的內容都是我干的。 我是一名探鬼主播墨礁,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼幢竹,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了恩静?” 一聲冷哼從身側響起焕毫,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎驶乾,沒想到半個月后邑飒,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡级乐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年疙咸,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片风科。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡撒轮,死狀恐怖,靈堂內的尸體忽然破棺而出贼穆,到底是詐尸還是另有隱情腔召,我是刑警寧澤,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布扮惦,位于F島的核電站,受9級特大地震影響亲桦,放射性物質發(fā)生泄漏崖蜜。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一客峭、第九天 我趴在偏房一處隱蔽的房頂上張望豫领。 院中可真熱鬧,春花似錦舔琅、人聲如沸等恐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽课蔬。三九已至,卻和暖如春郊尝,著一層夾襖步出監(jiān)牢的瞬間二跋,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工流昏, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留扎即,地道東北人吞获。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像谚鄙,于是被迫代替她去往敵國和親各拷。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345

推薦閱讀更多精彩內容