用作記錄這次更新遇到的一些坑。目前有以下,持續(xù)更新:
藍牙隱私權(quán)限
modal樣式:modalPresentationStyle
(13.1.2上已修復(fù))UIGestureRecognizer的delaysTouchesBegan與touchesBegan:
UITextField的UIKeyboardWillChangeFrameNotification通知
暫時不適配DarkMode的問題
關(guān)于UTI的一個小問題
待更新......
1. 藍牙隱私權(quán)限
原本公司的app是請求了藍牙權(quán)限Privacy - Bluetooth Peripheral Usage Description的,后來更新的時候也看到有這方面的問題但是沒多想,結(jié)果就崩了。
解決:添加Privacy - Bluetooth Always Usage Description,而且老的還不能刪貌似,否則iOS13以下的又不能用了。
2. modalPresentationStyle
其他分享里肯定也有說到這個,默認modal樣式改了,需要手動設(shè)置對應(yīng)的style,不過我發(fā)現(xiàn)了有兩種說法:
// 說法一
self.modalPresentationStyle = UIModalPresentationOverFullScreen
// 說法二
self.modalPresentationStyle = UIModalPresentationFullScreen
目前知道的區(qū)別是選用UIModalPresentationOverFullScreen會導(dǎo)致dismiss以后前一個controller的viewWillAppear:不走。其他區(qū)別未深究。
解決:present控制器的時候添加x.modalPresentationStyle = UIModalPresentationFullScreen
3. (13.1.2上已修復(fù))UIGestureRecognizer的delaysTouchesBegan與touchesBegan:
我有個view上同時添加了UITapGestureRecognizer和重寫了touchesBegan:系列方法,之前為了防止tap的began與touchesBegan產(chǎn)生可能的沖突,我對手勢的delaysTouchesBegan屬性賦值了YES。在13之前沒問題,但是在更新了13的設(shè)備上,總是先識別tap手勢,只有在tap識別失敗的時候才會調(diào)用touchesBegan:系列方法(雖然看蘋果解釋本來就是這樣的,但是以前不會感覺有什么問題,而這次實測我手指觸摸view手指都快抬起來了才走了touchesBegan),這樣導(dǎo)致操作的時候看上去頁面像卡住了一樣。
我做了一些測試:
在iOS13上不注釋
delaysTouchesBegan:
a. 單次點擊(期望是tap),tap被識別,觸摸不被觸發(fā)。
b. 觸摸view,會先等tap手勢識別失敗,然后觸發(fā)touches系列回調(diào),等待手勢失敗的時間很長。
在iOS13上注釋delaysTouchesBegan:
a. 單次點擊(期望是tap),會執(zhí)行touchesBegan:,touchesCancelled:和tap手勢,并且觸摸的began和tap同時執(zhí)行,觸摸的cancelled在began執(zhí)行完后立即執(zhí)行。
b. 觸摸view,也是兩種同時識別,touches正常執(zhí)行,tap也如預(yù)期的失敗
在iOS12上不注釋delaysTouchesBegan:
a. 單次點擊(期望是tap),如期。
b. 觸摸view,跟上面的iOS13上的區(qū)別是等待時間很短。
所以現(xiàn)在蘋果也說一定要處理touchesCancelled:,原本我只期望在tap手勢里執(zhí)行的一些操作,現(xiàn)在由于touchesBegan-Cancelled也會走一遍,這個在我這里導(dǎo)致了一些問題,所以cancelled里要處理。
解決:我注釋掉了delaysTouchesBegan,改在touchesCancelled:里處理操作。這個屬性慎用,感覺蘋果偷偷把時間延長了。
// tapGesture.delaysTouchesBegan = YES;
4. UITextField的UIKeyboardWillChangeFrameNotification通知
我有個頁面有多個textField,在它們之間切換輸入的時候,會多次收到UIKeyboardWillChangeFrameNotification,而13之前沒這個問題,這個可能會導(dǎo)致布局上的問題。
連接手機調(diào)試的時候,在多個textField輸入框之間快速來回點擊,會出現(xiàn)CPU飆到95+的情況,觀察到后面的banner都不滾動了,Time Profile里給出的信息:

解決:關(guān)注一下鍵盤彈出收回操作時視圖布局可能出現(xiàn)的問題。
5. 暫時不適配DarkMode的問題
- 原本app里的某些文字顏色是自定義的一種深色,結(jié)果在設(shè)置了深色模式的設(shè)備上直接看不到了(應(yīng)該是很淺的顏色?跟白色背景混一起了)。
- 狀態(tài)欄手動設(shè)置
UIStatusBarStyleDefault的地方顏色會與期望的不一致
解決:最好的解決辦法當然是適配DarkMode了。對于暫時不適配的,我在info.plist里設(shè)置了User Interface Style = Light,然后在需要設(shè)置狀態(tài)欄的地方分情況判斷。
6. 關(guān)于UTI的一個小問題
app有自定義一個文件格式,原本conform topublic.content,在iOS13之前都沒問題,在iOS13的設(shè)備上,從第三方app打開我這個自定義格式的文件,居然找不到我的app了,我懷疑是不是我原本對于public.content有哪里理解錯了。
解決:自定義文件類型改成comforms topublic.data,現(xiàn)在看來沒問題。