android 界面设计大全

一.基础知识

    我们在使用Android手机时,可能会经常用到其中的设置界面,如下所示:

1 Android系统中的设置界面

    而且对于我们自己开发的一个完整的程序来说,我们也会需要给用户提供一个设置界面使用户可以对程序的一些参数进行设置。因此,我们就来学习下如何实现符合我们需要的一个设置界面,及其背后的数据持久化功能。

二.实例开发

2.1 SharedPreferences

    在具体介绍Android的设置界面的实现之前,我们先来介绍一下预备知识,就是Android数据持久化方法中最简单的一种,即使用Preferences的键值对存储方式。这种方式主要用来存储比较简单的一些数据,而且是标准的BooleanIntFloatLongString等类型。

android.content.SharedPreferences是一个接口,用来获取和修改持久化存储的数据。有三种获取系统中保存的持久化数据的方式:

1. public SharedPreferences getPreferences (int mode)

    通过Activity对象获取,获取的是本Activity私有的Preference,保存在系统中的xml形式的文件的名称为这个Activity的名字,因此一个Activity只能有一个,属于这个Activity

2. public SharedPreferences getSharedPreferences (String name, int mode)

    因为Activity继承了ContextWrapper,因此也是通过Activity对象获取,但是属于整个应用程序,可以有多个,以第一参数的name为文件名保存在系统中。

3. public static SharedPreferences getDefaultSharedPreferences (Context context)

    PreferenceManager的静态函数,保存PreferenceActivity中的设置,属于整个应用程序,但是只有一个,Android会根据包名和PreferenceActivity的布局文件来起一个名字保存。

    通过以上方式取得SharedPreferences后就可以对数据进行读取或者保存了。

    保存方式如下:

[java]  view plain copy
  1. String STORE_NAME = "Settings";  
  2. SharedPreferences settings = getSharedPreferences(STORE_NAME, MODE_PRIVATE);  
  3. SharedPreferences.Editor editor = settings.edit();  
  4. editor.putInt("sourceType"0);  
  5.  editor.commit();  
 

    获得SharedPreferences,如果需要进行保存等修改操作,首先得通过其edit()方法获得SharedPreferences.Editor,然后就可以通过putInt、putString等方法以键值对(key-value)的方式保存数据,或者remove移除某个键(key),及调用clear方法删除所有内容。最后需要调用commit方法是使修改生效。

    读取方式如下:

[java]  view plain copy
  1. SharedPreferences settings = getSharedPreferences(STORE_NAME, MODE_PRIVATE);  
  2.  int source = settings.getInt("sorceType"1);  
 

    读取就更加简单了,只要获得SharedPreferences后,就可以通过getInt、getString等方法获取对应键(key)保存着的数据,如果没有找到key,则返回第二个参数作为默认值。

2.2 PreferenceActivity

    上面介绍SharedPreferences键值对保存的基础知识,接着我们就可以来实现Android系统的设置界面。Android系统中和设置界面相关的包为android.preference,其中有一个继承了ListActivityPreferenceActivity。

下面我们就先实现一个如下图2的最简单的PreferenceActivity设置界面,只有一个CheckBox选择选项,选中时显示“Yes,I love you!”,取消选择时显示“No,I am sorry.”。然后再介绍其具体的实现。

2 PreferenceActivity界面

    首先新建一个工程AndroidPreferenceDemo

    把extends Activity改为extends PreferenceActivity。

    在res目录下新建一个xml文件夹,接着在这个文件夹下新建一个取名为preferences.xmlFile文件,内容如下:

[xhtml]  view plain copy
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <PreferenceScreen   
  3.     xmlns:android="http://schemas.android.com/apk/res/android"   
  4.     android:title="Settings">  
  5.     <CheckBoxPreference   
  6.         android:title="Love me?"   
  7.         android:summaryOn="Yes,I love you!"  
  8.         android:summaryOff="No,I am sorry."  
  9.         android:defaultValue="true">  
  10.     </CheckBoxPreference>  
  11. </PreferenceScreen>  
 

    然后把java文件中的setContentView(R.layout.main);改为

addPreferencesFromResource(R.xml.preferences);

    完成了,最后可以运行试下效果。

 

    Java文件的实现很简单,继承PreferenceActivity后,调用其public void addPreferencesFromResource (int preferencesResId)

