天天看点

Android 3.0 r1中文API文档(103) —— InputMethodManager [输入法]

正文

  一、结构

public final class InputMethodManager extends Object

java.lang.Object

android.view.inputmethod.InputMethodManager

  二、类概述

  架构总述(Architecture Overview)

  输入法框架(IMF)共有三个主要部分:

  * 输入法管理器,管理各部分的交互。它是一个客户端API,存在于各个应用程序的context中,用来沟通管理所有进程间交互的全局系统服务。

  * 输入法(IME) ,实现一个允许用户生成文本的独立交互模块。系统绑定一个当前的输入法。使其创建和生成,决定输入法何时隐藏或者显示它的UI。同一时间只能有一个IME运行。

  * 客户应用程序,通过输入法管理器控制输入焦点和IME的状态。一次只能有一个客户端使用IME。

  应用程序(Applications)

  大多数情况下,使用标准TextView或其子类的应用程序只要做少量工作就可以让软键盘(soft input methods)正常工作。你要注意的是:

  通过API可以与IMF及其IME交互实现更细致的控制,如显示或输入区域,用户选取某输入法等。

    输入法(Input Methods)

    安全(Security)

  输入法关系到许多安全问题,因其基本不受约束地驱动UI并监视用户输入。Android输入法框架还允许调度第三方IME,所必须小心以限制他们的选择和相互作用。

  以下是IMF背后安全架构的要点:

* IMF中可能有许多客户进程,但在同一时间只有一个是激活的。未激活客户端不能与IMF核心交互通过下述机制实现。

* 客户应用程序可以要求系统选取一个新的IME,但不能编程式选择之一。这是避免恶意程序在用户导航到其它应用程序时,选择自己的IME并保持运行。也就是说,IME可以编程式的要求系统选择其它IME,因它完全控制了用户输入。

用户在可切换至一个新的IME前必须显式的启用它,以确认系统了解它,使其处于可用状态。

  三、常量

    public static final int HIDE_IMPLICIT_ONLY

           常量值: 1 (0x00000001)

    public static final int HIDE_NOT_ALWAYS

    常量值: 2 (0x00000002)

    public static final int RESULT_HIDDEN

    常量值: 3 (0x00000003)

    public static final int RESULT_SHOWN

    public static final int RESULT_UNCHANGED_HIDDEN

    常量值: 1 (0x00000001)

    public static final int RESULT_UNCHANGED_SHOWN

    常量值: 0 (0x00000000)

    public static final int SHOW_FORCED

    public static final int SHOW_IMPLICIT

常量值: 1 (0x00000001)

  四、公共方法

    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       在输入法启动时提供令牌验证,验证后可对其进行操作。

    public boolean hideSoftInputFromWindow (IBinder windowToken, int flags)

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

    从窗口上下文中确定当前接收输入的窗口,要求隐藏其软键盘窗口。它可由用户调用并得到结果而不仅仅是显式要求输入法窗口隐藏。

    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)

             参数

    view         可选的发送命令的视图,如你要发送命令而不考虑视图附加到输入法,此项可以为空。

    action      执行的命令名称。必须是作用域的名称,如前缀包名称,这样不同的开发者就不会创建冲突的命令。

    data         命令中包含的任何数据。

    public boolean setCurrentInputMethodSubtype (InputMethodSubtype subtype)

    (译者注:此方法为3.0中新增的方法)

    public void setInputMethod (IBinder token, String id)

    强制切换到新输入法部件。只能由持有token的应用程序(application)或服务(service) 调用当前激活输入法。

    id              切换到新输入法的唯一标识。

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

    强制切换到一个新的输入法和指定的类型。只能由持有token的应用程序(application)或服务(service) 调用当前激活输入法。(译者注:此方法为3.0中新增的方法)

    id              切换到新输入法的唯一标识。

    subtype 切换到新输入法的新类型。

    public void showInputMethodAndSubtypeEnabler (String topId)

    public void showInputMethodPicker ()

    (译者注:显示输入法菜单列表)

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

    如需要,显式要求当前输入法的软键盘区域向用户显示。当用户与视图交互,用户表示要开始执行输入操作时,可以调用此方法。

    view         当前焦点视图,可接受软键盘输入。

    public boolean showSoftInput (View view, int flags)

    public void showSoftInputFromInputMethod (IBinder token, int flags)

    显示输入法的软键盘区域,这样用户可以到看到输入法窗口并能与其交互。只能由当前激活输入法调用,因需令牌(token)验证。

    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)

    本方法切换输入法的窗口显示。如输入窗口已显示,它隐藏。如无输入窗口则显示。

    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)

返回当前选择区域。

  五、补充

文章精选

<a href="http://blog.csdn.net/pilou5400/archive/2010/10/20/5954905.aspx">android 软键盘 InputMethodManager</a>

<a href="http://blog.csdn.net/a345017062/archive/2011/01/06/6121147.aspx">Android输入法框的梳理</a>

<a href="http://yongsun.me/2010/10/%E5%BC%80%E6%BA%90%E6%8B%BC%E9%9F%B3%E8%BE%93%E5%85%A5%E6%B3%95%E7%A4%BE%E5%8C%BA%E7%9A%84%E5%A4%A7%E8%9E%8D%E5%90%88%EF%BC%88libpinyin%EF%BC%89/">开源拼音输入法社区的大融合(libpinyin)</a>

<a href="http://www.doc88.com/p-66411886449.html">android中文输入法实现</a>

结束

  越忙越需要坚持。 

本文转自over140 51CTO博客,原文链接:http://blog.51cto.com/over140/582384,如需转载请自行联系原作者

继续阅读