Android 3.0 r1中文API文檔(103) —— InputMethodManager [輸入法]

前言html

  本章內容是android.view.inputmethod.InputMethodManager,爲輸入法相關章節,版本爲Android 3.0 r1,翻譯來自"六必治",歡迎你們訪問他的博客:http://www.cnblogs.com/zcmky/,再次感謝"六必治" !期待你加入Android API 中文的翻譯,聯繫我over140@gmail.com。java

 

聲明android

  歡迎轉載,但請保留文章原始出處:)
 編程

    農民伯伯:http://over140.blog.51cto.com/安全

    Android中文翻譯組: http://goo.gl/6vJQl


正文架構

  1、結構app

public final class InputMethodManager extends Object框架

        

java.lang.Object編輯器

android.view.inputmethod.InputMethodManageride

 

  2、類概述

  整個輸入法框架(IMF)結構的核心API,應用程序之間進行調度和當前輸入法交互。你能夠用Context.getSystemService()取得這一接口的實例。

  架構總述(Architecture Overview)

  輸入法框架(IMF)共有三個主要部分:

  * 輸入法管理器,管理各部分的交互。它是一個客戶端API,存在於各個應用程序的context中,用來溝通管理全部進程間交互的全局系統服務。

  * 輸入法(IME) ,實現一個容許用戶生成文本的獨立交互模塊。系統綁定一個當前的輸入法。使其建立和生成,決定輸入法什麼時候隱藏或者顯示它的UI。同一時間只能有一個IME運行。

  * 客戶應用程序,經過輸入法管理器控制輸入焦點和IME的狀態。一次只能有一個客戶端使用IME

  應用程序(Applications)

  大多數狀況下,使用標準TextView或其子類的應用程序只要作少許工做就可讓軟鍵盤(soft input methods)正常工做。你要注意的是:

  * 正確設置你的可編輯文本視圖inputType,這樣輸入法有足夠的上下文幫助用戶向其輸入文本。

  * 當輸入法顯示時妥善處理隱藏屏幕空間。理想的狀況下應用程序應處理窗口變小,如必要你能夠利用系統執行平移窗口。你應在活動(activity)中設置windowSoftInputMode屬性或調整建立窗口的相應值,以便系統決定平移或縮放(它會嘗試自動調整但可能出錯)。

  * 你還能夠經過相同的windowSoftInputMode控制窗口的首選軟鍵盤狀態(打開、關閉等)。

  經過API能夠與IMF及其IME交互實現更細緻的控制,如顯示或輸入區域,用戶選取某輸入法等。

  當你編寫本身的文本編輯器的時候,你要實現onCreateInputConnection(EditorInfo)以返回你的InputConnection的接口實例,用來容許IME和你的文本編輯域來交互。

    輸入法(Input Methods)

  一個輸入法(IME)是Service(服務)的實現,一般繼承自 InputMethodServiceIME提供核心的 InputMethod接口,儘管提供InputMethod一般是由InputMethodService來處理,而IME的實現只須要處理更高層的API

           更多信息參閱InputMethodService

    安全(Security)

  輸入法關係到許多安全問題,因其基本不受約束地驅動UI並監視用戶輸入。Android輸入法框架還容許調度第三方IME,所必須當心以限制他們的選擇和相互做用。

  如下是IMF背後安全架構的要點:

* 只容許系統訪問經BIND_INPUT_METHOD權限許可訪問IMEInputMethod接口。經過綁定到要求這個權限的服務來強制實現這一點。因此係統能夠保證沒有不被信任的客戶端在它的控制以外訪問到當前的輸入法。

* IMF中可能有許多客戶進程,但在同一時間只有一個是激活的。未激活客戶端不能與IMF核心交互經過下述機制實現。