方法从一个xml文件中获取preference然后显示为标准的设置界面。

    因此我们只要在xml文件中布局好要显示的设置界面内容就可以了。

    下面我们看下布局文件xml的内容。

    对应的xml中可以使用的标签(Tag)可以分为两类,一类是管理布局的显示,如PreferenceScreen;另一类是具体的设置内容,如CheckBoxPreference。

PreferenceScreen可以显示一个完整的页面,可以嵌套,包含在PreferenceScreen标签里的内容都将以一个完整的页面显示。

    我们学习一个PreferenceScreen的界面,如下图3所示。

图3 PreferenceScreen相关的布局

    当点击左图的选项时,分别会以新的页面显示,如中间和右图所示。

    上面页面对应的xml布局文件如下所示:

[xhtml]  view plain copy
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <PreferenceScreen   
  3.     xmlns:android="http://schemas.android.com/apk/res/android"   
  4.     android:title="Settings">  
  5.     <PreferenceScreen   
  6.         xmlns:android="http://schemas.android.com/apk/res/android"  
  7.         android:title="Emotions"  
  8.         android:summary="settings about emotions">  
  9.         <CheckBoxPreference    
  10.             android:title="Love me?"   
  11.             android:summaryOn="Yes,I love you!"  
  12.             android:summaryOff="No,I am sorry."  
  13.             android:defaultValue="true">  
  14.         </CheckBoxPreference>  
  15.         <CheckBoxPreference   
  16.             android:title="Hate me?"   
  17.             android:summaryOn="Yes,I hate you!"  
  18.             android:summaryOff="No,you are a good person."  
  19.             android:defaultValue="false">  
  20.         </CheckBoxPreference>       
  21.     </PreferenceScreen>  
  22.     <PreferenceScreen   
  23.         xmlns:android="http://schemas.android.com/apk/res/android"  
  24.         android:title="Relations"  
  25.         android:summary="settings about relations">  
  26.         <CheckBoxPreference   
  27.             android:title="Family?"   
  28.             android:summaryOn="Yes,we are family!"  
  29.             android:summaryOff="No,I am sorry."  
  30.             android:defaultValue="true">  
  31.         </CheckBoxPreference>  
  32.         <CheckBoxPreference   
  33.             android:title="Friends?"   
  34.             android:summaryOn="Yes,we are friends!"  
  35.             android:summaryOff="No,I am sorry."  
  36.             android:defaultValue="false">  
  37.         </CheckBoxPreference>       
  38.     </PreferenceScreen>     
  39. </PreferenceScreen>  
 

    和管理布局显示相关的除了PreferenceScreen外,还有一个常用的为PreferenceCategory,我们把上面xml文件中间那两个PreferenceScreen改为PreferenceCategory就可以看到PreferenceCategory的显示效果了,如下图4所示。

PreferenceCategory相关的布局

    可以看到PreferenceCategory是把包含的内容归为同一类,但只是显示在一个页面中。


    管理布局相关的两个标签可以使设置内容显示的更有条理,但是更主要的还是具体设置相关的标签,除了我们已经在使用的用于二选一的CheckBoxPreference外,Android系统提供的还有以对话框显示的DialogPreference,可以输入文本的EditTextPreference,以列表方式显示供选择的ListPreference和设置铃声用的RingtonePreference。

下面我们选择比较常用的ListPreference来介绍下具体使用。

首先在res/values/文件夹下新建一个取名为array.xml的文件,内容为:

[xhtml]  view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <resources>  
  3.     <!-- 系统设置界面需要要到的数组 -->  
  4.     <string-array name="auto_update_frequency_entry">  
  5.         <item>10分钟</item>  
  6.         <item>30分钟</item>  
  7.         <item>1小时</item>  
  8.         <item>12小时</item>  
  9.         <item>24小时</item>     
  10.     </string-array>  
  11.     <string-array name="auto_update_frequency_value">  
  12.         <item>10</item>  
  13.         <item>30</item>  
  14.         <item>60</item>  
  15.         <item>720</item>  
  16.         <item>1440</item>     
  17.     </string-array>  
  18.     </resources>  
 

    然后在res/values/strings.xml文件中添加

