赵雅智_Intent传值

来源:互联网 发布:回国人员留学证明 知乎 编辑:程序博客网 时间:2024/05/20 15:40

Intent简介

Android基本的设计理念是鼓励减少组件间的耦合,因此Android提供了Intent (意图Intent提供了一种通用的消息系统,它允许在你的应用程序与其它的应用程序间传递Intent来执行动作和产生事件。使用Intent可以激活Android应用的三个核心组件:活动、服务和广播接收器。

 

 

 

在一个Activity中可以使用系统提供的startActivity(Intent intent)方法打开新的Activity,在打开新的Activity前,你可以决定是否为新的Activity传递参数:

IntentActivity

打开新的Activity,不传递参数

startActivity(new Intent(MainActivity.this, NewActivity.class));

新建一个显式意图,第一个参数为当前Activity类对象,第二个参数为你要打开的Activity

 

Bunder类作用:

Bundle类用作携带数据,它类似于Map,用于存放key-value名值对形式的值。

相对于Map,它提供了各种常用类型的putXxx()/getXxx()方法,

:putString()/getString()putInt()/getInt()

putXxx()用于往Bundle对象放入数据,getXxx()方法用于从Bundle对象里获取数据。

Bundle的内部实际上是使用了HashMap<String, Object>类型的变量来存放putXxx()方法放入的值:

public final class Bundle implements Parcelable, Cloneable {

       .....

Map<String, Object> mMap;

public Bundle() {

        mMap = new HashMap<String, Object>();

         ......

  }

public void putString(String key, String value) {

       mMap.put(key, value);

  }

public String getString(String key) {

        Object o = mMap.get(key);

         return (String) o;

        ........//类型转换失败后会返回null,这里省略了类型转换失败后的处理代码

}

}

在调用Bundle对象的getXxx()方法时,方法内部会从该变量中获取数据,然后对数据进行类型转换,转换成什么类型由方法的Xxx决定,getXxx()方法会把转换后的值返回。

 

Intent附加数据的两种写法

用于批量添加数据到Intent

Intent intent = new Intent();

Bundle bundle = new Bundle();//该类用作携带数据

bundle.putString("name", "CSDN");

intent.putExtras(bundle);//为意图追加额外的数据,意图原来已经具有的数据不会丢失,但key同名的数据会被替换

把数据一个个地添加进Intent

这种写法使用起来比较方便,而且只需要编写少量的代码。

Intent intent = new Intent();

intent.putExtra("name", "CSDN");

Intent提供了各种常用类型重载后的putExtra()方法,如: putExtra(String name, String value)、 putExtra(String name, long value),在putExtra()方法内部会判断当前Intent对象内部是否已经存在一个Bundle对象,如果不存在就会新建Bundle对象,以后调用putExtra()方法传入的值都会存放于该Bundle对象,下面是IntentputExtra(String name, String value)方法代码片断:

public class Intent implements Parcelable {

private Bundle mExtras;

public Intent putExtra(String name, String value) {

        if (mExtras == null) {

            mExtras = new Bundle();

        }

        mExtras.putString(name, value);

        return this;

 }

 

在新的Activity中接收前面Activity传递过来的参数:

intent

Intent intent = getIntent(); 

String username = intent.getStringExtra("username1");   

String userpwd = intent.getStringExtra("userpwd1"); 

 

bundler

Bundle bundle = this.getIntent().getExtras();

String name = bundle.getString("name");

int age = bundle.getInt("age");

 

实例1:人品测试

实现说明:

在第一个activity中输入姓名,通过测试按钮,在第二个activity中显示人品值

实现效果:


 

程序主要代码:

第一个activity的布局文件

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:paddingBottom="@dimen/activity_vertical_margin"    android:paddingLeft="@dimen/activity_horizontal_margin"    android:paddingRight="@dimen/activity_horizontal_margin"    android:paddingTop="@dimen/activity_vertical_margin"    tools:context=".FirstActivity" >    <TextView        android:id="@+id/textView1"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="姓名"         android:layout_marginTop="30dp"/>    <Button        android:id="@+id/button1"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_alignLeft="@+id/textView1"        android:layout_below="@+id/et_name"        android:layout_marginTop="28dp"        android:onClick="openActivity"        android:text="测试人品" />    <EditText        android:id="@+id/et_name"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_alignParentRight="true"        android:layout_alignTop="@+id/textView1"        android:ems="10" /></RelativeLayout>


第二个activity的布局文件

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:paddingBottom="@dimen/activity_vertical_margin"    android:paddingLeft="@dimen/activity_horizontal_margin"    android:paddingRight="@dimen/activity_horizontal_margin"    android:paddingTop="@dimen/activity_vertical_margin"    tools:context=".SecondActivity" >    <TextView        android:id="@+id/tv_rp"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="@string/hello_world" />    <Button        android:id="@+id/button1"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_alignParentLeft="true"        android:layout_alignParentRight="true"        android:layout_centerVertical="true"        android:layout_below="@+id/tv_rp"        android:layout_marginTop="30dp"        android:onClick="returnActiviy"        android:text="返回" /></RelativeLayout>


第一个activityactivity主要代码

package com.example.android_activity;import android.app.Activity;import android.content.Intent;import android.os.Bundle;import android.view.View;import android.widget.EditText;public class FirstActivity extends Activity {private EditText et_name;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);//设置当前的视图(相当于网站的一个网页)setContentView(R.layout.activity_first);et_name = (EditText) findViewById(R.id.et_name);}public void openActivity(View v){String name =  et_name.getText().toString();//意图Intent intent = new Intent(FirstActivity.this,SecondActivity.class);//将姓名传过去//intent.putExtra("name", name);//方式一传值//方式二传值Bundle bundle = new Bundle();bundle.putString("name", name);intent.putExtras(bundle);//执行意图startActivity(intent);}}

 

第二个activityactivity主要代码

package com.example.android_activity;import java.util.Random;import android.app.Activity;import android.content.Intent;import android.os.Bundle;import android.view.View;import android.widget.TextView;public class SecondActivity extends Activity {private TextView tv_rp;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_second);//获取控件tv_rp = (TextView) findViewById(R.id.tv_rp);//获取随机数Random random = new Random();int n = random.nextInt(100);//创建意图Intent intent = getIntent();//获取第一个activity传来的项目//String name = intent.getStringExtra("name");//方式一取值//方式二取值Bundle bundle = intent.getExtras();String name = bundle.getString("name");//设置值tv_rp.setText(name+"的人品是:"+n+"分");}public void returnActiviy(View v){//意图Intent intent = new Intent(SecondActivity.this,FirstActivity.class);//执行意图startActivity(intent);} }

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?><manifest xmlns:android="http://schemas.android.com/apk/res/android"    package="com.example.android_activity"    android:versionCode="1"    android:versionName="1.0" >    <uses-sdk        android:minSdkVersion="8"        android:targetSdkVersion="17" />    <!--     application应用     android:icon="@drawable/ic_launcher" 应用图标  (设置-应用)     android:label="@@string/app_name" 应用标题  (设置-应用)    -->    <application        android:allowBackup="true"        android:icon="@drawable/ic_launcher"        android:label="@string/app_name"        android:theme="@style/AppTheme" >        <!--             默认的时候会给 android:icon=""加图标        高版本:手动加入         label文本:如果这个activity是手机桌面应用入口,默认就要设置成 android:label="@string/app_name"        -->        <!-- 第一个activity -->        <activity            android:name="com.example.android_activity.FirstActivity"            android:label="@string/app_name" >            <intent-filter>                <action android:name="android.intent.action.MAIN" />                <category android:name="android.intent.category.LAUNCHER" />            </intent-filter>        </activity>        <!-- 第二个activity -->        <activity            android:name="com.example.android_activity.SecondActivity"            android:label="人品详情"            android:theme="@android:style/Theme.Dialog" >            <intent-filter>                <action android:name="android.intent.action.MAIN" />                <category android:name="android.intent.category.LAUNCHER" />            </intent-filter>        </activity>    </application></manifest>


实例二

项目需求

当我们穿的是一个实体类的时候,传递参数并在控制台输出

运行结果 

如下:

 

源代码

User实体类
第一个activity的布局文件 同人品测试
第二个activity的布局文件 同人品测试
第一个activityactivity主要代码

package com.example.android_activity;import android.app.Activity;import android.content.Intent;import android.os.Bundle;import android.view.View;public class FirstActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);//设置当前的视图(相当于网站的一个网页)setContentView(R.layout.activity_first);}public void openActivity(View v){//意图Intent intent = new Intent(FirstActivity.this,SecondActivity.class);//传递的类必须是可序列化对象intent.putExtra("user", new User(1, "Jack", "aaa"));//执行意图startActivity(intent);} }

第二个activityactivity主要代码

package com.example.android_activity;import android.app.Activity;import android.content.Intent;import android.os.Bundle;import android.view.View;public class SecondActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_second);Intent intent = getIntent();User user = (User) intent.getSerializableExtra("user");System.out.println(user.toString());}public void returnActiviy(View v){//意图Intent intent = new Intent(SecondActivity.this,FirstActivity.class);//执行意图startActivity(intent);} }

AndroidManifest.xml 同人品测试

 

得到新打开Activity 关闭后返回的数据

如果你想在Activity中得到新打开Activity 关闭后返回的数据,你需要使用系统提供的startActivityForResult(Intent intent, int requestCode)方法打开新的Activity,新的Activity 关闭后会向前面的Activity 传回数据,为了得到传回的数据,你必须在前面的Activity中重写onActivityResult(int requestCode, int resultCode, Intent data)方法:

public class MainActivity extends Activity {

@Override 

protected void onCreate(Bundle savedInstanceState) {

.......

Button button =(Button) this.findViewById(R.id.button);

button.setOnClickListener(new View.OnClickListener(){

public void onClick(View v) {

//第一个参数为请求码,即调用startActivityForResult()传递过去的值

//第二个参数为结果码,结果码用于标识返回数据来自哪个新Activity

startActivityForResult (new Intent(MainActivity.this, NewActivity.class),1);

}

});

}

 

@Override 

protected void onActivityResult(int requestCode, int resultCode, Intent data) {

//得到新Activity 关闭后返回的数据

String result = data.getExtras().getString(result));

}

}

