ios13適配

iOS13適配

1.私有KVC

[self setValue:baseTabBar forKey:@"tabBar"]; //正常

[_textField setValue:[UIColor redColor] forKeyPath:@"_placeholderLabel.textColor"];///崩潰
[_textField setValue:[UIFont systemFontOfSize:14] forKeyPath:@"_placeholderLabel.font"];///崩潰

_textField.attributedPlaceholder = [[NSAttributedString alloc] initWithString:@"姓名" attributes:@{NSFontAttributeName:[UIFont systemFontOfSize:14],NSForegroundColorAttributeName:[UIColor redColor]}]; ///新的實現(xiàn)

在Xcode10上編譯不會有問題墨礁,但是在Xcode11上編譯的會崩潰贱纠。并且- (void)setValue:(nullable id)value forKey:(NSString *)key方法沒問題,- (void)setValue:(nullable id)value forKeyPath:(NSString *)keyPath會崩潰

2.presentViewController的問題

會出現(xiàn)這種情況是主要是因為我們之前對UIViewController里面的一個屬性霞玄,即modalPresentationStyle(該屬性是控制器在模態(tài)視圖時將要使用的樣式)沒有設(shè)置需要的類型骤铃。在iOS13中modalPresentationStyle的默認(rèn)改為UIModalPresentationAutomatic,而在之前默認(rèn)是UIModalPresentationFullScreen。

這個不受Xcode版本的影響坷剧,只要是iOS13的系統(tǒng)惰爬,沒有顯式設(shè)置modalPresentationStyle,就會有這個問題

3.即將廢棄的 LaunchImage

從 iOS 8 的時候惫企,蘋果就引入了 LaunchScreen补鼻,我們可以設(shè)置 LaunchScreen來作為啟動頁。當(dāng)然雅任,現(xiàn)在你還可以使用LaunchImage來設(shè)置啟動圖。不過使用LaunchImage的話咨跌,要求我們必須提供各種屏幕尺寸的啟動圖沪么,來適配各種設(shè)備,隨著蘋果設(shè)備尺寸越來越多锌半,這種方式顯然不夠 Flexible禽车。而使用 LaunchScreen的話,情況會變的很簡單刊殉, LaunchScreen是支持AutoLayout+SizeClass的殉摔,所以適配各種屏幕都不在話下。 注意啦??记焊,從2020年4月開始逸月,所有使? iOS13 SDK 的 App 將必須提供 LaunchScreen,LaunchImage即將退出歷史舞臺

4.暗黑模式

原理

1.將同一個資源遍膜,創(chuàng)建出兩種模式的樣式碗硬。系統(tǒng)根據(jù)當(dāng)前選擇的樣式瓤湘,自動獲取該樣式的資源

2.每次系統(tǒng)更新樣式時,應(yīng)用會調(diào)用當(dāng)前所有存在的元素調(diào)用對應(yīng)的一些重新方法恩尾,進(jìn)行重繪視圖弛说,可以在對應(yīng)的方法做相應(yīng)的改動

資源文件適配

1.創(chuàng)建一個Assets文件(或在現(xiàn)有的Assets文件中)
2.新建一個圖片資源文件(或者顏色資源文件、或者其他資源文件)
3.選中該資源文件翰意, 打開 Xcode ->View ->Inspectors ->Show Attributes Inspectors (或者Option+Command+4)視圖木人,將Apperances 選項 改為Any,Dark
4.執(zhí)行完第三步冀偶,資源文件將會有多個容器框醒第,分別為 Any Apperance 和 Dark Apperance. Any Apperance 應(yīng)用于默認(rèn)情況(Unspecified)與高亮情況(Light), Dark Apperance 應(yīng)用于暗黑模式(Dark)
5.代碼默認(rèn)執(zhí)行時蔫磨,就可以正常通過名字使用了淘讥,系統(tǒng)會根據(jù)當(dāng)前模式自動獲取對應(yīng)的資源文件

注意

