赞
踩
在Android应用中,有时需要从一个Activity向另一个Activity传递数据,并在第二个Activity处理后将结果传递回第一个Activity。
这种情况下,我们可以使用startActivityForResult()
和onActivityResult()
方法来实现数据回传。
创建新的Android项目:
打开Android Studio并创建一个新的Android项目,确保选择适当的项目名称和包名。
创建两个Activity:
在项目中创建两个Activity,一个用于发送数据,另一个用于接收和处理数据。
右键单击app
文件夹,然后选择New
> Activity
来创建这些Activity。
创建两个Activity:在项目中创建两个Activity,一个用于发送数据,另一个用于接收数据。分别命名它们为SendDataActivity
和ReceiveDataActivity
。
设计SendDataActivity界面:在activity_send_data.xml
中设计SendDataActivity的界面,添加一个EditText和一个Button,用于输入数据并发送它。
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".SendDataActivity"> <EditText android:id="@+id/editText" android:layout_width="match_parent" android:layout_height="wrap_content" android:hint="Enter data to send" android:layout_centerVertical="true" android:layout_centerHorizontal="true" /> <Button android:id="@+id/sendButton" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Send Data" android:layout_below="@id/editText" android:layout_centerHorizontal="true" android:layout_marginTop="16dp" /> </RelativeLayout>
实现效果
activity_receive_data.xml
中设计ReceiveDataActivity的界面,添加一个TextView用于显示接收到的数据。<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".ReceiveDataActivity"> <TextView android:id="@+id/receivedDataTextView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerInParent="true" android:text="这里将显示接收到的值" android:textSize="24sp" android:textColor="#FF5733" android:textStyle="bold" android:letterSpacing="0.05" android:lineSpacingExtra="8dp" android:background="#F2F2F2" android:padding="16dp" android:drawablePadding="8dp" /> <Button android:id="@+id/returnButton" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="返回数据" android:layout_below="@id/receivedDataTextView" android:layout_centerHorizontal="true" android:layout_marginTop="16dp" /> </RelativeLayout>
实现效果
SendDataActivity.java
中,使用startActivityForResult()
发送数据到ReceiveDataActivity。首先,定义一个 请求码(可以是任何整数)和一个数据键来标识数据。package com.leo.activitytransfer; import androidx.appcompat.app.AppCompatActivity; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.EditText; public class SendDataActivity extends AppCompatActivity { private static final int REQUEST_CODE = 1; private EditText editText; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_send_data); editText = findViewById(R.id.editText); Button sendButton = findViewById(R.id.sendButton); sendButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String dataToSend = editText.getText().toString(); Intent intent = new Intent(SendDataActivity.this, ReceiveDataActivity.class); intent.putExtra("data", dataToSend); startActivityForResult(intent, REQUEST_CODE); } }); } }
ReceiveDataActivity.java
中,使用getIntent()
来接收来自SendDataActivity的数据,并将其显示在TextView中。package com.leo.activitytransfer; import androidx.appcompat.app.AppCompatActivity; import android.content.Intent; import android.os.Bundle; import android.widget.TextView; public class ReceiveDataActivity extends AppCompatActivity { private TextView receivedDataTextView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_receive_data); receivedDataTextView = findViewById(R.id.receivedDataTextView); Intent intent = getIntent(); if (intent != null) { String receivedData = intent.getStringExtra("data"); if (receivedData != null) { receivedDataTextView.setText(receivedData); } } } }
处理回传数据:在SendDataActivity
中,使用onActivityResult()
方法来处理从ReceiveDataActivity
回传的数据。
@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == REQUEST_CODE) {
if (resultCode == RESULT_OK && data != null) {
String receivedData = data.getStringExtra("dataFromReceive");
// 处理回传的数据
System.out.println(receivedData);
}
}
}
在ReceiveDataActivity中回传数据:在ReceiveDataActivity
中,如果需要回传数据给SendDataActivity
,可以通过setResult()
方法进行回传。
@Override
public void onBackPressed() {
// 在返回键按下时回传数据给SendDataActivity
String dataToReturn = "Data from ReceiveDataActivity";
Intent resultIntent = new Intent();
resultIntent.putExtra("dataFromReceive", dataToReturn);
setResult(RESULT_OK, resultIntent);
finish();
}
当然,也可以直接设置返回按钮的响应事件
private TextView receivedDataTextView; private Button returnButton; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_receive_data); receivedDataTextView = findViewById(R.id.receivedDataTextView); returnButton = findViewById(R.id.returnButton); Intent intent = getIntent(); if (intent != null) { String receivedData = intent.getStringExtra("data"); if (receivedData != null) { receivedDataTextView.setText(receivedData); } } returnButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 在按钮点击事件中触发数据回传 String dataToReturn = "Data from ReceiveDataActivity"; Intent resultIntent = new Intent(); resultIntent.putExtra("dataFromReceive", dataToReturn); setResult(RESULT_OK, resultIntent); finish(); } }); }
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools"> <application android:allowBackup="true" android:dataExtractionRules="@xml/data_extraction_rules" android:fullBackupContent="@xml/backup_rules" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/Theme.AppCompat.DayNight" tools:targetApi="31"> <activity android:name=".SendDataActivity" android:exported="true" android:label="@string/app_name" android:theme="@style/Theme.AppCompat.DayNight"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <activity android:name=".ReceiveDataActivity" android:exported="false" /> </application> </manifest>
实现效果
下面我将解释一下原理,并验证是否成功回传了数据。
原理:
SendDataActivity
启动ReceiveDataActivity
时,你使用startActivityForResult()
方法,传递了一个请求码(REQUEST_CODE
)。ReceiveDataActivity
中,当用户按下返回键或者点击returnButton
按钮时,你设置了回传的数据,并调用了setResult()
方法来设置结果码和传递数据。ReceiveDataActivity
调用了finish()
来关闭自身,将数据回传给调用它的SendDataActivity
。SendDataActivity
中,你实现了onActivityResult()
方法,在这个方法中,你检查返回的请求码和结果码,如果它们符合预期,就从data
中提取回传的数据。验证是否成功回传了数据:
ReceiveDataActivity
中,你在按钮点击事件和onBackPressed()
方法中都设置了回传数据。这确保了不论用户是点击按钮还是返回键,都会回传数据。SendDataActivity
中,你实现了onActivityResult()
方法,用于接收回传的数据。要验证是否成功回传了数据,你可以按照以下步骤进行:
SendDataActivity
。SendDataActivity
中输入一些数据,然后点击发送按钮。ReceiveDataActivity
,并将数据传递给它。ReceiveDataActivity
中,你可以看到传递的数据显示在receivedDataTextView
中。ReceiveDataActivity
将被关闭,并将数据回传给SendDataActivity
。SendDataActivity
的onActivityResult()
方法中,你会看到回传的数据。你已经在这个方法中使用了System.out.println()
来打印数据,所以你可以在控制台中看到打印的数据。如果你看到控制台中输出的数据是"返回的数据 Data from ReceiveDataActivity",那就表示成功回传了数据。这就是验证是否成功回传了数据的方式。
请确保在
SendDataActivity
中使用正确的请求码(REQUEST_CODE
),并检查回传的结果码和数据是否符合你的预期,以确保数据回传的成功与否。
如果要实现图片选择和显示功能,我们可以使用Android的图像选择器来实现。在接收数据的Activity中,启动图像选择器,然后在成功选择图像后,将图像的URI传递给发送数据的Activity。
1. 在AndroidManifest.xml中添加权限:
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
这是为了获取访问外部存储的权限。
2. 创建placeholder_image.xml文件:
为了在ImageView中显示默认的占位图像,我们可以直接在虚拟机中拍照
3. 修改布局文件:
activity_send_data.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:padding="16dp" tools:context=".SendDataActivity"> <EditText android:id="@+id/editText" android:layout_width="match_parent" android:layout_height="wrap_content" android:hint="Enter text..." android:layout_marginBottom="16dp" /> <Button android:id="@+id/sendButton" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Send Data" android:layout_below="@id/editText" /> <!-- 添加一个按钮来选择图片 --> <Button android:id="@+id/chooseImageButton" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Choose Image" android:layout_below="@id/sendButton" android:layout_marginTop="16dp" /> <!-- 用于显示选择的图片 --> <ImageView android:id="@+id/selectedImageView" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_below="@id/chooseImageButton" android:layout_marginTop="16dp" android:visibility="gone" /> </RelativeLayout>
这里我们添加了一个ImageView
用于显示选择的图片,并添加了一个按钮用于触发图片选择操作。
实现效果
activity_receive_data.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:padding="16dp" tools:context=".ReceiveDataActivity"> <TextView android:id="@+id/receivedDataTextView" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginBottom="16dp" android:text="" /> <Button android:id="@+id/returnButton" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Return Data" android:layout_below="@id/receivedDataTextView" /> <!-- 添加一个ImageView来显示选择的图片 --> <ImageView android:id="@+id/receivedImageView" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_below="@id/returnButton" android:layout_marginTop="16dp" android:visibility="gone" /> </RelativeLayout>
3. 修改activity文件:
SendDataActivity.java
package com.leo.transfer; import android.content.Intent; import android.graphics.Bitmap; import android.net.Uri; import android.os.Bundle; import android.provider.MediaStore; import android.view.View; import android.widget.Button; import android.widget.EditText; import android.widget.ImageView; import androidx.annotation.Nullable; import androidx.appcompat.app.AppCompatActivity; public class SendDataActivity extends AppCompatActivity { private static final int REQUEST_CODE = 1; private EditText editText; private ImageView selectedImageView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_send_data); editText = findViewById(R.id.editText); Button sendButton = findViewById(R.id.sendButton); selectedImageView = findViewById(R.id.selectedImageView); // 添加ImageView的引用 sendButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String dataToSend = editText.getText().toString(); Intent intent = new Intent(SendDataActivity.this, ReceiveDataActivity.class); intent.putExtra("data", dataToSend); startActivityForResult(intent, REQUEST_CODE); } }); // 添加按钮点击事件来选择图片 Button chooseImageButton = findViewById(R.id.chooseImageButton); chooseImageButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 打开系统图库应用 openGallery(); } }); } // 打开系统图库应用 private void openGallery() { Intent intent = new Intent(Intent.ACTION_PICK, MediaStore.Images.Media.EXTERNAL_CONTENT_URI); startActivityForResult(intent, REQUEST_CODE); } @Override protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) { super.onActivityResult(requestCode, resultCode, data); if (requestCode == REQUEST_CODE) { if (resultCode == RESULT_OK) { if (data != null) { String receivedData = data.getStringExtra("dataFromReceive"); // 处理回传的文本数据 // ... // 处理回传的图片数据 Uri selectedImageUri = data.getData(); if (selectedImageUri != null) { Intent intent = new Intent(SendDataActivity.this, ReceiveDataActivity.class); intent.putExtra("dataFromSend", receivedData); intent.putExtra("imageUri", selectedImageUri.toString()); startActivityForResult(intent, REQUEST_CODE); } } } } } }
这个代码中,我们首先在onCreate
方法中初始化了ImageView
和按钮。然后,在按钮的点击事件中,我们启动了图库选择图片的意图。
在onActivityResult
方法中,我们检查是否返回了正确的请求码(REQUEST_CODE
)和结果码。如果一切正常,我们获取选中的图片的URI,并使用MediaStore.Images.Media.getBitmap()
方法将图片加载到ImageView
中,从而显示出来。
ReceiveDataActivity.java
package com.leo.transfer; import android.content.Intent; import android.graphics.Bitmap; import android.net.Uri; import android.os.Bundle; import android.provider.MediaStore; import android.view.View; import android.widget.Button; import android.widget.ImageView; import android.widget.TextView; import androidx.appcompat.app.AppCompatActivity; public class ReceiveDataActivity extends AppCompatActivity { private TextView receivedDataTextView; private ImageView receivedImageView; private Button returnButton; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_receive_data); receivedDataTextView = findViewById(R.id.receivedDataTextView); receivedImageView = findViewById(R.id.receivedImageView); // 添加ImageView的引用 returnButton = findViewById(R.id.returnButton); Intent intent = getIntent(); if (intent != null) { String receivedData = intent.getStringExtra("dataFromSend"); if (receivedData != null) { receivedDataTextView.setText(receivedData); } String imageUriString = intent.getStringExtra("imageUri"); if (imageUriString != null) { Uri imageUri = Uri.parse(imageUriString); try { Bitmap bitmap = MediaStore.Images.Media.getBitmap(this.getContentResolver(), imageUri); receivedImageView.setVisibility(View.VISIBLE); receivedImageView.setImageBitmap(bitmap); } catch (Exception e) { e.printStackTrace(); } } } returnButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 在按钮点击事件中触发数据回传 String dataToReturn = "Data from ReceiveDataActivity"; Intent resultIntent = new Intent(); resultIntent.putExtra("dataFromReceive", dataToReturn); setResult(RESULT_OK, resultIntent); finish(); } }); } @Override public void onBackPressed() { // 在返回键按下时回传数据给SendDataActivity String dataToReturn = "Data from ReceiveDataActivity"; Intent resultIntent = new Intent(); resultIntent.putExtra("dataFromReceive", dataToReturn); setResult(RESULT_OK, resultIntent); finish(); } }
现在,我们的应用程序能够允许用户选择图片,并在ReceiveDataActivity
中显示它。按照以下步骤验证:
SendDataActivity
。SendDataActivity
中点击 “Select Image” 按钮。ReceiveDataActivity
的ImageView
中。实现效果
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。