用作記錄這次更新遇到的一些坑。目前有以下,持續更新:
藍牙隱私權限
modal樣式:modalPresentationStyle
(13.1.2上已修復)UIGestureRecognizer的delaysTouchesBegan與touchesBegan:
UITextField的UIKeyboardWillChangeFrameNotification通知
暫時不適配DarkMode的問題
關于UTI的一個小問題
待更新......
1. 藍牙隱私權限
原本公司的app是請求了藍牙權限Privacy - Bluetooth Peripheral Usage Description
的,后來更新的時候也看到有這方面的問題但是沒多想,結果就崩了。
解決:添加Privacy - Bluetooth Always Usage Description
,而且老的還不能刪貌似,否則iOS13以下的又不能用了。
2. modalPresentationStyle
其他分享里肯定也有說到這個,默認modal樣式改了,需要手動設置對應的style,不過我發現了有兩種說法:
// 說法一
self.modalPresentationStyle = UIModalPresentationOverFullScreen
// 說法二
self.modalPresentationStyle = UIModalPresentationFullScreen
目前知道的區別是選用UIModalPresentationOverFullScreen
會導致dismiss以后前一個controller的viewWillAppear:
不走。其他區別未深究。
解決:present控制器的時候添加x.modalPresentationStyle = UIModalPresentationFullScreen
3. (13.1.2上已修復)UIGestureRecognizer的delaysTouchesBegan與touchesBegan:
我有個view上同時添加了UITapGestureRecognizer
和重寫了touchesBegan:
系列方法,之前為了防止tap的began與touchesBegan產生可能的沖突,我對手勢的delaysTouchesBegan
屬性賦值了YES
。在13之前沒問題,但是在更新了13的設備上,總是先識別tap手勢,只有在tap識別失敗的時候才會調用touchesBegan:
系列方法(雖然看蘋果解釋本來就是這樣的,但是以前不會感覺有什么問題,而這次實測我手指觸摸view手指都快抬起來了才走了touchesBegan),這樣導致操作的時候看上去頁面像卡住了一樣。
我做了一些測試:
在iOS13上不注釋
delaysTouchesBegan
:
a. 單次點擊(期望是tap),tap被識別,觸摸不被觸發。
b. 觸摸view,會先等tap手勢識別失敗,然后觸發touches系列回調,等待手勢失敗的時間很長。
在iOS13上注釋delaysTouchesBegan
:
a. 單次點擊(期望是tap),會執行touchesBegan:
,touchesCancelled:
和tap手勢,并且觸摸的began和tap同時執行,觸摸的cancelled在began執行完后立即執行。
b. 觸摸view,也是兩種同時識別,touches正常執行,tap也如預期的失敗
在iOS12上不注釋delaysTouchesBegan
:
a. 單次點擊(期望是tap),如期。
b. 觸摸view,跟上面的iOS13上的區別是等待時間很短。
所以現在蘋果也說一定要處理touchesCancelled:
,原本我只期望在tap手勢里執行的一些操作,現在由于touchesBegan-Cancelled
也會走一遍,這個在我這里導致了一些問題,所以cancelled里要處理。
解決:我注釋掉了delaysTouchesBegan
,改在touchesCancelled:
里處理操作。這個屬性慎用,感覺蘋果偷偷把時間延長了。
// tapGesture.delaysTouchesBegan = YES;
4. UITextField的UIKeyboardWillChangeFrameNotification通知
我有個頁面有多個textField,在它們之間切換輸入的時候,會多次收到UIKeyboardWillChangeFrameNotification
,而13之前沒這個問題,這個可能會導致布局上的問題。
連接手機調試的時候,在多個textField輸入框之間快速來回點擊,會出現CPU飆到95+的情況,觀察到后面的banner都不滾動了,Time Profile里給出的信息:
解決:關注一下鍵盤彈出收回操作時視圖布局可能出現的問題。
5. 暫時不適配DarkMode的問題
- 原本app里的某些文字顏色是自定義的一種深色,結果在設置了深色模式的設備上直接看不到了(應該是很淺的顏色?跟白色背景混一起了)。
- 狀態欄手動設置
UIStatusBarStyleDefault
的地方顏色會與期望的不一致
解決:最好的解決辦法當然是適配DarkMode了。對于暫時不適配的,我在info.plist
里設置了User Interface Style = Light
,然后在需要設置狀態欄的地方分情況判斷。
6. 關于UTI的一個小問題
app有自定義一個文件格式,原本conform topublic.content
,在iOS13之前都沒問題,在iOS13的設備上,從第三方app打開我這個自定義格式的文件,居然找不到我的app了,我懷疑是不是我原本對于public.content
有哪里理解錯了。
解決:自定義文件類型改成comforms topublic.data
,現在看來沒問題。