Android输入法不使用多客户端多屏适配-Android12
- 1、IME屏幕之间切换
- 2、属性配置
- 3、屏幕之间切换 IME 窗口
在非默认屏幕上运行的应用
1、IME屏幕之间切换
系统使用一个 IME,但可以在屏幕之间切换,以跟踪用户焦点。Android 10 默认所有第一方和第三方 IME 在创建时都会根据新屏幕的尺寸调整布局和大小。
如果屏幕 A 上有一个活动连接,并且屏幕 B 上的输入字段请求获得输入焦点,则会触发以下流程:
- 屏幕 B 上的输入字段发出一个新的输入连接。
- InputMethodManagerService 检查是否应该批准该连接。
- 系统为该 IME 选择一个屏幕。如果屏幕 B 支持且允许显示 IME,则使用屏幕 B。否则,将选择设备的主屏幕。
- 如果所选屏幕并非来自屏幕 A,则重新建立连接。系统会销毁 InputMethodService,然后重新创建它。
实现如下
- DisplayWindowSettings#shouldShowImeLocked()
- DisplayWindowSettings#setShouldShowImeLocked()
Android12上没有:(Android12查看/frameworks/base/services/core/java/com/android/server/wm/DisplayWindowSettingsProvider.java
)
2、属性配置
com.android.internal.R.bool.config_perDisplayFocusEnabled
:系统是否启用每个显示器的焦点。如果系统具有每个显示器的输入法,则此值应为config_perDisplayFocusEnabled=true。
/frameworks/base/core/res/res/values/config.xml
persist.debug.multi_client_ime \ ro.sys.multi_client_ime
属性不需要设置- 配置显示
display_settings.xml
文件,DisplayWindowSettingsProvider#readSettings()
读取文件配置
private static final String DATA_DISPLAY_SETTINGS_FILE_PATH = "system/display_settings.xml";
private static final String VENDOR_DISPLAY_SETTINGS_FILE_PATH = "etc/display_settings.xml";
3、屏幕之间切换 IME 窗口
-
在 IMMS 端,当通过
ViewRootImpl#handleWindowFocusChanged -> InputMethodManager#onPostWindowFocus -> IMMS#startInputOrWindowGainedFocus
收到来自外部屏幕的应用客户端焦点请求时,它会先取消绑定当前的输入法服务,然后再重新绑定该服务,以在onServiceConnected()
中重新附加针对该外部屏幕的新 IME 窗口令牌。
-
在 IMS 端,收到 IMS#attachToken 后,将触发以下流程:
- 调用 ContextImpl#updateDisplay,以在 InputMethodService#attachToken() 中更新服务上下文的屏幕。这会调用 ViewGroup#addView() 来调整键盘布局并适应检查当前上下文的目标屏幕。
- 调用 DisplayContent#setInputMethodWindowLocked() 之后,该实现使用 WindowProcessController 将进程级屏幕配置更改发送给 IME 进程,以替换资源和屏幕指标。
- 调用 onConfigurationChanged() 和 ViewGroup#addView() 之后,InputMethodService 客户端将获得合适的配置(其中包含正确的屏幕指标)来重新初始化输入视图。