Android 12系统源码_Settings(一)认识Preference

打印 上一主题 下一主题

主题 513|帖子 513|积分 1539

媒介

想刀一家公司的心事藏不住的,原本只了解一下Android系统应用Settings的配置开关列表中某个开关开启或关闭的时间,系统做了哪些响应操纵,结果搞了半天发现完全看不懂。写界面就写界面吧,但是Settings模块完全没有利用Android常规UI那种方案,而是结合Preference重新搞了一套UI结构方案,这样我们要想研究或定制Settings模块的某些功能,就必须先对Preference这套UI结构方案有个简朴的认识。
一、Preference

1.1、简介

在 Android 开发中,Preference 是用来构建用户界面的组件,它提供了一种简朴而有用的方式来管理应用的设置和用户偏好。Preference 类及其相关类主要用于创建和管理用户界面中的设置选项,例如复选框、单选按钮、列表项等,允许用户调整应用的行为和表面。
1.2、主要的 Preference 类型



  • Preference:
Preference 是所有偏好设置类的基类,通常不直接利用,而是通过其子类进行扩展和利用。


  • CheckBoxPreference:
CheckBoxPreference 是一个复选框偏好设置,允许用户通过勾选或取消勾选来控制一个布尔值设置项。


  • ListPreference:
ListPreference 允许用户从一个固定的列表中选择一个选项,例如选择语言、主题等。


  • EditTextPreference:
EditTextPreference 允许用户输入文本,通常用于需要用户输入自界说内容的设置项。


  • SwitchPreference:
SwitchPreference 是一个开关偏好设置,与 CheckBoxPreference 类似,但利用了开关样式而不是复选框。


  • PreferenceCategory:
PreferenceCategory 可以用来将多个相关联的偏好设置项构造到一个类别中,以改善界面的结构和可读性。
二、Preference简朴实例

Android系统Settings模块通常大量利用了Preference来构建UI视图,如果直接去看根本都会一脸蒙蔽,这里我们利用Preference编写一个最简朴的案例,只要看懂了这个案例,再去分析Settings模块利用Preference所构建的UI视图,根本就柳暗花明了。
2.1、创建 Preference XML 文件

在 res/xml 目录下创建一个 XML 文件,界说应用的偏好设置结构和各个设置项的属性。
   res/xml/root_preferences.xml
  1. <PreferenceScreen xmlns:app="http://schemas.android.com/apk/res-auto">
  2.     <PreferenceCategory app:title="@string/messages_header">
  3.         <EditTextPreference
  4.             app:key="signature"
  5.             app:title="@string/signature_title"
  6.             app:useSimpleSummaryProvider="true" />
  7.         <ListPreference
  8.             app:defaultValue="reply"
  9.             app:entries="@array/reply_entries"
  10.             app:entryValues="@array/reply_values"
  11.             app:key="reply"
  12.             app:title="@string/reply_title"
  13.             app:useSimpleSummaryProvider="true" />
  14.     </PreferenceCategory>
  15.     <PreferenceCategory app:title="@string/sync_header">
  16.         <SwitchPreferenceCompat
  17.             app:key="sync"
  18.             app:title="@string/sync_title" />
  19.         <SwitchPreferenceCompat
  20.             app:dependency="sync"
  21.             app:key="attachment"
  22.             app:summaryOff="@string/attachment_summary_off"
  23.             app:summaryOn="@string/attachment_summary_on"
  24.             app:title="@string/attachment_title" />
  25.     </PreferenceCategory>
  26.    
  27. </PreferenceScreen>
复制代码
  res/values/arrays.xml
  1. <resources>
  2.     <!-- Reply Preference -->
  3.     <string-array name="reply_entries">
  4.         <item>Reply</item>
  5.         <item>Reply to all</item>
  6.     </string-array>
  7.     <string-array name="reply_values">
  8.         <item>reply_value</item>
  9.         <item>reply_all_value</item>
  10.     </string-array>
  11. </resources>
