什么是首选项(Preferences)?
首选项是指用户在系统中可以自定义的一些设置,通常用于调整应用程序的行为、外观和功能,在Android应用中,首选项通常以对话框的形式展示给用户,用户可以通过点击对话框中的按钮来修改设置,首选项的保存和读取是通过SharedPreferences类来实现的。
如何创建首选项界面?
1、在res/xml目录下创建一个名为preferences.xml的文件,用于定义首选项界面的布局。
<?xml version="1.0" encoding="utf-8"?><PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"> <SwitchPreferenceCompat android:key="switch_key" android:title="开关标题" android:summary="开关描述" android:defaultvalue="true" /></PreferenceScreen>
2、在Java代码中创建一个继承自PreferenceActivity的类,并重写onCreate方法。
import android.os.Bundle;import androidx.preference.PreferenceActivity;import androidx.preference.PreferenceFragmentCompat;import com.example.myapplication.R;public class SettingsActivity extends PreferenceActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); addPreferencesFromResource(R.xml.preferences); }}
3、在AndroidManifest.xml文件中注册SettingsActivity。
<activity android:name=".SettingsActivity" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter></activity>
如何保存首选项的修改?
在Android中,首选项的保存和读取是通过SharedPreferences类来实现的,以下是一个简单的示例:
1、在PreferenceFragmentCompat中添加SharedPreferences实例。
import androidx.preference.PreferenceManager;import com.example.myapplication.R;import com.example.myapplication.preferences.MyPreferenceFragment;import java.util.ArrayList;import java.util.List;import java.util.concurrent.atomic.AtomicInteger;public class MyPreferenceFragment extends PreferenceFragmentCompat { private AtomicInteger counter = new AtomicInteger(0); private List<String> keys = new ArrayList<>(); // 存储已添加的首选项键值对的键名列表,避免重复添加相同的键值对时覆盖旧值。 private SharedPreferences sharedPreferences; // SharedPreferences实例。 @Override public void onCreatePreferences(Bundle savedInstanceState, String rootKey) { setPreferencesFromResource(R.xml.preferences, rootKey); // 从XML文件中加载首选项界面布局。 init(); // 初始化SharedPreferences实例。 } private void init() { // 初始化SharedPreferences实例,在此处添加SharedPreferences的相关配置,如文件路径、版本号等,具体请参考官方文档。 https://developer.android.com/guide/topics/data/data-storagepreferrences-files-get-set-and-save-data。 sharedPreferences = PreferenceManager.getDefaultSharedPreferences(requireContext()); // 通过Context获取默认的SharedPreferences实例,若需要指定文件路径等参数,请使用其他构造方法创建SharedPreferences实例,如:SharedPreferences preferences = getSharedPreferences("my_preferences", Context.MODE_PRIVATE);,为了避免重复添加相同的键值对时覆盖旧值,需要将已添加的键名存储在一个列表中,在此示例中,keys列表用于存储已添加的键名,当添加新的首选项时,先判断该键名是否已存在于列表中,若不存在则将其添加到列表中并添加到SharedPreferences中,否则,提示用户该首选项已存在且未被覆盖,更新UI显示新添加的首选项及其当前值,具体实现细节请参考官方文档。 https://developer.android.com/guide/topics/data/data-storagepreferrences-files-get-set-and-save-data。
免责声明:本站内容仅用于学习参考,信息和图片素材来源于互联网,如内容侵权与违规,请联系我们进行删除,我们将在三个工作日内处理。联系邮箱:chuangshanghai#qq.com(把#换成@)