[xhtml]  view plain copy
  1. <!-- 统设置界面需要要到的字符串 -->  
  2.     <string name="system_settings">系统设置</string>  
  3.     <string name="auto_update_setting">自动更新设置</string>  
  4.     <string name="auto_update_switch_title">自动更新</string>  
  5.     <string name="auto_update_switch_key">auto_update_switch</string>  
  6.     <string name="auto_update_switch_summary_on">开启自动更新</string>  
  7.     <string name="auto_update_switch_summary_off">关闭自动更新</string>  
  8.     <string name="auto_update_frequency_title">更新频率</string>  
  9.     <string name="auto_update_frequency_key">auto_update_frequency</string>  
  10.     <string name="auto_update_frequency_default_value">10</string>  
  11.         <string name="auto_update_frequency_summary">设置自动更新的时间周期</string>  
  12.     <string name="cancel">取消</string>  
 

    需要的数据现在准备好了,下面我们来完成对应的xml文件。xml文件中各个标签的属性比较多,虽然Android有代码自动补全功能,但是还是使用Android提供的Structure界面来填写比较方便,下面我们就以这个方式来完成。

    在res/xml文件夹下新建一个Android XML File文件,取名为preferencesii.xml,类型选择PreferenceRoot Element选择PreferenceScreen。          在Structure方式显示时,就会列出选中标签的所有属性,然后就可以根据需要填写属性,如下图5所示:

填写xmlPreference的属性

    从上图我们可以看到一个Preference拥有的属性。其中Key为这个PreferenceID,设置了才可以在代码中引用,Title是显示的标题,Summary是显示在标题下的文字介绍, 一般在Dependency中填写一个CheckBoxPreference的Key,这样就会在填写的那个CheckBoxPreference勾选时当前这个Preference才可用,Default Value为初始值,等等。

    点击“Add”按钮,就会添加新的标签,我们依次添加一个CheckBoxPreference和ListPreference。属于CheckBoxPreference的特有属性主要为Summary OnSummary Off,比较好理解。下面具体来看下ListPreference属性的填写:

6 ListPreference的属性

    我们可以看到,ListPreference除了继承自Preference的属性外,还有自己ListPreference的属性和继承自DialogPreference的属性。其中属于ListPreference的属性有两个:Entries填的为一个字符串数组,是列表显示出来的值,而Entry Values是长度对应的字符串数组,是和Entries对应的具体的值。DialogPreference只要填一个Dialog title标题和一个取消按钮显示的字即可。在Preference属性的Dependency中我们填写上面一个CheckBoxPreferenceKey,这样就会只有在CheckBoxPreference勾选时这个ListPreference才有效。

完整的xml显示

    最后把java文件中的addPreferencesFromResource(R.xml.preferences);改为addPreferencesFromResource(R.xml.preferencesii);

    保存运行,看下效果。

8 ListPreference显示

2.3 OnPreferenceChangeListener

    以上我们分别介绍了Preference对数据的保存及PreferenceActivity设置界面。当PreferenceActivity中的内容改变时,Android系统会自动进行保存和持久化维护,我们只需要在要用的设置界面中数据的地方进行读取就可以了。同时Android还提供了OnPreferenceClickListener和OnPreferenceChangeListener两个与Preference相关的监听接口,当PreferenceActivity中的某一个Preference进行了点击或者改变的操作时,都会回调接口中的函数,这样可以第一个时间向其他Activity等通知系统设置进行了改变。

下面我们以一个具体的Demo说明PreferenceActivity和其监听接口的使用。

    新建一个工程AndroidPreferenceDemoII,并按上面的步骤添加xml文件夹和其内容Preferenceii.xml,还有values文件夹中的array.xmlstrings.xml

    新建一个名为Settingsclass,内容为:

