需要學習輸入法框架的 API;不同系統的輸入法框架有較大差異,可能會涉及壹些系統底層的細節;調試困難;Windows 的輸入法以 DLL 註入方式加載,需要事先註冊到系統,且不可運行時替換 (hot-swap);Mac OS 對輸入法做超時控制,難以利用斷點單步調試我的建議是,在理解輸入法工作原理的基礎上,先寫壹個邏輯純粹的、在命令行上以 REPL (Read-eval-print loop) 方式工作的輸入法原型。比方說,首先實現輸入壹串編碼、查詞典、輸出查詢結果。如果是做拼音輸入法,可進壹步在詞典查詢基礎上完成詞組、語句的轉換。然後,再增加選字、編輯等功能鍵的處理邏輯。不可顯示為字符的按鍵,可通過轉義序列模擬,例如 `rime_api_console` 采用花括弧+IBus鍵名表示任意的按鍵:`shuruufa{Left}{Left}{BackSpace}{End}`/lotem/librime/blob/master/tools/rime_api_console.cc#L144這樣做的好處是可以將測試用的按鍵序列保存為文本,通過輸入重定向重放測試場景:```$ rime_api_console< test_key_sequence.txt```原型將輸入法所需邏輯完全實現後,即可集成到真實的輸入法框架,完善用戶介面等等。最後,藉機宣傳壹下 RIME:RIME/中州韻輸入法引擎,是壹套跨平臺的輸入法算法框架,即在輸入法與操作系統接口之上封裝了壹套輸入法常用的算法和邏輯組件,允許用戶以 YAML 文檔格式自定義輸入方案和碼表,快速建立拼音、註音、五筆及類似形態的輸入法。對於需要特殊邏輯的輸入法,可通過編程擴展該框架,使開發者只須專註於相關邏輯。目前這壹框架的不足是接口尚未完全定型、缺少開發文檔。