用作記錄這次更新遇到的一些坑吃型。目前有以下喇勋,持續(xù)更新:
藍牙隱私權(quán)限
modal樣式:modalPresentationStyle
(13.1.2上已修復)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è)置對應的style,不過我發(fā)現(xiàn)了有兩種說法:
// 說法一
self.modalPresentationStyle = UIModalPresentationOverFullScreen
// 說法二
self.modalPresentationStyle = UIModalPresentationFullScreen
目前知道的區(qū)別是選用UIModalPresentationOverFullScreen
會導致dismiss以后前一個controller的viewWillAppear:
不走最疆。其他區(qū)別未深究杯巨。
解決:present控制器的時候添加x.modalPresentationStyle = UIModalPresentationFullScreen
3. (13.1.2上已修復)UIGestureRecognizer的delaysTouchesBegan與touchesBegan:
我有個view上同時添加了UITapGestureRecognizer
和重寫了touchesBegan:
系列方法,之前為了防止tap的began與touchesBegan產(chǎn)生可能的沖突努酸,我對手勢的delaysTouchesBegan
屬性賦值了YES
服爷。在13之前沒問題,但是在更新了13的設(shè)備上获诈,總是先識別tap手勢层扶,只有在tap識別失敗的時候才會調(diào)用touchesBegan:
系列方法(雖然看蘋果解釋本來就是這樣的,但是以前不會感覺有什么問題烙荷,而這次實測我手指觸摸view手指都快抬起來了才走了touchesBegan)镜会,這樣導致操作的時候看上去頁面像卡住了一樣。
我做了一些測試:
在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也如預期的失敗
在iOS12上不注釋delaysTouchesBegan
:
a. 單次點擊(期望是tap)竹伸,如期泥栖。
b. 觸摸view,跟上面的iOS13上的區(qū)別是等待時間很短。
所以現(xiàn)在蘋果也說一定要處理touchesCancelled:
吧享,原本我只期望在tap手勢里執(zhí)行的一些操作魏割,現(xiàn)在由于touchesBegan-Cancelled
也會走一遍,這個在我這里導致了一些問題钢颂,所以cancelled里要處理钞它。
解決:我注釋掉了delaysTouchesBegan
,改在touchesCancelled:
里處理操作甸陌。這個屬性慎用,感覺蘋果偷偷把時間延長了盐股。
// tapGesture.delaysTouchesBegan = YES;
4. UITextField的UIKeyboardWillChangeFrameNotification通知
我有個頁面有多個textField钱豁,在它們之間切換輸入的時候,會多次收到UIKeyboardWillChangeFrameNotification
疯汁,而13之前沒這個問題牲尺,這個可能會導致布局上的問題。
連接手機調(diào)試的時候幌蚊,在多個textField輸入框之間快速來回點擊谤碳,會出現(xiàn)CPU飆到95+的情況,觀察到后面的banner都不滾動了溢豆,Time Profile里給出的信息:
解決:關(guān)注一下鍵盤彈出收回操作時視圖布局可能出現(xiàn)的問題。
5. 暫時不適配DarkMode的問題
- 原本app里的某些文字顏色是自定義的一種深色漩仙,結(jié)果在設(shè)置了深色模式的設(shè)備上直接看不到了(應該是很淺的顏色搓茬?跟白色背景混一起了)。
- 狀態(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)在看來沒問題放刨。