[java]  view plain copy
  1. //继承PreferenceActivity,并实现OnPreferenceChangeListener和OnPreferenceClickListener监听接口  
  2. public class Settings extends PreferenceActivity implements OnPreferenceChangeListener,   
  3. OnPreferenceClickListener{  
  4.     //定义相关变量  
  5.     String updateSwitchKey;  
  6.     String updateFrequencyKey;  
  7.     CheckBoxPreference updateSwitchCheckPref;  
  8.     ListPreference updateFrequencyListPref;  
  9.     @Override  
  10.     public void onCreate(Bundle savedInstanceState) {  
  11.         super.onCreate(savedInstanceState);  
  12.         //从xml文件中添加Preference项  
  13.         addPreferencesFromResource(R.xml.preferencesii);  
  14.         //获取各个Preference  
  15.         updateSwitchKey = getResources().getString(R.string.auto_update_switch_key);  
  16.         updateFrequencyKey = getResources().getString(R.string.auto_update_frequency_key);  
  17.         updateSwitchCheckPref = (CheckBoxPreference)findPreference(updateSwitchKey);  
  18.         updateFrequencyListPref = (ListPreference)findPreference(updateFrequencyKey);  
  19.         //为各个Preference注册监听接口  
  20.         updateSwitchCheckPref.setOnPreferenceChangeListener(this);  
  21.         updateSwitchCheckPref.setOnPreferenceClickListener(this);  
  22.         updateFrequencyListPref.setOnPreferenceChangeListener(this);  
  23.         updateFrequencyListPref.setOnPreferenceClickListener(this);         
  24.     }  
  25.     @Override  
  26.     public boolean onPreferenceChange(Preference preference, Object newValue) {  
  27.         // TODO Auto-generated method stub  
  28.         Log.v("SystemSetting""preference is changed");  
  29.         Log.v("Key_SystemSetting", preference.getKey());  
  30.         //判断是哪个Preference改变了  
  31.         if(preference.getKey().equals(updateSwitchKey))  
  32.         {  
  33.             Log.v("SystemSetting""checkbox preference is changed");  
  34.         }  
  35.         else if(preference.getKey().equals(updateFrequencyKey))  
  36.         {  
  37.             Log.v("SystemSetting""list preference is changed");  
  38.         }  
  39.         else  
  40.         {  
  41.             //如果返回false表示不允许被改变  
  42.             return false;  
  43.         }  
  44.         //返回true表示允许改变  
  45.         return true;  
  46.     }  
  47.     @Override  
  48.     public boolean onPreferenceClick(Preference preference) {  
  49.         // TODO Auto-generated method stub  
  50.         Log.v("SystemSetting""preference is clicked");  
  51.         Log.v("Key_SystemSetting", preference.getKey());  
  52.         //判断是哪个Preference被点击了  
  53.         if(preference.getKey().equals(updateSwitchKey))  
  54.         {  
  55.             Log.v("SystemSetting""checkbox preference is clicked");  
  56.         }  
  57.         else if(preference.getKey().equals(updateFrequencyKey))  
  58.         {  
  59.             Log.v("SystemSetting""list preference is clicked");  
  60.         }  
  61.         else  
  62.         {  
  63.             return false;  
  64.         }  
  65.         return true;  
  66.     }  
  67. }  
 

    主要是获取xml文件中的各个Preference,然后为其注册监听接口,最后在监听接口的回调函数中打印相关的信息。

    接着在Manifest文件中对这个Activity进行注册:

[xhtml]  view plain copy
  1. <activity android:name=".Settings">  
  2. </activity>  
 

    然后对AndroidPreferenceDemoII.java文件进行如下修改:

