当前位置:  编程技术>移动开发
本页文章导读:
    ▪Intent其间传递复杂的对象        Intent之间传递复杂的对象 在实际项目中,页面之间传值,除了以上几种,经常还有传递Object对象、List类型、List<Object>类型和全局变量等等的需求。本文就是介绍怎么传递这几种类型的.........
    ▪ ListView几个不一般的属性        ListView几个特别的属性       由于这两天在做listView的东西,所以整理出来一些我个人认为比较特别的属性,通过设置这样的属性可以做出更加美观的列表       首先是stackFromBottom属性,这.........
    ▪ 十年微日志       十年微日记 迄今为止iPhone上发现的最好的日记本软件。将十年中的同一天放在一页上显示,写某一天日记的时候,可以回顾之前每一年的这一天都做了什么,太有成就感了界面看着很舒服.........

[1]Intent其间传递复杂的对象
    来源: 互联网  发布时间: 2014-02-18
Intent之间传递复杂的对象

在实际项目中,页面之间传值,除了以上几种,经常还有传递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();  

  •     
    [2] ListView几个不一般的属性
        来源: 互联网  发布时间: 2014-02-18
    ListView几个特别的属性

          由于这两天在做listView的东西,所以整理出来一些我个人认为比较特别的属性,通过设置这样的属性可以做出更加美观的列表

          首先是stackFromBottom属性,这只该属性之后你做好的列表就会显示你列表的最下面,值为true和false.

    android:stackFromBottom="true"             

          第二是 transciptMode属性,需要用ListView或者其它显示大量Items的控件实时跟踪或者查看信息,并且希望最新的条目可以自动滚动到可视范围内。通过设置的控件transcriptMode属性可以将Android平台的控件(支持ScrollBar)自动滑动到最底部。
     android:transcriptMode="alwaysScroll"    

           第三cacheColorHint属性,很多人希望能够改变一下它的背景,使他能够符合整体的UI设计,改变背景背很简单只需要准备一张图片然后指定属性 android:background="@drawable/bg",不过不要高兴地太早,当你这么做以后,发现背景是变了,但是当你拖动,或者点击list空白位置的时候发现ListItem都变成黑色的了,破坏了整体效果。

           如果你只是换背景的颜色的话,可以直接指定android:cacheColorHint为你所要的颜色,如果你是用图片做背景的话,那也只要将android:cacheColorHint指定为透明(#00000000)就可以了

           第四divider属性,该属性作用是每一项之间需要设置一个图片做为间隔,或是去掉item之间的分割线

     android:divider="@drawable/list_driver"  其中  @drawable/list_driver 是一个图片资源,如果不想显示分割线则只要设置为android:divider="@drawable/@null" 就可以了

           第五fadingEdge属性,上边和下边有黑色的阴影

    android:fadingEdge="none" 设置后没有阴影了~

           第五scrollbars属性,作用是隐藏listView的滚动条,

    android:scrollbars="none"与setVerticalScrollBarEnabled(true);的效果是一样的,不活动的时候隐藏,活动的时候也隐藏

           第六fadeScrollbars属性,android:fadeScrollbars="true"  配置ListView布局的时候,设置这个属性为true就可以实现滚动条的自动隐藏和显示。


        
    [3] 十年微日志
        来源: 互联网  发布时间: 2014-02-18
    十年微日记
    迄今为止iPhone上发现的最好的日记本软件。
    将十年中的同一天放在一页上显示,写某一天日记的时候,可以回顾之前每一年的这一天都做了什么,太有成就感了
    界面看着很舒服,还有提醒、纪念日等功能

        
    最新技术文章:
    ▪Android开发之登录验证实例教程
    ▪Android开发之注册登录方法示例
    ▪Android获取手机SIM卡运营商信息的方法
    ▪Android实现将已发送的短信写入短信数据库的...
    ▪Android发送短信功能代码
    ▪Android根据电话号码获得联系人头像实例代码
    ▪Android中GPS定位的用法实例
    ▪Android实现退出时关闭所有Activity的方法
    ▪Android实现文件的分割和组装
    ▪Android录音应用实例教程
    ▪Android双击返回键退出程序的实现方法
    ▪Android实现侦听电池状态显示、电量及充电动...
    ▪Android获取当前已连接的wifi信号强度的方法
    ▪Android实现动态显示或隐藏密码输入框的内容
    ▪根据USER-AGENT判断手机类型并跳转到相应的app...
    ▪Android Touch事件分发过程详解
    ▪Android中实现为TextView添加多个可点击的文本
    ▪Android程序设计之AIDL实例详解
    ▪Android显式启动与隐式启动Activity的区别介绍
    ▪Android按钮单击事件的四种常用写法总结
    ▪Android消息处理机制Looper和Handler详解
    ▪Android实现Back功能代码片段总结
    ▪Android实用的代码片段 常用代码总结
    ▪Android实现弹出键盘的方法
    ▪Android中通过view方式获取当前Activity的屏幕截...
    ▪Android提高之自定义Menu(TabMenu)实现方法
    ▪Android提高之多方向抽屉实现方法
    ▪Android提高之MediaPlayer播放网络音频的实现方法...
    ▪Android提高之MediaPlayer播放网络视频的实现方法...
    ▪Android提高之手游转电视游戏的模拟操控
     


    站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3