同一工程內(nèi)多個Assets文件在打包后,就會生成一個Assets.car 文件堤如,所以要保證Assets內(nèi)資源文件的名字不能相同

UIView

traitCollectionDidChange(_:)
layoutSubviews()
draw(_:)
updateConstraints()
tintColorDidChange()

UIViewController

traitCollectionDidChange(_:)
updateViewConstraints()
viewWillLayoutSubviews()
viewDidLayoutSubviews()

UIPresentationController

traitCollectionDidChange(_:)
containerViewWillLayoutSubviews()
containerViewDidLayoutSubviews()

全局關(guān)閉黑暗模式

  • 方式一 配置plist文件: 在Info.plist 文件中蒲列,添加UIUserInterfaceStyle key 名字為 User Interface Style 值為String,將UIUserInterfaceStyle key 的值設(shè)置為 Light

在開發(fā)中搀罢,如果用的系統(tǒng)控件(如cell蝗岖、tableview的背景色)未設(shè)置背景色(或者為透明),則進(jìn)入暗黑模式后榔至,控件背景色變?yōu)楹谏?/p>

可以每一個頁面設(shè)置抵赢,當(dāng)然也可以整體設(shè)置,
一般我們的APP都是在一個window下的唧取,那就整體設(shè)置APP里的window

  • 方式二 :代碼關(guān)閉黑暗模式 強制關(guān)閉暗黑模式
#if defined(__IPHONE_13_0) && __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_13_0
if(@available(iOS 13.0,*)){
self.window.overrideUserInterfaceStyle = UIUserInterfaceStyleLight;
}
#endif

單個界面不遵循暗黑模式

  1. UIViewController與UIView 都新增一個屬性 overrideUserInterfaceStyle

  2. 將 overrideUserInterfaceStyle 設(shè)置為對應(yīng)的模式铅鲤,則強制限制該元素與其子元素以設(shè)置的模式進(jìn)行展示,不跟隨系統(tǒng)模式改變進(jìn)行改變

    1. 設(shè)置 ViewController 的該屬性枫弟, 將會影響視圖控制器的視圖和子視圖控制器采用該樣式
    2. 設(shè)置 View 的該屬性邢享, 將會影響視圖及其所有子視圖采用該樣式
    3. 設(shè)置 Window 的該屬性, 將會影響窗口中的所有內(nèi)容都采用樣式淡诗,包括根視圖控制器和在該窗口中顯示內(nèi)容的所有演示控制器(UIPresentationController)

iOS適配暗黑模式:http://www.reibang.com/p/7925bd51d2d6

5.增加一直使用藍(lán)牙的權(quán)限申請

CBCentralManager骇塘,iOS13以前,使用藍(lán)牙時可以直接用韩容,不會出現(xiàn)權(quán)限提示款违,iOS13后,再使用就會提示了群凶。
在info.plist里增加

