Android基本的设计理念是鼓励减少组件间的耦合,因此Android提供了Intent (意图) ,Intent提供了一种通用的消息系统,它允许在你的应用程序与其它的应用程序间传递Intent来执行动作和产生事件。使用Intent可以激活Android应用的三个核心组件:活动、服务和广播接收器。
在一个Activity中可以使用系统提供的startActivity(Intent intent)方法打开新的Activity,在打开新的Activity前,你可以决定是否为新的Activity传递参数:
打开新的Activity,不传递参数
startActivity(new Intent(MainActivity.this, NewActivity.class));
新建一个显式意图,第一个参数为当前Activity类对象,第二个参数为你要打开的Activity类
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 = new Intent();
Bundle bundle = new Bundle();//该类用作携带数据
bundle.putString("name", "CSDN");
intent.putExtras(bundle);//为意图追加额外的数据,意图原来已经具有的数据不会丢失,但key同名的数据会被替换
这种写法使用起来比较方便,而且只需要编写少量的代码。
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对象,下面是Intent的putExtra(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;
}
Intent intent = getIntent();
String username = intent.getStringExtra("username1");
String userpwd = intent.getStringExtra("userpwd1");
Bundle bundle = this.getIntent().getExtras();
String name = bundle.getString("name");
int age = bundle.getInt("age");
在第一个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>
第一个activity的activity主要代码
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; @Override protected 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); } }
第二个activity的activity主要代码
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; @Override protected 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的布局文件 同人品测试
第一个activity的activity主要代码
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 { @Override protected 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); } }
第二个activity的activity主要代码
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 { @Override protected 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 关闭后返回的数据,你需要使用系统提供的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(“result”, “csdn”);//把返回数据存入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的请求,作相应业务处理
}
}
}
在一个Activity中,可能会使用startActivityForResult()方法打开多个不同的Activity处理不同的业务,当这些新Activity关闭后,系统都会调用前面Activity的onActivityResult(int requestCode, int resultCode, Intent data)方法。为了知道返回的数据来自于哪个新Activity,在onActivityResult()方法中可以这样做(ResultActivity和NewActivity为要打开的新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会打开ResultActivity和NewActivity
@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; @Override protected 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); } /** * 获取你返回数据的处理方法 */ @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { // TODO Auto-generated method stub super.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; @Override protected 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); // 关闭activity SecondActivity.this.finish(); } }
联系人源码下载地址:http://download.csdn.net/detail/zhaoyazhi2129/7415089
转载请标明原文地址:http://blog.csdn.net/zhaoyazhi2129/article/details/27379407