当新Activity关闭后,新Activity返回的数据通过Intent进行传递,android平台会调用前面Activity onActivityResult()方法,把存放了返回数据的Intent作为第三个输入参数传入,在onActivityResult()方法中使用第三个输入参数可以取出新Activity返回的数据。

 

使用startActivityForResult(Intent intent, int requestCode)方法打开新的Activity,新Activity关闭前需要向前面的Activity返回数据需要使用系统提供的setResult(int resultCode, Intent data)方法实现:

public class NewActivity extends Activity {

@Override

protected void onCreate(Bundle savedInstanceState) {

button.setOnClickListener(new View.OnClickListener(){

public void onClick(View v) {

Intent intent = new Intent();//数据是使用Intent返回

intent.putExtra(resultcsdn);//把返回数据存入Intent

NewActivity.this.setResult(RESULT_OK, intent);//设置返回数据

NewActivity.this.finish();//关闭Activity

}

});

}

}

setResult()方法的第一个参数值可以根据业务需要自己定义,上面代码中使用到的RESULT_OK是系统Activity类定义的一个常量,值为-1,代码片断如下:

public class android.app.Activity extends ......{

public static final int RESULT_CANCELED = 0;

public static final int RESULT_OK = -1;

public static final int RESULT_FIRST_USER = 1;

}