<key>NSBluetoothAlwaysUsageDescription</key> 
<string>我們要一直使用您的藍(lán)牙插爹,具體做什么別問我</string>`

6.使用MJExtension 中處理NSNull的不同

這個直接會導(dǎo)致Crash的在將服務(wù)端數(shù)據(jù)字典轉(zhuǎn)換為模型時,如果遇到服務(wù)端給的數(shù)據(jù)為NSNull時请梢,
mj_JSONObject递惋,其中 class_copyPropertyList方法得到的屬性里柔滔,多了一種EFSQLBinding類型的東西,而且屬性數(shù)量也不準(zhǔn)確萍虽,
那就沒辦法了睛廊,
我只能改寫這個方法了,這個組件沒有更新的情況下杉编,寫了一個方法swizzling掉把當(dāng)遇到 NSNull時超全,直接轉(zhuǎn)為nil了。

7. WKWebView 中測量頁面內(nèi)容高度的方式變更

iOS 13以前
document.body.scrollHeight
iOS 13中
document.documentElement.scrollHeight
兩者相差55 應(yīng)該是瀏覽器定義高度變了

8. 友盟消息推送邓馒,獲取deviceToken適配

- (void)application:(UIApplication *)application
didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
{
   if (![deviceToken isKindOfClass:[NSData class]]) return;
      const unsigned *tokenBytes = (const unsigned *)[deviceToken bytes];
      NSString *hexToken = [NSString stringWithFormat:@"%08x%08x%08x%08x%08x%08x%08x%08x",ntohl(tokenBytes[0]), ntohl(tokenBytes[1]), ntohl(tokenBytes[2]),ntohl(tokenBytes[3]), ntohl(tokenBytes[4]), ntohl(tokenBytes[5]),ntohl(tokenBytes[6]),ntohl(tokenBytes[7])];
      pushDeviceToken = hexToken;
      NSLog(@"deviceToken:%@",hexToken);
}

9. StatusBar 與之前版本不同

目前狀態(tài)欄也增加了一種模式嘶朱,由之前的兩種,變成了三種, 其中default由之前的黑色內(nèi)容光酣,變成了會根據(jù)系統(tǒng)模式疏遏,自動選擇當(dāng)前展示lightContent還是darkContent

10. fishhook 導(dǎo)致的Crash (https://github.com/facebook/fishhook/issues/61

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市救军,隨后出現(xiàn)的幾起案子财异,更是在濱河造成了極大的恐慌,老刑警劉巖唱遭,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件戳寸,死亡現(xiàn)場離奇詭異,居然都是意外死亡拷泽,警方通過查閱死者的電腦和手機疫鹊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來司致,“玉大人拆吆,你說我怎么就攤上這事≈茫” “怎么了锈拨?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長羹唠。 經(jīng)常有香客問我,道長娄昆,這世上最難降的妖魔是什么佩微? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮萌焰,結(jié)果婚禮上哺眯,老公的妹妹穿的比我還像新娘。我一直安慰自己扒俯,他們只是感情好奶卓,可當(dāng)我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布一疯。 她就那樣靜靜地躺著,像睡著了一般夺姑。 火紅的嫁衣襯著肌膚如雪墩邀。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天盏浙,我揣著相機與錄音眉睹,去河邊找鬼。 笑死废膘,一個胖子當(dāng)著我的面吹牛竹海,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播丐黄,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼斋配,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了灌闺?” 一聲冷哼從身側(cè)響起艰争,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎菩鲜,沒想到半個月后园细,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡接校,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年猛频,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蛛勉。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡鹿寻,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出诽凌,到底是詐尸還是另有隱情毡熏,我是刑警寧澤,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布侣诵,位于F島的核電站痢法,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏杜顺。R本人自食惡果不足惜财搁,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望躬络。 院中可真熱鬧尖奔,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至茴扁,卻和暖如春铃岔,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背丹弱。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工德撬, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人躲胳。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓蜓洪,卻偏偏與公主長得像,于是被迫代替她去往敵國和親坯苹。 傳聞我的和親對象是個殘疾皇子隆檀,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,877評論 2 345

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

  • ios13 UISegmentedControl 的 setTintColor 屬性失效, 新增了一個setSe...
    海利昂閱讀 9,170評論 3 5
  • 1.私有KVC 在Xcode10上編譯不會有問題粹湃,但是在Xcode11上編譯的會崩潰恐仑。并且- (void)setV...
    iOS亮子閱讀 916評論 0 2
  • 原文博客地址: iOS13適配深色模式(Dark Mode) 好像大概也許是一年前, Mac OS系統(tǒng)發(fā)布了深色模...
    TitanCoder閱讀 36,923評論 8 61
  • 對iOS13 適配的總結(jié),下面有些是自己遇到的为鳄,有些是收集的裳仆,希望能給大家一些思路 iOS13中presentVi...
    1劍天下閱讀 7,449評論 2 9
  • 蘋果全球開發(fā)者大會 (英文全稱是“Worldwide Developers Conference”),簡稱為“WW...
    Coder_JMicheal閱讀 3,245評論 4 11