新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 基于Qtopia的嵌入式中文輸入法設(shè)計

基于Qtopia的嵌入式中文輸入法設(shè)計

作者: 時間:2010-07-20 來源:網(wǎng)絡(luò) 收藏

2 中的實現(xiàn)
2.1 模塊的實現(xiàn)

拼音,要實現(xiàn)數(shù)字拼音鍵到漢字的轉(zhuǎn)換。所謂數(shù)字拼音是指按照手機鍵盤上英文字母的布局來輸入漢語拼音所得到的一串?dāng)?shù)字,對于九宮格形式的虛擬鍵盤來說,其鍵盤的布局特點導(dǎo)致不能直接輸入漢語拼音而只能輸入數(shù)字鍵盤掃描碼,然后由掃描碼的識別及糾錯處理模塊對其進行拼音組合、文字匹配檢索后才能得到相應(yīng)的漢字,處理流程見圖l。

本文引用地址:http://m.butianyuan.cn/article/151720.htm


首先用戶輸入的數(shù)字鍵盤掃描碼要轉(zhuǎn)換為相應(yīng)的漢語拼音,本文采用查表檢索法實現(xiàn)數(shù)字拼音到漢語拼音的轉(zhuǎn)換,并對用戶無效的拼音組合進行高亮提示。然后根據(jù)字典數(shù)據(jù)庫檢索相應(yīng)的漢字,并對用戶的輸入進行機器學(xué)習(xí),針對用戶輸入習(xí)慣不同,對用戶輸入常用詞進行自適應(yīng)排序。利用自帶字庫的基礎(chǔ)語言模型與用戶常用詞模型相結(jié)合的檢索技術(shù)對候選字進行自動排序,得到最終的候選字輸出。如圖2所示。


該輸入法注重對用戶輸入的常用詞、高頻詞的自適應(yīng),利用基礎(chǔ)字庫模型和用戶習(xí)慣模型結(jié)合進行解碼。主要思想是通過跟蹤用戶輸入過程,記錄用戶輸入習(xí)慣,然后根據(jù)用戶的輸入字詞的不同概率動態(tài)調(diào)整相應(yīng)的數(shù)據(jù),并將結(jié)果存放于用戶模型中。
2.2 移植輸入法到
2.x系統(tǒng)中支持彈出式輸入法的插件實現(xiàn)。彈出式輸入法在沒有鍵盤和其他文件輸入設(shè)備時使用,它彈出窗口部件,用戶可通過設(shè)備的觸摸屏操作產(chǎn)生鍵事件,它們也被看做筆的輸入方法。在本文中,采用ExtInputMethodInterface作為創(chuàng)建輸入法插件的接口。
(1)為彈出輸入方法設(shè)備窗口部件。彈出輸入法必須提供一個顯示在屏幕上的Qwidget窗口部件,并在一個鍵被按下時發(fā)出一個信號,Qt-opia處理輸入窗口部件的顯示和隱藏。信號和插槽是Qt的核心機制,應(yīng)用于對象之間的通信,信號和插槽是真正的信息封裝,所有從QObject或其子類派生的類都能夠包含信號,當(dāng)對象改變狀態(tài)時,信號就由該對象發(fā)射(emit)出去,對象并不需要知道另一端是誰在接收這個信號。本文的輸入法,在用戶點擊選字按鍵時,一個包含所選字符的keyPress信號被發(fā)射出去。

linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)


評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