请求码

使用startActivityForResult(Intent intent, int requestCode)方法打开新的Activity,我们需要为startActivityForResult()方法传入一个请求码(第二个参数)。请求码的值是根据业务需要由自已设定,用于标识请求来源。在onActivityResult()方法如果需要知道新Activity是由那个按钮打开的,并且要做出相应的业务处理,

这时可以这样做:

 @Override  public void onCreate(Bundle savedInstanceState) {

        ....

        button1.setOnClickListener(new View.OnClickListener(){

  public void onClick(View v) {

   startActivityForResult (new Intent(MainActivity.this, NewActivity.class), 1);

   }});

        button2.setOnClickListener(new View.OnClickListener(){

  public void onClick(View v) {

   startActivityForResult (new Intent(MainActivity.this, NewActivity.class), 2);

   }}); 

       @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) {

               switch(requestCode){

                   case 1:

                       //来自按钮1的请求,作相应业务处理

                   case 2:

                //来自按钮2的请求,作相应业务处理

                }

          }

}

 

 

结果码


根据官方文档的说明,RequestCode用来标识打开了哪个Activity,而ResultCode是用来返回被打开的Activity是否完成了任务。在你的例子里,如果打开ResultActivity,那么应该令请求码为1,而打开NewActivity的时候请求码则为2,在MainActivity的onActivityResult函数里,通过判断requestCode判断是哪个Activity的结果,而resultCode用来返回状态,比如用户在NewActivity里面保存了修改,则resultCode返回0,撤销了修改,则返回1,然后在MainActivity里面判断是否完成了操作。