[java]  view plain copy
  1. public class AndroidPreferenceDemoII extends Activity {  
  2.     /** Called when the activity is first created. */  
  3.     // 菜单项  
  4.     final private int menuSettings=Menu.FIRST;  
  5.     private static final int REQ_SYSTEM_SETTINGS = 0;    
  6.     @Override  
  7.     public void onCreate(Bundle savedInstanceState) {  
  8.         super.onCreate(savedInstanceState);  
  9.         setContentView(R.layout.main);  
  10.     }  
  11.     //创建菜单  
  12.     @Override  
  13.     public boolean onCreateOptionsMenu(Menu menu)  
  14.     {  
  15.         // 建立菜单  
  16.         menu.add(0, menuSettings, 2"设置");  
  17.         return super.onCreateOptionsMenu(menu);  
  18.     }  
  19.     //菜单选择事件处理  
  20.     @Override  
  21.     public boolean onMenuItemSelected(int featureId, MenuItem item)  
  22.     {  
  23.         switch (item.getItemId())  
  24.         {  
  25.             case menuSettings:  
  26.                 //转到Settings设置界面  
  27.                 startActivityForResult(new Intent(this, Settings.class), REQ_SYSTEM_SETTINGS);  
  28.                 break;  
  29.             default:  
  30.                 break;  
  31.         }  
  32.         return super.onMenuItemSelected(featureId, item);  
  33.     }  
  34.     //Settings设置界面返回的结果  
  35.     protected  void onActivityResult(int requestCode, int resultCode, Intent data) {  
  36.         if(requestCode == REQ_SYSTEM_SETTINGS)  
  37.         {  
  38.             //获取设置界面PreferenceActivity中各个Preference的值  
  39.             String updateSwitchKey = getResources().getString(R.string.auto_update_switch_key);  
  40.             String updateFrequencyKey = getResources().getString(R.string.auto_update_frequency_key);  
  41.             //取得属于整个应用程序的SharedPreferences  
  42.             SharedPreferences settings = PreferenceManager.getDefaultSharedPreferences(this);  
  43.             Boolean updateSwitch = settings.getBoolean(updateSwitchKey, true);  
  44.             String updateFrequency = settings.getString(updateFrequencyKey, "10");  
  45.             //打印结果  
  46.             Log.v("CheckBoxPreference_Main", updateSwitch.toString());  
  47.             Log.v("ListPreference_Main", updateFrequency);  
  48.         }  
  49.         else  
  50.         {  
  51.             //其他Intent返回的结果  
  52.         }  
  53.     }  
  54. }  
 

    主要是添加一个设置菜单,点击后转到设置界面,当从设置界面返回后读取保存的内容,并打印出来查看。

    最后我们看一下运行的效果:

设置界面操作

    操作的Log输出如下图10所示:

 

10 DDMSLogCat输出

 

    点击设置菜单转到设置界面后,首先点击CheckBox,输出前6行,然后点击ListPreference,输出3行,当选择列表的第二个进行改变时,再输出3行,最后按返回键回到第一个页面,打印出最后2行。

 

    最后我们看一下这些设置参数在系统中的保存文件。在DDMSFile Explorer中,查看data/data/com.ichliebephone文件夹,我们可以看到有如下文件:

11 Preference保存的文件

 

    把这个文件导出到电脑上,可以看到起内容为:

[xhtml]  view plain copy
  1. <?xml version='1.0' encoding='utf-8' standalone='yes' ?>  
  2. <map>  
  3. <string name="auto_update_frequency">30</string>  
  4. <boolean name="auto_update_switch" value="true" />  
  5. </map>  
 

    文件以map的方式保存了两个设置参数

三.总结

    我们学习了AndroidPreference相关内容,包括最基本的SharedPreferences的使用,及进一步的PreferenceActivity设置界面的介绍,最后根据以上的内容完成了一个简单的Demo

    Preference键值对的方式是Android最简单的一种数据持久化方式,虽然比较简单,但是也比较实用,特别是在保存小量的数据时。Android上的功能更加强大相对也更加复杂的SQLite数据保存方式我们以后接着学习。

 

 

文章对应的完整代码例子可以在这里下载:

http://download.csdn.net/source/2728956

  转自:http://blog.csdn.net/ichliebephone/article/details/5916320

   另外一个:

   

Android的配置界面PreferenceActivity

 我想大家对于android的系统配置界面应该不会陌生吧,即便陌生,那么下面的界面应该似曾相识吧,假若还是不认识,那么也没有关系,我们这一节主要就是介绍并讲解android 中系统配置界面的使用,相信大家看完本节后,一定能知道怎么使用这些东西了。

从上述界面中(其实是一个界面),我们可以看到有2组元素,第一组为:自动更新,更新频率。第二组为:是否登录,账号,密码。

其实分组是为了方便管理而已。这里主要使用到了选择,列表,编辑框等Preference.

我们还是来温习下基础知识吧。

一.基础知识

通常我们开发一个程序时,会需要给用户提供一个设置界面,使用户可以对程序的一些参数进行设置。通常我们使用Preferences的键值对存储方式,来对Android数据持久化。

 

android.content.SharedPreferences是一个接口,用来获取和修改持久化存储的数据。有三种方式可以获取系统中持久化的数据,这些数据时存放在.xml中的:

1:public SharedPreferences getPreferences (int mode),只隶属于activity对象,并以这个对象为文件名。

2:public SharedPreferences getSharedPreferences (String name, int mode),隶属于整个应用,以name名称保存。

3:public static SharedPreferences getDefaultSharedPreferences (Context context),隶属于整个应用,保存PreferenceActivity中的设置,根据包名和PreferenceActivity的布局文件来起一个名字保存。

