`

android Preference以及监听事件学习

 
阅读更多
基础知识
在Android系统源码中,绝大多数应用程序的UI布局采用了Preference的布局结构,而不是我们平时在模拟器中构建应用程序时使用的View布局结构,例如,Setting模块中布局。当然,凡事都有例外,FMRadio应用程序中则使用了View布局结构(可能是该应用程序是marvel公司提供的,如果由google公司做,那可说不准)。归根到底,Preference布局结构和View的布局结构本质上还是大同小异,Preference的优点在于布局界面的可控性和高效率以及可存储值的简洁性(每个Preference存储在相对应下的SharedPreference文件夹下)。 下面,我们对比Preference和View下得各个子控件,对他们的家庭元素在宏观上有个更好的把握性。

Preference相关的两个重要监听接口

Preference.OnPreferenceChangeListener   该监听器的一个重要方法如下:
boolean onPreferenceChange(Preference preference,Object objValue)
             说明:  当Preference的元素值发送改变时,触发该事件。
             返回值:true  代表将新值写入sharedPreference文件中。
                     false 则不将新值写入sharedPreference文件

Preference.OnPreferenceClickListener  该监听器的一个重要方法如下:
         public boolean onPreferenceClick(Preference preference)
             说明:当点击控件时触发发生,可以做相应操作。
                            
那么当一个Preference控件实现这两个接口时,当被点击或者值发生改变时,触发方法是如何执行的呢?事实上,
它的触发规则如下:
      1 先调用onPreferenceClick()方法,如果该方法返回true,则不再调用onPreferenceTreeClick方法 ;如果onPreferenceClick方法返回false,则继续调用onPreferenceTreeClick方法。
      2 onPreferenceChange的方法独立与其他两种方法的运行。也就是说,它总是会运行。


Preference种类



具体表现



Preference的跳转

方法一:静态配置
<Preference android:key="wifi_setting" android:title="Wi-Fi设置"
		android:summary="设置和管理无线接入点" android:dependency="apply_wifi">
		<!-- 点击时 自定义一个默认跳转Intent  action指定隐式Intent -->
		<!-- action指定隐式Intent ; targetPackage和targetClass指定显示Intent-->
<intent android:action="com.feixun.action.seemAction" 
android:targetPackage="com.feixun.qin" android:targetClass="com.feixun.qin.MainActivity" />
</Preference>


方法二:可以在onPreferenceTreeClick()创建新的intent显示的进行跳转。

 //点击事件触发  
 public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen,  
            Preference preference) {  
        Log.i(TAG, "onPreferenceTreeClick----->"+preference.getKey());  
        // 对控件进行操作  
        operatePreference(preference);  
        if (preference.getKey().equals("wifi_setting")) {  
            // 创建一个新的Intent,  
            // 函数如果返回true, 则跳转至该自定义的新的Intent ;  
            // 函数如果返回false,则跳转至xml文件中配置的Intent ;  
            Intent i = new Intent(HelloPreference.this, OtherActivity.class);  //OtherActivity只是一个简单的Activity  
            i.putExtra("type", "wifi");  
            startActivity(i);  
            return true;  
        }  
        return false;  
    }  


布局文件
<?xml version="1.0" encoding="utf-8"?>  
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">  
  
    <PreferenceCategory android:title="我的位置"  
        android:key="set_local" />  
    <CheckBoxPreference android:key="apply_wireless"  
        android:title="使用无线网络" android:summary="使用无线网络在应用程序(例如Google地图)中查看位置"  
        android:defaultValue="true">  
    </CheckBoxPreference>  
    <CheckBoxPreference android:key="apply_gps"  
        android:title="使用GPS" android:summary="定位到街道级别(需要消耗更多的电量以及天气允许)">  
    </CheckBoxPreference>  
  
    <PreferenceCategory android:title="无线和网络设置"></PreferenceCategory>  
  
    <CheckBoxPreference android:key="apply_fly"   
        android:title="飞行模式" android:summary="禁用所有无线连接" >  
    </CheckBoxPreference>  
  
    <CheckBoxPreference android:key="apply_internet"  
        android:title="Internet共享" android:summary="禁用通过USB共享Internet连接">  
    </CheckBoxPreference>  
  
    <CheckBoxPreference android:key="apply_wifi"  
        android:title="Wi-Fi" android:summary="打开Wi-Fi">  
    </CheckBoxPreference>  
    <Preference android:key="wifi_setting" android:title="Wi-Fi设置"  
        android:summary="设置和管理无线接入点" android:dependency="apply_wifi">  
        <!-- 点击时 自定义一个默认跳转Intent  action指定隐式Intent -->  
        <!-- action指定隐式Intent ; targetPackage和targetClass指定显示Intent-->  
        <intent android:action="com.feixun.action.seemAction"   
            android:targetPackage="com.feixun.qin" android:targetClass="com.feixun.qin.MainActivity" />  
    </Preference>  
    <CheckBoxPreference android:key="apply_bluetooth"  
        android:title="蓝牙" android:summary="启用蓝牙">  
    </CheckBoxPreference>  
    <Preference android:key="bluetooth_setting" android:title="蓝牙设置"  
        android:summary="管理连接、设备设备名称和可检测性" android:dependency="apply_bluetooth">  
    </Preference>  
    <EditTextPreference android:key="number_edit"  
        android:title="输入电话号码" android:defaultValue="123">  
    </EditTextPreference>  
    <ListPreference android:key="depart_value"  
        android:title="部门设置" android:dialogTitle="选择部门" android:entries="@array/department"  
        android:entryValues="@array/department_value">  
    </ListPreference>  
    <RingtonePreference android:key="ring_key"  
        android:title="铃声" android:ringtoneType="all" android:showDefault="true"  
        android:showSilent="true">  
    </RingtonePreference>  
</PreferenceScreen> 


新建一个HelloActivity继承PreferenceActivity
package com.feixun.qin;

import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.preference.CheckBoxPreference;
import android.preference.EditTextPreference;
import android.preference.ListPreference;
import android.preference.Preference;
import android.preference.PreferenceActivity;
import android.preference.PreferenceManager;
import android.preference.PreferenceScreen;
import android.preference.Preference.OnPreferenceClickListener;
import android.util.Log;

public class HelloPreference extends PreferenceActivity implements
		Preference.OnPreferenceClickListener,
		Preference.OnPreferenceChangeListener {
	private static String TAG = "HelloPreference";          
	private CheckBoxPreference mapply_wifiPreference;       //打开wifi
	private CheckBoxPreference mapply_internetPreference;   //Internet共享
	private ListPreference depart_valuePreference;          //部门设置
	private EditTextPreference number_editPreference;       //输入电话号码
	private Preference mwifi_settingPreference;             //wifi设置
	private String oldDeptId; // 旧部门的名称

	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		addPreferencesFromResource(R.xml.mypreference);
		//根据key值找到控件
		mapply_wifiPreference = (CheckBoxPreference) findPreference("apply_wifi");
		mapply_internetPreference = (CheckBoxPreference) findPreference("apply_internet");
		depart_valuePreference = (ListPreference) findPreference("depart_value");
		number_editPreference = (EditTextPreference) findPreference("number_edit");
		mwifi_settingPreference = (Preference) findPreference("wifi_setting");

		// 设置监听器
		mapply_internetPreference.setOnPreferenceClickListener(this);
		mapply_internetPreference.setOnPreferenceChangeListener(this);
		depart_valuePreference.setOnPreferenceClickListener(this);
		depart_valuePreference.setOnPreferenceChangeListener(this);
		number_editPreference.setOnPreferenceClickListener(this);
		number_editPreference.setOnPreferenceChangeListener(this);
		mwifi_settingPreference.setOnPreferenceClickListener(this);

		// 得到我们的存储Preferences值的对象,然后对其进行相应操作
		SharedPreferences shp = PreferenceManager.getDefaultSharedPreferences(this);
		boolean apply_wifiChecked = shp.getBoolean("apply_wifi", false);
	}

	// 对控件进行的一些操作
	private void operatePreference(Preference preference) {
		if (preference == mapply_wifiPreference){                  //点击了    "打开wifi"
			Log.i(TAG, " Wifi CB, and isCheckd ="+ mapply_wifiPreference.isChecked());
		}else if (preference.getKey().equals("apply_internet")){   //点击了"Internet共享"
			Log.i(TAG, " internet CB, and isCheckd = "+mapply_internetPreference.isChecked());
		}else if (preference == depart_valuePreference){           //点击了 "部门设置"
			Log.i(TAG, " department CB,and selectValue = "+ depart_valuePreference.getValue() + ", Text="+ depart_valuePreference.getEntry());
		}else if (preference.getKey().equals("wifi_setting")) {    //点击了"wifi设置"
			mwifi_settingPreference.setTitle("its turn me.");
		}else if (preference == number_editPreference)             //点击了"输入电话号码"
			Log.i(TAG, "Old Value="+ number_editPreference.getText() + ", New Value="+ number_editPreference.getEditText().toString());
	}
	// 点击事件触发
	@Override
	public boolean onPreferenceClick(Preference preference) {
		// TODO Auto-generated method stub
		Log.i(TAG, "onPreferenceClick----->"+String.valueOf(preference.getKey()));
		// 对控件进行操作
		operatePreference(preference);
		return false;
	}
        //点击事件触发
	public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen,
			Preference preference) {
		Log.i(TAG, "onPreferenceTreeClick----->"+preference.getKey());
		// 对控件进行操作
		operatePreference(preference);
		if (preference.getKey().equals("wifi_setting")) {
			// 创建一个新的Intent,
			// 函数如果返回true, 则跳转至该自定义的新的Intent ;
			// 函数如果返回false,则跳转至xml文件中配置的Intent ;
			Intent i = new Intent(HelloPreference.this, OtherActivity.class);  //OtherActivity只是一个简单的Activity
			i.putExtra("type", "wifi");
			startActivity(i);
			return true;
		}
		return false;
	}

	// 当Preference的值发生改变时触发该事件,true则以新值更新控件的状态,false则do noting
	public boolean onPreferenceChange(Preference preference, Object objValue) {
		Log.i(TAG, "onPreferenceChange----->"+String.valueOf(preference.getKey()));
		if (preference == mapply_wifiPreference){
			Log.i(TAG, "Wifi CB, and isCheckd = " + String.valueOf(objValue));
		}else if (preference.getKey().equals("apply_internet")) {
			Log.i(TAG, "internet CB, and isCheckd = "+ String.valueOf(objValue));
			return false;  //不保存该新值
		}else if (preference == depart_valuePreference){
			Log.i(TAG, "  Old Value"+ depart_valuePreference.getValue()+" NewDeptName"+objValue);
		}else if (preference.getKey().equals("wifi_setting")) {
			Log.i(TAG, "change" + String.valueOf(objValue));
			mwifi_settingPreference.setTitle("its turn me.");  //重新设置title
		} else if (preference == number_editPreference) {
			Log.i(TAG, "Old Value = " + String.valueOf(objValue));
			return false; // 不保存更新值
		}
		return true;  //保存更新后的值
	}
}



在应用程序中,我们可以通过代码的方式来访问该sharedPreference文件,继而可以对其进行读取甚至任何操作。

String STORE_NAME = "Settings";  
SharedPreferences settings = getSharedPreferences(STORE_NAME, MODE_PRIVATE);  
SharedPreferences.Editor editor = settings.edit();  
editor.putInt("sourceType", 0);  
editor.commit();    


参考:http://blog.csdn.net/qinjuning/article/details/6710003
参考:http://www.cnblogs.com/wangjianhui/archive/2011/06/16/2082270.html



  • 大小: 2.4 KB
  • 大小: 65.3 KB
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    Android中Preference的使用以及监听事件分析

    在Android开发中,Preference是构建用户界面的一种...理解并熟练运用Preference的使用、监听事件以及数据持久化,能够极大地提高开发效率。通过自定义Preference,开发者可以进一步扩展其功能,满足各种复杂的需求。

    Android中preference的使用实例代码

    为了响应用户在设置界面的操作,我们需要监听Preference的改变事件。这可以通过实现`OnPreferenceChangeListener`接口来实现: ```java public class SettingsActivity extends AppCompatActivity implements ...

    Android Preference解读

    然后,我们可以通过监听Preference的改变事件来执行相应的操作: ```java public class SettingsFragment extends PreferenceFragmentCompat { @Override public void onCreatePreferences(Bundle ...

    Android Preference Framework源码

    6. **事件监听**:Preference可以添加OnPreferenceChangeListener和OnPreferenceClickListener监听器,以便在用户更改设置或点击设置项时执行相应的逻辑。 7. **自定义Preference**:如果系统提供的Preference子类...

    android Preference的Demo

    源代码将包含具体的布局设计、Fragment的实现以及SharedPreferences的读写示例,帮助开发者更好地理解如何在实际项目中利用`android Preference`组件来创建用户友好的设置界面。这个Demo不仅适合初学者学习,也是...

    安卓Android源码——Preference_Demo.rar

    - 监听事件:可以通过覆写`onPreferenceChange(Preference preference, Object newValue)`或`onPreferenceClick(Preference preference)`等回调方法来处理用户操作。 3. **自定义Preference** - 当系统提供的...

    Android学习笔记 Preference的使用

    这篇名为“Android学习笔记 - Preference的使用”的博客文章可能涵盖了以下关键知识点: 1. **Preference基础知识**: - `Preference` 类是Android中的一个抽象类,它是所有设置项的基础。`CheckBoxPreference`、`...

    android Preference Demo

    《Android中的Preference Demo详解》 在Android开发中,Preference是一个重要的组件,用于创建用户界面,让用户可以方便地进行设置和偏好选择。Preference Demo是展示如何使用Preference进行UI设计的一个实例,它...

    Android Preference

    通过这个"Android_Preferences_example",开发者可以学习到如何创建用户友好的设置界面,以及如何处理用户对这些设置的更改。理解并熟练运用Preference和PreferenceActivity是构建任何Android应用不可或缺的一部分,...

    Android应用源码之Preference_Demo-IT计算机-毕业设计.zip

    - 可以通过`findPreference(CharSequence key)`方法获取到具体的`Preference`对象,然后监听其点击事件,实现相应的逻辑。 4. **数据存储**: - 用户的设置通常保存在共享首选项(SharedPreferences)中。`...

    Android程序 preference应用

    当用户在Preference界面上进行操作时,例如点击开关或输入文本,我们可以监听这些事件并更新SharedPreferences。以下是如何监听`CheckBoxPreference`的改变: ```java @Override public void ...

    Pro Android学习:Preference(首选项)小例子

    在这个“Pro Android学习:Preference(首选项)小例子”中,我们将深入探讨Preference的使用以及它在实际应用中的实现。 首先,Preference的使用始于XML布局文件。在Android资源目录下的res/xml中,开发者会创建一...

    Android PreferenceActivity 使用练习

    然后,我们可以监听这些偏好项的改变事件,以便在用户做出选择时执行相应的操作。这通常通过`Preference.OnPreferenceChangeListener`接口实现: ```java checkBoxPref.setOnPreferenceChangeListener(new ...

    AndroidPreferenceDemo

    这个示例项目对于初学者来说是一个很好的学习资源,它演示了如何在Android应用中创建一个自定义的设置页面,以及如何保存和读取用户设置。通过对这个项目的深入理解和实践,开发者可以掌握如何使用`Preference`和`...

    Preference

    在Android开发中,"Preference" 是一个非常重要的概念,它涉及到用户界面(UI)的设计以及用户设置的管理。"Preference" 类通常用于构建类似于系统设置的界面,让用户能够轻松地更改应用的偏好设置。本教程将深入...

    android各种Preference的使用

    在Android开发中,Preference是用来构建用户界面中设置页面的关键组件,它允许用户通过简单的交互来改变应用的配置或设置。本篇文章将详细讲解如何在Android中使用各种类型的Preference,特别是ListPreference。 ...

    android 探索首选项框架xxxPreference

    在“Preference_Demo”这个压缩包中,很可能包含了作者创建的示例项目,包含XML布局文件、自定义Preference的Java代码以及相关的测试用例。通过研究这个示例,开发者可以直观地学习如何在实际项目中使用和扩展首选项...

    Android应用源码之Preference_Demo.zip

    总的来说,Preference_Demo项目是一个学习Android设置界面开发的绝佳资源,它涵盖了从基础到进阶的各种用法,包括但不限于添加、配置、监听和自定义Preference。通过研究这个示例代码,开发者可以更深入地理解和掌握...

    Android白天夜晚模式切换实现

    总之,实现Android应用中的白天夜晚模式切换,主要涉及BroadcastReceiver监听系统时间变化、AppCompatDelegate切换主题模式以及设置界面的用户交互。通过以上步骤,你就可以为自己的应用添加这一实用功能了。

    应用源码之Preference_Demo.zip

    对于毕业设计或者代码学习者来说,Preference_Demo是一个很好的实践项目,它能帮助理解Android应用的设置界面是如何构建的,以及如何处理用户的偏好设置。通过这个Demo,你可以学习到: 1. 如何在XML中定义...

Global site tag (gtag.js) - Google Analytics