展锐添加了一些实用功能,例如它可以配置是否默认开启抽屉风格:
一、默认配置
配置如下:
//设置双层,即抽屉风格。单层:single 双层:dual
Launcher3/ext/res/values/config.xml
<string name="default_home_screen_style" translatable="false">dual</string>
二、流程解析
分析一下单层和双层是如何切换的,进入应用目录packages/apps/Launcher3
2.1设置流程
主屏幕设置中可切换风格,默认为dual。分析陌生代码,从可见的地方入手,例如它的title名称为:Home screen style
,查找相关字符串的位置如下
./res/values/strings_ext.xml: <string name="home_screen_style_title">Home screen style</string>
根据key名称查找引用的位置:
./res/xml/launcher_preferences_extension.xml: android:title="@string/home_screen_style_title"
34 <ListPreference
35 android:key="pref_home_screen_style"
36 android:title="@string/home_screen_style_title"
37 android:summary="%s"
38 android:entries="@array/home_screen_style_entries"
39 android:entryValues="@array/home_screen_style_values"
40 android:defaultValue="@string/default_home_screen_style" />
看到是一个Preference配置文件,查找引用该preference的位置:
src/com/sprd/ext/LauncherSettingsExtension.java
//该类并不是一个Preference的子类,分析代码知道它只是依赖于一个PreferenceFragment,
//因而可以猜想到它一定是把自己注入了设置界面的SettingsActivity的Preference了
public static final String PREF_HOME_SCREEN_STYLE_KEY = "pref_home_screen_style";
100 /* add for single layer launcher model */
101 Preference slPreference = mFragment.findPreference(PREF_HOME_SCREEN_STYLE_KEY);
102 MultiModeController mmc = mMonitor.getMultiModeController();
103 if (mmc != null && MultiModeController.isSupportDynamicChange()) {
104 slPreference.setOnPreferenceChangeListener(mmc);
105 } else {
106 mFragment.getPreferenceScreen().removePreference(slPreference);
107 }
// src/com/android/launcher3/settings/SettingsActivity.java
//看到了吧,这里就是用户设置界面的入口
227 //Sprd add custom settings
228 mSettingExtension = new LauncherSettingsExtension(this);
229 mSettingExtension.initPreferences(savedInstanceState);
从LauncherSettingsExtension.java可以看到单双层切换是由MultiModeController
来监听的,继续跟踪:
//src/com/sprd/ext/multimode/MultiModeController.java
156 public boolean onPreferenceChange(Preference preference, Object newValue) {
157 if (LauncherSettingsExtension.sIsUserAMonkey) {
158 return false;
159 }
160
161 final String newModel = (String) newValue;
162 if (!getHomeScreenStylePrefValue(mContext).equals(newModel)) {
163 // Value has changed
164 show(preference.getContext(), null, mContext.getString(R.string.home_screen_style_notification),
165 true, false);
166
167 LauncherModel.runOnWorkerThread(() -> {
168
169 // Synchronously write the preference. 记录用户选择
170 MultiModeUtilities.syncSaveNewModel(mContext, newModel);
171
172 LauncherAppMonitor.getInstance(mContext).onLauncherStyleChanged(newModel);
173
174 LogUtils.d("Change Launcher style", "restarting launcher");
175 UtilitiesExt.exitLauncher();
176 });
177 }
178 return false;
179 }
在preference改变的时候是通过MultiModeUtilities.syncSaveNewModel方法记录的值,那么有记录肯定也有读取,查代码:
//读取style值,这里读写很明显使用的是sharedpreference
77 static String getHomeScreenStylePrefValue(Context context) {
78 if (context == null) {
79 return DUAL;
80 }
81 Resources res = context.getResources();
82 return Utilities.getPrefs(context)
83 .getString(LauncherSettingsExtension.PREF_HOME_SCREEN_STYLE_KEY,
84 res.getString(R.string.default_home_screen_style));//默认返回值在这里
85 }
86 //记录style值
87 @SuppressLint("ApplySharedPref")
88 static void syncSaveNewModel(Context context, String newModel) {
89 String key = LauncherSettingsExtension.PREF_HOME_SCREEN_STYLE_KEY;
90 Utilities.getPrefs(context).edit().putString(key, newModel).commit();
91 }
如果要继续查看使用的配置文件名称和key值,只需要继续查找Utilities源码就行了,这里不再缀述。我们要找的默认值已经找到了,它就是R.string.default_home_screen_style
,搜索一下它在哪个文件中就可以了
网友评论