SharedPreferences可以保存BooleanIntFloatLongString等类型。一般是SharedPreferences.Editor的putXXX()方法保存,并commit()方法提交;或者是remove(),方法移除,clear()方法清空,当然操作完毕后需要commit()方法提交。

    一般的,可以使用SharedPreferences保存持久化数据,比如登陆账号,密码,以及相对固定设置参数等等,看你应用需要。

    既然使用到设置参数界面,那么我们可以来认识下一下几个类标签:

1:PreferenceScreen 持久化设置界面的顶级容器,代表一屏,里面可以嵌套屏幕,嵌套的时候可以点击跳转到另外一屏。

2:PreferenceCategory 当前屏的分组容器,说白了,就是为了划分组而已。

3:CheckBoxPreference,ListPreference,EditTextPreference等等组件。这些都是常见的对应上述的选择标签、列表标签、编辑标签。

上述组件都有titile,summary,key属性。title标题描述,summary:详细描述,key:保存SharedPreferences时候的键。

 

二.实战

既然有了上述基础知识后,我们就可以来做如上的设置界面了,在上述界面中,我们知道当前配置界面只需一屏,没有额外的跳转,那么需要PreferenceScreen,不需要嵌套其他PreferenceScreen,而设置界面分为两栏,那么需要两个PreferenceCategory,并且这个PreferenceCategory可以设置标题。同时根据界面,我们还需要CheckBoxPreferenceListPreference,EditTextPreference等。操作如图:

 


当然了,我们还是实际操作下吧,然后实际联系理论(理论联系实际太抽象),我们首先编写使用工具选择标签,然后形成代码,存放在xml文件夹中,如下:

View Code

当然这里使用到了一些文件,代码一并释放:

View Code
View Code

接下来,我们就来解释下xml文件夹中设置文件的一些内容吧:

 android:key="@string/update_key"   这个是我们持久化时SharedPreferences保存的键,
            android:summaryOn="@string/auto_update_switch_summary_on"     选中后显示内容
            android:summaryOff="@string/auto_update_switch_summary_off"     未选中后显示内容
            android:summary="@string/auto_update_setting"                             平常状态显示内容
            android:title="@string/auto_update_switch_title"                               标题
            android:defaultValue="true"                                                             默认值
  android:dialogTitle="@string/auto_update_frequency_title"                           对话框标题
            android:entries="@array/auto_frequency_name"                                列表项显示名称
            android:entryValues="@array/auto_frequency_value"                          列表项值

  android:disableDependentsState="true"          CheckBoxPreference的值为真的时候,禁用依赖于该设置的其他设置项。

  android:dependency="@string/isneilflag_key"  根据上述设置依赖于CheckBoxPreference的真值进行启用与禁用。

  注意:我们可以从上图知道ListPreference是继承之Preference,以及DialogPreference的,那么就有它们的属性以及方法了。

 好了,设置界面已经定义完成,我们来定义一个activity继承之PreferenceActivity,并使之显示吧。

 当然噩梦可以再使之继承接口OnPreferenceChangeListener,OnPreferenceClickListener,PreferenceActivity中的某一个Preference进行了点击或者改变的操作时,都会回调接口中的函数。

具体代码如下:

View Code

从上述代码可知: 

1:设置显示Preferences可以调用方法addPreferencesFromResource(R.xml.preference); 传递preference文件即可。

2:然后通过findPreference();方法找到键的类标签

3:我们定义2个监听接口监听参数是否设置成功。

4:在监听接口中返回true就是设置允许提交。

结果打印如下:


成功!

也许你会问,我们这里并没有使用

SharedPreferences settings = PreferenceManager.getDefaultSharedPreferences(this);

settings.getXXXX();settings.putXXXX();以及commit()等方法,设置、获取并提交值啊?!是的,在这里我们不需这样,因为

PreferenceActivity中的内容改变时,Android系统会自动进行保存和持久化维护,我们只需要在要用的设置界面中数据的地方进行读取就可以了

当然,您可以在其他界面使用SharedPreferences settings = PreferenceManager.getDefaultSharedPreferences(this);等类方法来获取数据,看能不能获取到


   转自:
http://www.cnblogs.com/zhangdongzi/archive/2012/01/05/2313519.html

 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值