复制代码
  res/values/strings.xml
  1. <resources>
  2.     <string name="app_name">SettingsDemoApplication</string>
  3.     <string name="title_activity_settings">SettingsActivity</string>
  4.     <!-- Preference Titles -->
  5.     <string name="messages_header">Messages</string>
  6.     <string name="sync_header">Sync</string>
  7.     <!-- Messages Preferences -->
  8.     <string name="signature_title">Your signature</string>
  9.     <string name="reply_title">Default reply action</string>
  10.     <!-- Sync Preferences -->
  11.     <string name="sync_title">Sync email periodically</string>
  12.     <string name="attachment_title">Download incoming attachments</string>
  13.     <string name="attachment_summary_on">Automatically download attachments for incoming emails
  14.     </string>
  15.     <string name="attachment_summary_off">Only download attachments when manually requested</string>
  16. </resources>
复制代码
2.2、创建PreferenceFragmentCompat类

创建一个 Java 类继承自 PreferenceFragmentCompat,并在其中加载上述 XML 文件。
  1. public class SettingsFragment extends PreferenceFragmentCompat {
  2.     @Override
  3.     public void onCreatePreferences(Bundle savedInstanceState, String rootKey) {
  4.         setPreferencesFromResource(R.xml.root_preferences, rootKey);
  5.     }
  6.    
  7. }
复制代码
2.3、在 Activity 中显示PreferenceFragmentCompat

新建一个Activity,并在该Activity中将 SettingsFragment 添加到结构中。
   com/example/settings/SettingsActivity.java
  1. public class SettingsActivity extends AppCompatActivity {
  2.     @Override
  3.     protected void onCreate(Bundle savedInstanceState) {
  4.         super.onCreate(savedInstanceState);
  5.         setContentView(R.layout.activity_settings);
  6.         //加载SettingsFragment
  7.         getSupportFragmentManager()
  8.                 .beginTransaction()
  9.                 .replace(R.id.settings_container, new SettingsFragment())
  10.                 .commit();
  11.     }
  12. }
复制代码
  res/layout/settings_activity.xml
  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2.     android:layout_width="match_parent"
  3.     android:layout_height="match_parent">
  4.     <FrameLayout
  5.         android:id="@+id/settings_container"
  6.         android:layout_width="match_parent"
  7.         android:layout_height="match_parent" />
  8.         
  9. </LinearLayout>
复制代码
2.4、UI效果图视图

利用Preference只要经过上面的简朴配置就能实现下面的效果图了。

2.5、监听Preference控件的状态厘革

  1. public class SettingsFragment extends PreferenceFragmentCompat {
  2.     public static final String TAG = "SettingsFragment";
  3.     @Override
  4.     public void onCreatePreferences(Bundle savedInstanceState, String rootKey) {
  5.         setPreferencesFromResource(R.xml.root_preferences, rootKey);
  6.         //监听Preference的状态
  7.         EditTextPreference editTextPreference = findPreference("signature");
  8.         editTextPreference.setOnPreferenceChangeListener(new Preference.OnPreferenceChangeListener() {
  9.             @Override
  10.             public boolean onPreferenceChange(@NonNull Preference preference, Object newValue) {
  11.                 //回调日志打印
  12.                 Log.i(TAG, "onPreferenceChange preference = " + preference + ", newValue = " + newValue);
  13.                 return false;
  14.             }
  15.         });
  16.         ListPreference listPreference = findPreference("reply");
  17.         listPreference.setOnPreferenceChangeListener(new Preference.OnPreferenceChangeListener() {
  18.             @Override
  19.             public boolean onPreferenceChange(@NonNull Preference preference, Object newValue) {
  20.                 //回调日志打印
  21.                 Log.i(TAG, "onPreferenceChange preference = " + preference + ", newValue = " + newValue);
  22.                 return false;
  23.             }
  24.         });
  25.         SwitchPreferenceCompat switchPreferenceSync = findPreference("sync");
  26.         switchPreferenceSync.setOnPreferenceChangeListener(new Preference.OnPreferenceChangeListener() {
  27.             @Override
  28.             public boolean onPreferenceChange(@NonNull Preference preference, Object newValue) {
  29.                 //回调日志打印
  30.                 Log.i(TAG, "onPreferenceChange preference = " + preference + ", newValue = " + newValue);
  31.                 return false;
  32.             }
  33.         });
  34.         SwitchPreferenceCompat switchPreferenceAttachment = findPreference("attachment");
  35.         switchPreferenceAttachment.setOnPreferenceChangeListener(new Preference.OnPreferenceChangeListener() {
  36.             @Override
  37.             public boolean onPreferenceChange(@NonNull Preference preference, Object newValue) {
  38.                 //回调日志打印
  39.                 Log.i(TAG, "onPreferenceChange preference = " + preference + ", newValue = " + newValue);
  40.                 return false;
  41.             }
  42.         });
  43.     }
  44. }
