展锐添加了一些实用功能,例如它可以配置是否默认开启抽屉风格:
一、默认配置
配置如下:
//设置双层,即抽屉风格。单层: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
,搜索一下它在哪个文件中就可以了