發現問題
最近產品提了一個需求:要求某個“輸入框”禁止輸入 Emoji 表情,我們能想到的方案是:在 UITextField 的 textField:shouldChangeCharactersInRange:replacementString: 代理方法中判斷即將輸入的字符串是否包含 Emoji 表情,如果包含,就在該方法中返回 NO,不允許輸入。
關于如何判斷一字符串是否包含 Emoji 表情的方法,網上已經有很多代碼片段,一般是通過 Unicode 編碼范圍來判斷 ,詳見這里:https://gist.github.com/cihancimen/4146056 ,方法名記為:
- (BOOL)stringContainsEmoji:(NSString *)string;
按照上述思路開發完后,Emoji 表情確實是被限制住無法輸入了,但是當把鍵盤切換為 iOS 系統自帶的九宮格拼音鍵盤準備輸入漢字時,卻發現拼音無法輸入。這是怎么回事?
解決過程
首先通過觀察系統自帶拼音鍵盤的行為,可以發現,當通過拼音來輸入漢字時,系統會先在輸入框中“預輸入”拼音字母作為占位,等用戶在鍵盤上選中漢字時,輸入框中的占位“拼音字母”就會被替換為所對應的漢字,如下圖:
通過斷點調試我們還發現,在輸入拼音過程中,以“知識小集”(zhishixiaoji)為例,當我們通過點擊第 9 個鍵來輸入字母 z 時,在 UITextField 的代理方法中獲取到的即將輸入的字符不是 z ,而是一個符號 ? ,而輸入結束后(textFieldDidChange:)該符號 ? 就會被替換為所對應的字母,然后當點擊第 4 個鍵來輸入字母 h 時,同樣地得到即將輸入的字符為 ? ,然后再被替換為 h,以此類推…
我們猜測,蘋果之所以這么做是因為,對于九宮格拼音鍵盤,一個鍵代表著 3 或 4 個字母,當你點擊一個鍵時,它并不知道你要輸入那個字母,所以用一個帶圓圈的數字符號作為臨時占位,等輸入結束時才替換為相應的字母。
在九宮格拼音鍵盤中,”ABC” 鍵 ~ “WXYZ” 鍵所對應的臨時占位符號分別為 ?? … ? ,表情 “^-^” 鍵所對應的為符號 ? ,而這些符號在 stringContainsEmoji: 方法中剛好都被判為是 Emoji,所以當輸入框禁止輸入 Emoji 表情時,就會導致拼音也無法輸入。
解決方案
就是在 Emoji 判定方法中,過濾掉上述符號(對應的 Unicode 編碼為 U+278b ~ U+2792 和 U+263b),如下:
但我們發現系統自帶的“全鍵盤拼音輸入”不會有上述問題,因為每個鍵都只代表一個字母:
而且,國內常用的第三方輸入法也不會有這個問題,因為它們不會在輸入框中“預輸入”拼音字符(而是把拼音顯示在鍵盤上方),只有等用戶選中漢字時,才把漢字填寫到輸入框中,如下(搜狗輸入法):
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答