兼容 - 純代碼完美適配 iPhoneX

前言

本文主要針對適配 iPhoneX列出一些關(guān)鍵點,仔細閱讀可完美適配 iPhoneX,其中還有一些是適配 iOS11的, 話不多少,開始正餐。

iPhoneX概況一覽

從圖中我們可以看出:

status bar 從20 變成了 44
導(dǎo)航條高度依然是 44
頂部的總體高度變成 88
安全區(qū)域距離頁面底部需要保留 34pt,系統(tǒng)自帶的 Tabbar已經(jīng)適配好了,但是自己的頁面書寫代碼就要注意了,以前可以觸底的,現(xiàn)在要保留34pt 距離了。

沒有適配 iPhoneX的觸底頁面

舊工程如何在iphoneX全屏顯示

只需要在LaunchImage中添加一個尺寸為1125?×?2436的啟動圖,并且工程使用LaunchImage加載啟動圖的,而不是使用 LaunchImage.storeBorad.

portrait是人像模式,也就是豎屏。landscape是風(fēng)景模式,也就是橫屏

看一下各種iPhone尺寸屏幕的分辨率和寬高比

設(shè)備 屏幕尺寸 分辨率(pt) Reader 分辨率(px) 寬高比
iPhone 3GS 3.5吋 320x480 @1x 320x480 0.666
iPhone 4/4s 3.5吋 320x480 @2x 640x960 0.666
iPhone 5/5s/5c 4.0吋 320x568 @2x 640x1136 0.563
iPhone 6、7、8 4.7吋 375x667 @2x 750x1334 0.562
iPhone 6Plus、 7Plus、 8Plus 5.5吋 414x736 @3x 1242x2208 0.5625
iPhoneX、iPhoneXS 5.8吋 375x812 @3x 1125?×?2436 0.4618
iPhoneXR 6.1吋 414x896 @2x 828?×?1792
iPhoneXS Mac 6.5吋 414x896 @3x 1242?×?2688

如何做到完美適配,使圖片等內(nèi)容不變形呢?
不做處理的話, iponeX上會出現(xiàn)變形,我們以寬的縮放比為正比縮放比,這樣不管以后屏幕高度如何變化,都不會出現(xiàn)變形的情形。

#define NEWX                     [UIScreen mainScreen].bounds.size.width/375
#define NEWY                     NEWX

iPhone X 變化最大的是頭部 & 底部

 非iPhone X :
 StatusBar 高20px,NavigationBar 高44px,底部TabBar高49px
iPhone X:
StatusBar 高44px,NavigationBar 高44px,底部TabBar高83px

所以,之前項目里寫死的 ±49 ±64 都要出問題,下面幾個宏挺管用的

  #define kStatusBarHeight [[UIApplication sharedApplication] statusBarFrame].size.height
  #define kNavBarHeight 44.0
  //注意:請直接獲取系統(tǒng)的tabbar高度,若沒有用系統(tǒng)tabbar,建議判斷屏幕高度;之前判斷  狀態(tài)欄高度的方法不妥,如果正在通話狀態(tài)欄會變高,導(dǎo)致判斷異常,下面只是一個例子,請勿直接使用!
  #define kTopHeight (kStatusBarHeight + kNavBarHeight)

一行代碼適配iPhoneX及有安全區(qū)域的機型的底部邊距

@interface UIView (MKUtility)

//適配 iphoneX、iphoneXS、iphoneXS Mac、iphoneXR
- (void)adaptBottowMarginForIphoneX;

@end

- (void)adaptBottowMarginForIphoneX {
  if (((UIScreen.mainScreen.bounds.size.width == 375) && (UIScreen.mainScreen.bounds.size.height == 812)) || ((UIScreen.mainScreen.bounds.size.width == 414) && (UIScreen.mainScreen.bounds.size.height == 896)) ) {
    [self mas_updateConstraints:^(MASConstraintMaker *make) {
      make.bottom.mas_equalTo(self.superview).offset(-34);
    }];
  }
}