在一个Activity中,可能会使用startActivityForResult()方法打开多个不同的Activity处理不同的业务,当这些新Activity关闭后,系统都会调用前面ActivityonActivityResult(int requestCode, int resultCode, Intent data)方法。为了知道返回的数据来自于哪个新Activity,在onActivityResult()方法中可以这样做(ResultActivityNewActivity为要打开的新Activity)

public class ResultActivity extends Activity {

       .....

       ResultActivity.this.setResult(1, intent);

       ResultActivity.this.finish();

}

public class NewActivity extends Activity {

       ......

        NewActivity.this.setResult(2, intent);

        NewActivity.this.finish();

}

public class MainActivity extends Activity { // 在该Activity会打开ResultActivityNewActivity

       @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) {

               switch(resultCode){

                   case 1:

                       // ResultActivity的返回数据

                   case 2:

               // NewActivity的返回数据

                }

          }

}

实例:联系人

实现要求

点击联系人按钮转入第二个activity,显示第一个activity传入的事件,点击返回将联系人信息返回。

 

 

代码解析:

1.第一个activity布局文件

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:paddingBottom="@dimen/activity_vertical_margin"    android:paddingLeft="@dimen/activity_horizontal_margin"    android:paddingRight="@dimen/activity_horizontal_margin"    android:paddingTop="@dimen/activity_vertical_margin"    tools:context=".SecondActivity" >    <Button        android:id="@+id/button1"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:text="选择联系人"        android:onClick="open" />    <EditText        android:id="@+id/et_name"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_alignParentLeft="true"        android:layout_below="@+id/button1"        android:ems="10" >        <requestFocus />    </EditText></RelativeLayout>

 

2.第二个activity布局文件

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:paddingBottom="@dimen/activity_vertical_margin"    android:paddingLeft="@dimen/activity_horizontal_margin"    android:paddingRight="@dimen/activity_horizontal_margin"    android:paddingTop="@dimen/activity_vertical_margin"    tools:context=".FirstActivity" >    <TextView            android:id="@+id/tv_name"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="aaa" />    <Button        android:id="@+id/button1"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_alignParentRight="true"        android:layout_alignParentTop="true"        android:text="返回"         android:onClick="back"/></RelativeLayout>

 

3.第一个activity主要代码

package com.example.android_activituresultset;import android.os.Bundle;import android.app.Activity;import android.content.Intent;import android.view.Menu;import android.view.View;import android.widget.EditText;public class FirstActivity extends Activity {private EditText et_name;private static final int GETDATAREQESTCODE = 1;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void open(View v) {Intent intent = new Intent();intent.setClass(FirstActivity.this, SecondActivity.class);intent.putExtra("type", "同事");// 必须使用这样的操作startActivityForResult(intent, GETDATAREQESTCODE);et_name = (EditText) findViewById(R.id.et_name);}/** * 获取你返回数据的处理方法 */@Overrideprotected void onActivityResult(int requestCode, int resultCode, Intent data) {// TODO Auto-generated method stubsuper.onActivityResult(requestCode, resultCode, data);switch (requestCode) {case GETDATAREQESTCODE://结果码为1的if (resultCode == 1) {String name = data.getStringExtra("name");et_name.setText(name);}break;default:break;}}}

 

4.第二个activity主要代码

package com.example.android_activituresultset;import android.app.Activity;import android.content.Intent;import android.os.Bundle;import android.view.View;import android.widget.TextView;import android.widget.Toast;public class SecondActivity extends Activity {private TextView tv_name;//结果码private static final int BAKERESULTCODE = 1;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_second);tv_name = (TextView) findViewById(R.id.tv_name);//获取第一个activity中传的值String type = getIntent().getStringExtra("type");Toast.makeText(this, type, Toast.LENGTH_LONG).show();}public void back(View v) {String name = tv_name.getText().toString().trim();// 创建意图对象Intent data = new Intent();// 设置传递数据data.putExtra("name", name);// 设置返回数据this.setResult(BAKERESULTCODE, data);// 关闭activitySecondActivity.this.finish();}}



联系人源码下载地址:http://download.csdn.net/detail/zhaoyazhi2129/7415089

转载请标明原文地址:http://blog.csdn.net/zhaoyazhi2129/article/details/27379407

0 0
原创粉丝点击