* 輸入法客戶端只可訪問InputMethodSession接口。每一個客戶端建立一個接口實例,只有與激活客戶相關聯的會話的調用纔會被IME處理。這點經過普通IME AbstractInputMethodService執行,必須由IME顯式的處理,而IME正是InputMethodSession的自定義實現。

* 只有激活的InputConnection接受操做。IMF通知每一個客戶進程是否激活,IMF忽略非激活進程對當前輸入聯接的調用。這確保了當前IME只將事件和文本編輯交付用戶可見焦點的UI

* 一個IME永遠不能在屏幕關閉時與 InputConnection交互。這是經過當屏幕關閉時全部客戶端無效,並防止不良IME在用戶沒法關注其行爲時驅動UI

* 客戶應用程序能夠要求系統選取一個新的IME,但不能編程式選擇之一。這是避免惡意程序在用戶導航到其它應用程序時,選擇本身的IME並保持運行。也就是說,IME能夠編程式的要求系統選擇其它IME,因它徹底控制了用戶輸入。

     用戶在可切換至一個新的 IME 前必須顯式的啓用它,以確認系統瞭解它,使其處於可用狀態。
 

  3、常量

    public static final int HIDE_IMPLICIT_ONLY

           hideSoftInputFromWindow(IBinder, int)中的標誌,表示若是用戶未顯式地顯示軟鍵盤窗口,則隱藏窗口。

           常量值: 1 (0x00000001)

 

    public static final int HIDE_NOT_ALWAYS

    hideSoftInputFromWindow(IBinder, int)中的標誌,表示軟鍵盤窗口老是隱藏,除非開始時以SHOW_FORCED顯示。

    常量值: 2 (0x00000002)

 

    public static final int RESULT_HIDDEN

 

    showSoftInput(View, int, ResultReceiver)hideSoftInputFromWindow(IBinder, int, ResultReceiver)ResultReceiver結果代碼標誌:軟鍵盤窗口從顯示切換到隱藏時的狀態。

    常量值: 3 (0x00000003)

 

    public static final int RESULT_SHOWN

 

    showSoftInput(View, int, ResultReceiver)hideSoftInputFromWindow(IBinder, int, ResultReceiver)ResultReceiver結果代碼標誌:軟鍵盤窗口從隱藏切換到顯示時的狀態。

    常量值: 2 (0x00000002)

 

    public static final int RESULT_UNCHANGED_HIDDEN

 

    showSoftInput(View, int, ResultReceiver)hideSoftInputFromWindow(IBinder, int, ResultReceiver)ResultReceiver結果代碼標誌:軟鍵盤窗口不變保持隱藏時的狀態。

    常量值: 1 (0x00000001)

 

    public static final int RESULT_UNCHANGED_SHOWN

 

    showSoftInput(View, int, ResultReceiver)hideSoftInputFromWindow(IBinder, int, ResultReceiver)ResultReceiver結果代碼標誌:軟鍵盤窗口不變保持顯示時的狀態。

    常量值: 0 (0x00000000)

 

    public static final int SHOW_FORCED

    showSoftInput(View, int)標誌,表示用戶強制打開輸入法(如長按菜單鍵),一直保持打開直至只有顯式關閉。

    常量值: 2 (0x00000002)

 

    public static final int SHOW_IMPLICIT

      showSoftInput(View, int)標誌,表示隱式顯示輸入窗口,非用戶直接要求。窗口可能不顯示。

       常量值 : 1 (0x00000001)
 

  4、公共方法

    public void displayCompletions (View view, CompletionInfo[] completions)

    (譯者注:輸入法自動完成)

 

    public InputMethodSubtype getCurrentInputMethodSubtype ()

    (譯者注:獲取當前輸入法類型?)

 

    public List<InputMethodInfo> getEnabledInputMethodList ()

    (譯者注:獲取已啓用輸入法列表?)

 

    public List<InputMethodSubtype> getEnabledInputMethodSubtypeList (InputMethodInfo imi, boolean allowsImplicitlySelectedSubtypes)

 

    public List<InputMethodInfo> getInputMethodList ()

    (譯者注:獲取輸入法列表)

 

    public Map<InputMethodInfo, List<InputMethodSubtype>> getShortcutInputMethodsAndSubtypes ()

 

    public void hideSoftInputFromInputMethod (IBinder token, int flags)

    關閉/隱藏輸入法軟鍵盤區域,用戶再也不看到或與其交互。只能由當前激活輸入法調用,因需令牌(token)驗證。

    參數

    token       在輸入法啓動時提供令牌驗證,驗證後可對其進行操做。

    flags        提供額外的操做標誌。當前能夠爲0 HIDE_IMPLICIT_ONLY, HIDE_NOT_ALWAYS等位設置。

 

    public boolean hideSoftInputFromWindow (IBinder windowToken, int flags)

      hideSoftInputFromWindow(IBinder, int, ResultReceiver)的無返回值版:從窗口上下文中肯定當前接收輸入的窗口,隱藏其輸入法窗口

    參數

    windowToken 由窗口請求View.getWindowToken()返回獲得的令牌(token)

    flags        提供額外的操做標誌。當前能夠爲0 HIDE_IMPLICIT_ONLY位設置。

 

    public boolean hideSoftInputFromWindow (IBinder windowToken, int flags, ResultReceiver resultReceiver)

    從窗口上下文中肯定當前接收輸入的窗口,要求隱藏其軟鍵盤窗口。它可由用戶調用並獲得結果而不只僅是顯式要求輸入法窗口隱藏。

    參數

    windowToken 由窗口請求View.getWindowToken()返回獲得的令牌(token)

    flags        提供額外的操做標誌。當前能夠爲0 HIDE_IMPLICIT_ONLY位設置。

        resultReceiver  如不爲空,當IME處理請求告訴你完成時調用。你收到的結果碼能夠是RESULT_UNCHANGED_SHOWN, RESULT_UNCHANGED_HIDDEN, RESULT_SHOWN, RESULT_HIDDEN

 

    public void hideStatusIcon (IBinder imeToken)

    (譯者注:隱藏狀態欄圖標?)

 

    public boolean isAcceptingText ()

    當前服務視圖接受全文編輯返回真。沒有輸入法聯接爲false,這時其只能處理原始按鍵事件。

 

    public boolean isActive (View view)

    視圖爲當前輸入的激活視圖時返回真。

 

    public boolean isActive ()

    輸入法中的任意視圖激活時返回真。

 

    public boolean isFullscreenMode ()

    判斷相關輸入法是否以全屏模式運行。全屏時,徹底覆蓋你的UI時,返回真,不然返回假。

 

    public boolean isWatchingCursor (View view)

    如當前輸入法要看到輸入編輯者的光標位置時返回真。

 

    public void restartInput (View view)

    若有輸入法聯接至視圖,重啓輸入以顯示新的內容。可在如下狀況時調用此方法:視圖的文字致使輸入法外觀變化或有按鍵輸入流,如應用程序調用TextView.setText()時。

             參數

    view        文字發生變化的視圖。

 

    public void sendAppPrivateCommand (View view, String action, Bundle data)

    對當前輸入法調用 InputMethodSession.appPrivateCommand()

             參數

    view         可選的發送命令的視圖,如你要發送命令而不考慮視圖附加到輸入法,此項能夠爲空。

    action      執行的命令名稱。必須是做用域的名稱,如前綴包名稱,這樣不一樣的開發者就不會建立衝突的命令。

    data         命令中包含的任何數據。

 

    public boolean setCurrentInputMethodSubtype (InputMethodSubtype subtype)

    (譯者注:此方法爲3.0中新增的方法)

 

    public void setInputMethod (IBinder token, String id)

    強制切換到新輸入法部件。只能由持有token的應用程序(application)或服務(service) 調用當前激活輸入法。

             參數

    token       在輸入法啓動時提供令牌驗證,驗證後可對其進行操做。

 

    id              切換到新輸入法的惟一標識。

 

 

    public void setInputMethodAndSubtype (IBinder token, String id, InputMethodSubtype subtype)

    強制切換到一個新的輸入法和指定的類型。只能由持有token的應用程序(application)或服務(service) 調用當前激活輸入法。(譯者注:此方法爲3.0中新增的方法)

             參數

    token       在輸入法啓動時提供令牌驗證,驗證後可對其進行操做。

    id              切換到新輸入法的惟一標識。

    subtype 切換到新輸入法的新類型。

 

    public void showInputMethodAndSubtypeEnabler (String topId)

    譯者注:此方法爲3.0中新增的方法)

 

    public void showInputMethodPicker ()

    (譯者注:顯示輸入法菜單列表)

 

    public boolean showSoftInput (View view, int flags, ResultReceiver resultReceiver)

    如須要,顯式要求當前輸入法的軟鍵盤區域向用戶顯示。當用戶與視圖交互,用戶表示要開始執行輸入操做時,能夠調用此方法。

             參數

    view         當前焦點視圖,可接受軟鍵盤輸入。

    flags        提供額外的操做標誌。當前能夠是0SHOW_IMPLICIT 位設置。

    resultReceiver         如不爲空,當IME處理請求告訴你完成時調用。你收到的結果碼能夠是RESULT_UNCHANGED_SHOWN, RESULT_UNCHANGED_HIDDEN, RESULT_SHOWN, RESULT_HIDDEN

 

    public boolean showSoftInput (View view, int flags)