复制代码
这样在我们对各个控件进行操纵的时间,就能收到对应控件的状态厘革了。
  1. 2024-08-03 01:08:39.808  3249-3249  SettingsFragment        com.example.settings                 I  onPreferenceChange preference = Your signature 未设置, newValue = 123456
  2. 2024-08-03 01:08:42.778  3249-3249  SettingsFragment        com.example.settings                 I  onPreferenceChange preference = Default reply action 未设置, newValue = reply_value
  3. 2024-08-03 01:08:49.891  3249-3249  SettingsFragment        com.example.settings                 I  onPreferenceChange preference = Sync email periodically, newValue = true
复制代码
三、Preference小结

简朴枚举下常见的Preference组件和标签。
4.1 常见组件

  1. (1) PreferenceScreen:根节点,代表一个偏好设置的屏幕。它是其他Preference组件的容器。
  2. (2) EditTextPreference:允许用户输入文本值的偏好设置。
  3. (3) CheckBoxPreference(在新版中被`SwitchPreferenceCompat`替代):提供一个开关按钮供用户开启或关闭某个设置。
  4. (4) SwitchPreferenceCompat:与CheckBoxPreference功能类似,提供一个滑动开关供用户切换设置。
  5. (5) ListPreference:显示一个选择列表,用户可以从中选择一个选项作为设置。
  6. (6) MultiSelectListPreference:允许用户从列表中选择多个选项。
  7. (7) PreferenceCategory:用于将偏好设置分组的类别标题。
  8. (8) PreferenceFragmentCompat:一个Fragment,用于在其内部显示一个偏好设置的屏幕。
复制代码
4.2 常见标签

  1. (1) key: 这个属性定义了偏好设置的唯一标识符。通过这个键,你可以在代码中检索或更新偏好设置的值。
  2. (2) title: 设置项的标题,这是用户在设置界面看到的文本。
  3. (3) summary: 设置项的摘要或描述,显示在标题下方,用于提供更多关于设置项的信息。
  4. (4) defaultValue: 定义设置项的默认值。当应用第一次运行,且用户尚未更改过该设置时,将使用此默认值。
  5. (5) widgetLayout: 允许开发者为偏好设置项指定一个自定义的布局。
  6. (6) dependency: 这个属性使当前偏好设置依赖于另一个偏好设置的值。例如,如果一个偏好设置项被禁用,直到另一个特定的偏好设置被激活/选中。
  7. (7) enabled: 控制偏好设置是否可用。默认为 true,即默认情况下是启用状态。
  8. (8) selectable: 控制偏好设置项是否可以被选中。默认为 true。
  9. (9) icon: 给设置项指定一个图标,以增加可识别性。
  10. (10) fragment: 指定当偏好设置被选中时,应该启动的Fragment的全名。这对于构建多层次的设置界面很有用。
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

何小豆儿在此

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表