本文详细讲述了Android intent之间复杂参数传递方法。分享给大家供大家参考,具体如下:
Intent是Activity与Activity之间,Activity与Service之间传递参数的介质,而这两种通常实现的是Java基本对象类型和String的传递。
在实际项目中,页面之间传值,除了以上几种,经常还有传递Object对象、List类型、List<Object>类型和全局变量等等的需求。本文就是介绍怎么传递这几种类型的参数。
一、传递List<String>和List<Integer>
以下以传递List<String>为例,发送List<String>语法为:
intent.putStringArrayListExtra(key, list);
接收List<String>的语法为:
list = (ArrayList<String>)getIntent().getStringArrayListExtra(key);
以下是一个运用实例:
// =============发送List<String>============= ArrayList<String> stringList = new ArrayList<String>(); stringList.add("string1"); stringList.add("string2"); stringList.add("string3"); Intent intent = new Intent(); intent.setClass(ListDemoActivity.this, StringListActivity.class); intent.putStringArrayListExtra("ListString", stringList); startActivity(intent); // ====================接收List<String>====================== ArrayList<String> stringList = (ArrayList<String>) getIntent().getStringArrayListExtra("ListString");
List<Integer>类似以上的操作调用下面的方法也可以实现发送和接收:
intent.putIntegerArrayListExtra(key, list); list =(ArrayList<Integer>) getIntent().getIntegerArrayListExtra(key);
二、使用Serializable和Parcelable两种方式传递Object
Android的Intent之间传递对象有两种方法,一种是Bundle.putSerializable(Key,Object);另一种是Bundle.putParcelable(Key,Object)。方法中的Object要满足一定的条件,前者实现了Serializable接口,而后者实现了Parcelable接口。
以下是实现了Serializable接口的User类,命名为SerializableUser纯粹是从类名方便区分实现了Parcelable接口的User类,实际开发中不建议这么命名:
public class SerializableUser implements Serializable { private String userName; private String password; public SerializableUser() { } public SerializableUser(String userName, String password) { this.userName = userName; this.password = password; } public String getUserName() { return userName; } public void setUserName(String userName) { this.userName = userName; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }
以下是实现了Parcelable接口的User类:
public class ParcelableUser implements Parcelable { private String userName; private String password; public ParcelableUser() { } public ParcelableUser(String userName, String password) { this.userName = userName; this.password = password; } public String getUserName() { return userName; } public void setUserName(String userName) { this.userName = userName; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public static final Parcelable.Creator<ParcelableUser> CREATOR = new Creator<ParcelableUser>() { @Override public ParcelableUser createFromParcel(Parcel source) { ParcelableUser parcelableUser = new ParcelableUser(); parcelableUser.userName = source.readString(); parcelableUser.password = source.readString(); return parcelableUser; } @Override public ParcelableUser[] newArray(int size) { return new ParcelableUser[size]; } }; @Override public int describeContents() { // TODO Auto-generated method stub return 0; } @Override public void writeToParcel(Parcel dest, int flags) { // TODO Auto-generated method stub dest.writeString(userName); dest.writeString(password); } }
使用两种方式传递的语法分别为:
bundle.putSerializable(key,object); bundle.putParcelable(key,object);
使用两种方式接收的语法分别为:
object=(Object) getIntent().getSerializableExtra(key); object=(Object) getIntent().getParcelableExtra(key);
// ==========分别使用Serializable和Parcelable发送Object=============== SerializableUser serializableUser = new SerializableUser("user1", "123456"); ParcelableUser parcelableUser = new ParcelableUser("user2","654321"); Intent intent = new Intent(); Bundle bundle = new Bundle(); bundle.putSerializable("serializableUser", serializableUser); bundle.putParcelable("parcelableUser", parcelableUser); intent.setClass(ListDemoActivity.this,ObjectActivity.class); intent.putExtras(bundle); startActivity(intent); // ====================接收Object====================== SerializableUser serializableUser = (SerializableUser) getIntent().getSerializableExtra("serializableUser"); ParcelableUser parcelableUser = (ParcelableUser) getIntent().getParcelableExtra("parcelableUser");
可能有人注意到,实现Serializable接口就是把对象序列化,然后再传输,和Java的常用编程没什么明显区别,而且User不需要明显改变,比较简单。我也推荐用这种方式。
然而,后一种实现Parcelable接口的类比较复杂,Parcelable是个什么东西呢?
Android提供了一种新的类型:Parcel,被用作封装数据的容器,封装后的数据可以通过Intent或IPC传递。 除了基本类型以外,只有实现了Parcelable接口的类才能被放入Parcel中。
实现Parcelable接口需要实现三个方法:
1)writeToParcel 方法。该方法将类的数据写入外部提供的Parcel中。
声明:writeToParcel (Parcel dest, int flags)。
2)describeContents方法。直接返回0就可以。
3)静态的Parcelable.Creator<T>接口,本接口有两个方法:
createFromParcel(Parcel in) 实现从in中创建出类的实例的功能。
newArray(int size) 创建一个类型为T,长度为size的数组, returnnew T[size];即可。本方法是供外部类反序列化本类数组使用。
通过log测试输出可知程序的运行情况,在bundle.putParcelable("parcelableUser", parcelableUser);时,调用了ParcelableUser类中的publicvoid writeToParcel(Parcel dest, int flags)方法,并向dest写数据,在 ParcelableUserparcelableUser= (ParcelableUser)getIntent().getParcelableExtra("parcelableUser");的时候,调用了ParcelableUser类中的public ParcelableUsercreateFromParcel(Parcel source) 方法,创建了一个ParcelableUser对象,并给这个对象的属性赋值,这里的Parcel source和Parcel dest是相同的,然后返回这个ParcelableUser对象。最后就可以打印出parcelableUser的属性信息了。
三、传递List<Object>
如果我们要传递的是Object组成的List列表,即List<Object>,该怎么办呢?首先需要将Object对象实现Serializable接口,然后把list强制类型转换成Serializable类型,最后通过:
Intent.putExtra(key, (Serializable)objectList);
这样的语法来传递,接收方在接收的时候也需要强制类型转换成List<Object>,接收 List<Object>使用的语法是:
objectList= (List<Object>) getIntent().getSerializableExtra(key);
以下是一个应用实例,这里使用的SerializableUser类在上一步有给出,这里就不再重复给出。
// ==============发送List<Object>=========== SerializableUser user1 = new SerializableUser("user1", "123456"); SerializableUser user2 = new SerializableUser("user2", "654321"); List<SerializableUser> objectList = new ArrayList<SerializableUser>(); objectList.add(user1); objectList.add(user2); Intent intent = new Intent(); intent.setClass(ListDemoActivity.this, ObjectListActivity.class); intent.putExtra("ListObject", (Serializable) objectList); startActivity(intent); // ====================接收List<Object>====================== List<SerializableUser> objectList = (List<SerializableUser>) getIntent().getSerializableExtra("ListObject");
四、全局变量
如果一些特殊的应用级别的参数,不方便使用intent来传递参数,我们很容易想到是不是有全局变量或静态变量可以使用?Java中的静态变量在这里是适合的,但其值在Activity调用了System.exit(0)或finish()后就丢失了。
而在android中有个更优雅的方式是使用ApplicationContext。这种全局变量方法相对静态类更有保障,直到应用的所有Activity全部被destory掉之后才会被释放掉。
Android的SDK中有说道,Application是用来保存全局变量的,并且是在package创建的时候就存在了。所以当我们需要创建全局变量的时候,不需要再像J2SE那样需要创建public权限的static变量,而直接在application中去实现。只需要调用Context的 getApplicationContext或者Activity的getApplication方法来获得一个Application对象,就可以设置或读取全局变量的值。
启动Application时,系统会创建一个PID,即进程ID,所有的Activity就会在此进程上运行。那么我们在Application创建的时候初始化全局变量,同一个应用的所有Activity都可以取到这些全局变量的值,换句话说,我们在某一个Activity中改变了这些全局变量的值,那么在同一个应用的其他Activity中值就会改变。
用法:
1. 创建一个属于你自己的android.app.Application的子类,为想要共享的private全局变量增加setter和getter方法。
public class MyApp extends Application{ private String globalVariable; public String getGlobalVariable() { return globalVariable; } public void setGlobalVariable(String globalVariable) { this.globalVariable = globalVariable; } }
2. 在manifest中申明一下这个类,这时Android就为此建立一个全局可用的实例。
其实就是在原来仅有的一个application标签上为application制定一个名字为这个全局实例。
<application android:name=".MyApp" android:icon="@drawable/icon" android:label="@string/app_name">
3. 可以在其他任何地方使用Context.getApplicationContext()方法获取这个实例,进而获取其中的状态(变量)。
// ============使用全局变量传递参数============== MyApp myApp = ((MyApp) getApplicationContext());//获得我们的应用程序MyApp myApp.setGlobalVariable("全局变量"); Intent intent = new Intent(); intent.setClass(ListDemoActivity.this, GlobalActivity.class); startActivity(intent); // ============接收全局变量的参数============== MyApp myApp = ((MyApp) getApplicationContext()); String globalVariable = myApp.getGlobalVariable();
更多关于Android相关内容感兴趣的读者可查看本站专题:《Android开发入门与进阶教程》、《Android编程之activity操作技巧总结》、《Android资源操作技巧汇总》、《Android文件操作技巧汇总》、《Android操作SQLite数据库技巧总结》、《Android操作json格式数据技巧总结》、《Android数据库操作技巧总结》、《Android编程开发之SD卡操作方法汇总》、《Android视图View技巧总结》及《Android控件用法总结》
希望本文所述对大家Android程序设计有所帮助。
主要内容:本节引言:,1.Intent传递简单数据,2.Intent传递数组,3.Intent传递集合,4.Intent传递对象,5.Intent传递Bitmap,6.传来传去不方便,直接定义全局数据,7.单例模式传参,本节小结:本节引言: 上一节中我们学习了Intent的一些基本使用,知道了Intent的七个属性,显式Intent以及 隐式Intent,以及如何自定义隐式Intent,最后还给大家提供了一些常用的系统Intent! 而本节跟大家讲解的是Intent传递数据的问题~好的,开始本节
本文向大家介绍详述ASP.Net中页面之间传参方法,包括了详述ASP.Net中页面之间传参方法的使用技巧和注意事项,需要的朋友参考一下 ASP.NET提供了卓越的事件驱动编程模型,让开发者简化了应用程序的总体设计,但是这个也造成了它固有的一些问题,例如,使用传统的ASP里,我们可以通过使用POST方法很容易地实现页面间传递值,同样的事情,在使用事件驱动编程模型的ASP.NET就不是那么容易了,当然
本文向大家介绍详解layui弹窗父子窗口之间传参数的方法,包括了详解layui弹窗父子窗口之间传参数的方法的使用技巧和注意事项,需要的朋友参考一下 本文介绍了layui弹窗父子窗口之间传参数的方法,分享给大家,具体如下: 1、父页面打开子页面并向子页面传参数 2、子页面向父页面传参数并关闭弹窗 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍在两个iframe之间传递参数的方法有哪些?相关面试题,主要包含被问及在两个iframe之间传递参数的方法有哪些?时的应答技巧和注意事项,需要的朋友参考一下 通过postMessage与父级通过,父级传递消息 通过websocket通信 如果是同一个域名下 可用stroage,监听storageChange事件通信 通过web worker也可通信
本文向大家介绍Spring MVC 学习 之 - URL参数传递详解,包括了Spring MVC 学习 之 - URL参数传递详解的使用技巧和注意事项,需要的朋友参考一下 在学习 Spring Mvc 过程中,有必要来先了解几个关键参数: @Controller: 在类上注解,则此类将编程一个控制器,在项目启动 Spring 将自动扫描此类,并进行对应URL路由映射。 @RequestMappin
本文向大家介绍JavaScript函数参数的传递方式详解,包括了JavaScript函数参数的传递方式详解的使用技巧和注意事项,需要的朋友参考一下 JavaScript使用一个变量对象来追踪变量的生存期。基本类型值被直接保存在变量对象内;而引用类型值则作为一个指针保存在变量对象内,该指针指向实际对象在内存中的存储位置。 基本类型值的传递 向参数传递基本类型值时,被传递的值会被复制给一个局部变量(即