Android默认输入法的配置和两个关键词相关,都保存在SettingsProvider或者settings_secure.xml里面。一个是enabled_input_methods,表示配置的系统允许使用的输入法的id字符串,中间以冒号分隔,比如com.android.inputmethod.latin/.LatinIME:com.xxxx.inputmethod.remote/.RemoteIME,另外一个是default_input_method,表示配置的系统默认使用的输入法。
/**
* List of input methods that are currently enabled. This is a string
* containing the IDs of all enabled input methods, each ID separated
* by ':'.
*/
public static final String ENABLED_INPUT_METHODS = "enabled_input_methods";
/**
* Setting to record the input method used by default, holding the ID
* of the desired method.
*/
public static final String DEFAULT_INPUT_METHOD = "default_input_method";
在InputMethodService启动时,一方面会从packagemanager那边获取InputMethodService的应用信息,另一方面也会settings数据库里面读取enabled_input_methods对应的输入法信息。如果后者是空的,则会把前者保存起来并enable,并通过InputMethodUtils.getMostApplicableDefaultIME方法来获取最适合当前系统的输入法,并设置为默认的输入法。如果后者不是空的,则会读取settings数据库的default_input_method信息,如果是有效的输入法就会把它设置为默认的输入法,如果不是有效的是空的则还是会通过getMostApplicableDefaultIME方法来获取最适合当前系统的输入法。
逻辑理清楚了,那么通过settings配置设置系统默认的输入法也就明确了,只要两步。
1.在SettingsProvider下defaults.xml添加enabled_input_methods和default_input_method的配置项。
<string name="def_input_method" translatable="false">com.xxxx.inputmethod.remote/.RemoteIME</string>
<string name="enabled_input_methods" translatable="false">com.android.inputmethod.latin/.LatinIME:com.xxxx.inputmethod.remote/.RemoteIME</string>
2.在SettingsProvider内的DatabaseHelper类里面loadSecureSettings里面添加上面两个值的读取。
loadStringSetting(stmt, Settings.Secure.DEFAULT_INPUT_METHOD, R.string.def_input_method);
loadStringSetting(stmt, Settings.Secure.ENABLED_INPUT_METHODS, R.string.enabled_input_methods);
顺便说下,虽然SettingsProvider从N版本开始就重构了,数据库里面的值都保存在data/users/userid/xxx_settings.xml里面,但是SettingsProvider在初始化时仍然会从之前创建的数据库里面把这些数据迁移出来,所以在defaults里面或者overlay对应的defaults文件下面配置的键值对都是始终有效的。