適配中遇到的其他問題

  • Pushde的時候列表/頁面發(fā)生向下偏移

    這是一個 iOS11適配的問題,如下設(shè)置即可。

    if (@available(iOS 11.0, *)){
        [[UIScrollView appearance] setContentInsetAdjustmentBehavior:UIScrollViewContentInsetAdjustmentNever];
    }else{
       self.automaticallyAdjustsScrollViewInsets = NO;
    }
    
  • iPhone X push的時候TabBar上移

    系統(tǒng)原生的Tabbar在push的時候會上移
    在UINavigationController的基類重寫pushViewController代理方法,在Push的時候修正一下TabBar的frame

      @interface MyNavigationController : UINavigationController  
      @end
    
      @implementation MyNavigationController
    
      - (void)pushViewController:(UIViewController *)viewController animated:(BOOL)animated
      {
          if (self.viewControllers.count > 0) {
              viewController.hidesBottomBarWhenPushed = YES;
          }
         [super pushViewController:viewController animated:animated];
          // 修改tabBra的frame
          CGRect frame = self.tabBarController.tabBar.frame;
          frame.origin.y = [UIScreen mainScreen].bounds.size.height - frame.size.height;
          self.tabBarController.tabBar.frame = frame;
      }
    
      在自定義的TabBarViewController
       @implementation MainTabBarViewController
    
      MyNavigationController *nav1=[[MyNavigationController alloc] initWithRootViewController:vc1];
      MyNavigationController *nav3=[[MyNavigationController alloc] initWithRootViewController:vc3];
      self.viewControllers=@[nav1,nav3];
    
  • 注意iPhone X的屏幕素質(zhì)比較好,所以它需要加載較高像素的圖片,我們要提供必要的@3x資源。
  • 另外由于iPhone X極高的長寬比,我們用作背景的圖片都需要重新設(shè)計,以保證比例適合,內(nèi)容被裁切后效果仍然ok。
  • 關(guān)于狀態(tài)欄另外兩個需要注意的地方:

    不要在iPhone X下隱藏狀態(tài)欄,一個原因是顯示內(nèi)容足夠高了,另一個是這樣內(nèi)容會被劉海切割。



    現(xiàn)在通話或者其它狀態(tài)下,狀態(tài)欄高度不會變化了,程序不需要去做兼容。

  • 橫屏

    在橫屏狀態(tài)下,不能因為劉海的原因?qū)?nèi)容向左或者向右便宜,要保證內(nèi)容的中心對稱:


  • 定位

    在IOS11,未在plist文件中配置NSLocationAlwaysAndWhenInUseUsageDeion,系統(tǒng)框不會彈出。

    <!-- 位置 -->
    <key>NSLocationUsageDescription</key>
    <string>獲取地理位置,精準推送服務(wù)</string>
    <!-- 在使用期間訪問位置 -->
    <key>NSLocationWhenInUseUsageDescription</key>
    <string>獲取地理位置,精準推送服務(wù)</string>
    <!-- 始終訪問位置 -->
    <key>NSLocationAlwaysUsageDescription</key>
     <string>App需要您的同意,才能始終訪問位置</string>
     <!-- iOS 11訪問位置 -->
     <key>NSLocationAlwaysAndWhenInUseUsageDeion</key>
    <string>App需要您的同意,才能始終訪問位置</string>
    
  • 如何實現(xiàn)在工程任何地方修改狀態(tài)欄顏色的設(shè)置

    info.plist中添加下面三項

     <key>UIStatusBarHidden</key>
      <false/>
     <key>UIStatusBarStyle</key>
      <string>UIStatusBarStyleLightContent</string>
      <key>UIViewControllerBasedStatusBarAppearance</key>
      <false/>
    

自己項目的適配效果


值得注意的是:我這個項目中使用的是系統(tǒng)自帶的導(dǎo)航欄、Tabbar。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,646評論 6 533
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,595評論 3 418
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,560評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,035評論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 71,814評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,224評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,301評論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,444評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,988評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,804評論 3 355
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,998評論 1 370
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,544評論 5 360
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,237評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,665評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,927評論 1 287
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,706評論 3 393
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 47,993評論 2 374

推薦閱讀更多精彩內(nèi)容