用户选项和设置用户界面

简介: 用户选项和设置用户界面

许多应用程序都会提供一个单独的界面,允许用户更改应用程序的选项和设置。Android提供了一套现成的Activity和Fragment类,使得创建这类用户界面非常容易:preferenceActivity和preferenceFragment。


首先在XML资源目录下创建XML文件,并在开头使用PreferenceScreen语法。该XML的结构很简单,它指定了所有允许用户更改的偏好,以及它们是如何相互作用的。开发者可以提供用于输入文本字符串的简单文本字段,复选框以及选项列表。对于每个选项,可以指定标题和说明,还可以把偏好分成不同的类别。开发者不需要自己去保存修改的值,因为PreferenceFragment会保存用户的修改。PreferenceFragment使用的SharedPreferences实例和从PreferenceManaget.getDefaultSharedPreferences()获取的是同一个。


下面的PreferenceScreen.xml代码显示了两个用户可配置的选项。

<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
    <PreferenceCategory android:title="@string/network_preferences_title">
        <CheckBoxPreference
                android:title="@string/network_wifi_only_title"
                android:summaryOn="@string/network_wifi_only_summary_on"
                android:summaryOff="@string/network_wifi_only_summary_off"
                android:key="network.wifiOnly"
                android:defaultValue="false"/>
        <ListPreference
                android:title="@string/animal_retry_count_title"
                android:summary="@string/animal_retry_count_summary"
                android:key="network.retryCount"
                android:defaultValue="3"
                android:entryValues="@array/animal_retry_count_option_values"
                android:entries="@array/animal_retry_count_options" />
    </PreferenceCategory>
</PreferenceScreen>


接下来要实现PreferenceActivity,并且添加preferenceFragment作为其UI,然后调用PreferenceFragment.addPreferencesFromResource()来指定用于显示设置用户界面的XML。Android框架会生成符合应用程序样式的主题的用户界面。


下面的代码指定了要使用的XML资源文件。本例还调用了PreferenceManager.setDefaultValues方法,这样偏好文件会使用XML文件指定的默认值。

public class SettingsFragment extends PreferenceFragment implements SharedPreferences.OnSharedPreferenceChangeListener{
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            PreferenceManager.setDefaultValues(getActivity(), R.xml.preference_screen, false);
            addPreferencesFromResource(R.xml.preference_screen);
            getPreferenceScreen().getSharedPreferences() .registerOnSharedPreferenceChangeListener(this);
        }
    @Override
    public void onDestroy() {
        super.onDestroy();
        getPreferenceScreen().getSharedPreferences() .unregisterOnSharedPreferenceChangeListener(this);
    }
    @Override
    public void onSharedPreferenceChanged(SharedPreferences sharedPreferences, String key) {
        Log.i("MainActivity", "liyuanjinglyj");
        Log.i("MainActivity",key);
        boolean flag=false;
        if("network.wifiOnly".equals(key)){
            flag=sharedPreferences.getBoolean(key,false);
        }
        if(flag){
            Toast.makeText(getActivity(), "打开了WIFI", Toast.LENGTH_LONG).show();
        }
    }
}

上面代码不仅实现了上述功能而且实现了SharedPreferences.OnSharedPreferenceChangeListener接口,当偏好设置发生改变时,就可以根据改变的Key处理相应的事件,当然光实现这个接口是不能监听偏好设置的变化的,还要注册后方能监听。

getPreferenceScreen().getSharedPreferences() .registerOnSharedPreferenceChangeListener(this);


当然有注册就必须注销。


启动这类Activity最常用的方式是使用Intent,而且要指定ComponentName而不是使用action字符串。还要确保在清单文件中把android:exported标志设为false,使其只能在应用程序中启动该Activity。


                                                   

相关文章
|
5月前
|
搜索推荐 C#
一个适用于定制个性化界面的WPF UI组件库
一个适用于定制个性化界面的WPF UI组件库
LabVIEW修改应用程序窗口外观
LabVIEW修改应用程序窗口外观
|
XML Java API
高级UI系列(三): 自定义UI动画篇
高级UI系列(三): 自定义UI动画篇
99 0
高级UI系列(三): 自定义UI动画篇
|
JavaScript 前端开发 API
了解如何构建 Metro 样式的应用程序
Windows 提供两组用于构建 Metro 风格应用的 API:Windows 运行时和 Windows JavaScript 库。但是Windows JavaScript 库和大众的javascript不兼容,也就是说不是一回事 参考url http://msdn.
647 0
|
Web App开发 JavaScript 前端开发
|
存储 前端开发 测试技术
[译] 如何理智地构建复杂用户界面
本文讲的是[译] 如何理智地构建复杂用户界面,下面的这些技巧是我希望有人在当我开始这样一个雄心勃勃的项目之前能告诉我的。这将为我节省大量时间和精力。
977 0