showSoftInput(View, int, ResultReceiver)的無返回值版:如須要,顯式要求當前輸入法的軟鍵盤區域向用戶顯示。

             參數

    view         當前焦點視圖,可接受軟鍵盤輸入。

    flags        提供額外的操做標誌。當前能夠是0SHOW_IMPLICIT 位設置。

 

    public void showSoftInputFromInputMethod (IBinder token, int flags)

    顯示輸入法的軟鍵盤區域,這樣用戶能夠到看到輸入法窗口並能與其交互。只能由當前激活輸入法調用,因需令牌(token)驗證。

             參數

    token       在輸入法啓動時提供令牌驗證,驗證後可對其進行操做。

    flags        提供額外的操做標誌。能夠是0 SHOW_IMPLICIT, SHOW_FORCED位設置。

 

    public void showStatusIcon (IBinder imeToken, String packageName, int iconId)

    (譯者注:顯示狀態欄圖標?)

 

    public boolean switchToLastInputMethod (IBinder imeToken)

 

    public void toggleSoftInput (int showFlags, int hideFlags)

    (譯者注:切換軟鍵盤)

 

    public void toggleSoftInputFromWindow (IBinder windowToken, int showFlags, int hideFlags)

    本方法切換輸入法的窗口顯示。如輸入窗口已顯示,它隱藏。如無輸入窗口則顯示。

             參數

    windowToken  由窗口請求View.getWindowToken()返回獲得的令牌(token)

    showFlags       提供額外的操做標誌。當前能夠爲0 HIDE_IMPLICIT_ONLY位設置。

    hideFlags         提供額外的操做標誌。能夠是0 HIDE_IMPLICIT_ONLY, HIDE_NOT_ALWAYS位設置。

 

    public void updateCursor (View view, int left, int top, int right, int bottom)

    返回窗口的當前光標位置。

 

    public void updateExtractedText (View view, int token, ExtractedText text)

    (譯者注:當內容變化時文本編輯器調用此方法,通知其新提取文本。)

 

    public void updateSelection (View view, int selStart, int selEnd, int candidatesStart, int candidatesEnd)

     返回當前選擇區域。
 

  5、補充

 

結束
 

  越忙越須要堅持。  

相關文章
相關標籤/搜索