In Android, you can jump from one Activity to another and back, with the previous Activity being able to save data and state by default. But this time I want to achieve the same goal by using startActivityForResult, which may seem a bit more complicated, but I can explore the rationale behind startActivityForResult and what to do with it.
The function to implement is as follows: transfer data from Activity A to Activity B, get data from Activity B, and then pass it back to Activity A. Add A “back to page” Button to Activity B. After returning to Activity A, we need to retain the information we entered earlier. We use startActivityForResult to pull Activity B. Activity A will have A wait for Activity B to return.
The specific steps are as follows:
- There is A Button in Activity A. Click the Button to retrieve the data to be transferred to Activity B, encapsulate the data into the Bundle, and call startActivityForResult to transfer the data to Activity B
- Activity A overwrites the onActivityResult function to determine whether requestCode and resultCode are the expected results. If so, fetch the data from the Bundle and redisplay it in Activity A
- In Activity B, retrieve the Intent object from Activity A and fetch the Bundle. Then, retrieve the data field from the Bundle and display it on the current page
- Activity B also has a Button. After clicking the Button, call setResult to return the result and close the current page. So it looks like you’re back to Activity A
1, the implementation of Activity A:
public class ExampleActivity extends Activity { private EditText mEditText; private RadioButton mRb1; private RadioButton mRb2; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main_page_layout); Button button = findViewById(R.id.buttonGoToLayout2); button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { mEditText = findViewById(R.id.editText); Double height = double. ParseDouble (medittext.gettext ().tostring ())); // Get gender String gender = ""; mRb1 = findViewById(R.id.radioButtonMale); mRb2 = findViewById(R.id.radioButtonFemale); if (mRb1.isChecked()) { gender = "M"; } else { gender = "F"; } Intent intent = new Intent(ExampleActivity.this, SecondActivity.class); // Pass the data into the second Activity Bundle = new Bundle(); bundle.putDouble("height", height); bundle.putString("gender", gender); intent.putExtras(bundle); startActivityForResult(intent, 0); }}); } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); if (resultCode == RESULT_OK && requestCode == 0) { Bundle bundle = data.getExtras(); double height = bundle.getDouble("height"); String gender = bundle.getString("gender"); mEditText.setText("" + height); if (gender.equals("M")) { mRb1.setChecked(true); } else { mRb2.setChecked(true); }}}}Copy the code
2, the layout file main_page_layout. XML:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_gravity="center"> <TextView android:id="@+id/textView1" Android :layout_width="match_parent" Android :layout_height="wrap_content" Android :text=" calculate standard weight "Android :paddingTop="20dp" Android :layout_width="wrap_content" Android :layout_width="wrap_content" android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/textView3" android:layout_alignStart="@id/textView1" android:layout_marginTop="38dp" android:layout_below="@id/textView1" android:layout_marginStart="46dp"/> <TextView Android :text=" height :" Android :layout_width="wrap_content" Android :layout_height="wrap_content" Android :id="@+id/textView4" android:layout_alignStart="@id/textView1" android:layout_marginStart="46dp" android:layout_below="@id/textView3" android:layout_marginTop="29dp"/> <EditText android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/editText" android:layout_toEndOf="@id/textView4" android:layout_marginStart="36dp" android:autofillHints="@string/app_name" android:hint="0" android:layout_alignBaseline="@id/textView4"/> <TextView Android :layout_width="wrap_content" Android :layout_height="wrap_content" Android :text=" cm" android:layout_alignBaseline="@id/editText" android:layout_toRightOf="@id/editText" android:layout_marginStart="10dp" /> <RadioButton android:layout_below="@id/textView1" Android :id="@+id/radioButtonMale" Android :text=" male" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignStart="@id/textView1" android:layout_marginTop="30dp" android:layout_marginStart="113dp"/> <RadioButton android:id="@+id/radioButtonFemale" Android :layout_width="wrap_content" Android :layout_height="wrap_content" android:layout_below="@id/textView1" android:layout_toEndOf="@id/radioButtonMale" android:layout_marginLeft="15dp" Android :layout_marginStart=" 30dp" Android :layout_marginStart="49dp"/> <Button Android :text=" margin" android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/buttonGoToLayout2" android:layout_marginTop="90dp" android:layout_below="@id/radioButtonMale" android:layout_alignStart="@id/textView1" android:layout_marginStart="92dp"/> </RelativeLayout>Copy the code
3. Implementation of Activity B:
public class SecondActivity extends Activity {
private Intent mIntent;
private Bundle mBundle;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.second_layout);
mIntent = getIntent();
mBundle = mIntent.getExtras();
// 记得判空
if (mBundle == null) {
return;
}
// 获取Bundle中的数据
double height = mBundle.getDouble("height");
String gender = mBundle.getString("gender");
// 判断性别
String genderText = "";
if (gender.equals("M")) {
genderText = "男性";
} else {
genderText = "女性";
}
// 获取标准体重
String weight = getWeight(gender, height);
// 设置需要显示的文字内容
TextView textView = findViewById(R.id.textView2);
textView.setText("你是一位" + genderText + "\n你的身高是" + height + "厘米\n你的标准体重是" + weight + "公斤");
Button button = findViewById(R.id.buttonGoBack);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// 设置结果,并关闭页面
setResult(RESULT_OK, mIntent);
finish();
}
});
}
// 四舍五入格式化
private String format(double num) {
NumberFormat formatter = new DecimalFormat("0.00");
return formatter.format(num);
}
// 计算标准体重的方法
private String getWeight(String gender, double height) {
String weight = "";
if (gender.equals("M")) {
weight = format((height - 80) * 0.7);
} else {
weight = format((height - 70) * 0.6);
}
return weight;
}
}
Copy the code
4, Activity B layout:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:text="This is the second layout" android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/textView2" android:paddingTop="30dp" android:paddingStart="50dp"/> <Button android:layout_width="wrap_content" Android :layout_height="wrap_content" Android :id="@+id/buttonGoBack" Android :text=" backpage" android:layout_alignStart="@id/textView2" android:layout_below="@id/textView2" android:layout_marginTop="54dp" android:layout_marginStart="52dp"/> </RelativeLayout>Copy the code
But there are three things to note:
-
The second parameter to startActivityForResult (requestCode) passes a value less than 0 and a value greater than 0. Equivalent to calling startActivity, onActivityResult is not called. (2) Pass a value greater than 0, such as 1: The effect is the same as passing 0, and the first argument to onActivityResult is the requestCode we passed through startActivityForResult
-
The second parameter to onActivityResult, resultCode, is returned by the second activity using setResult, and has two common values: RESULT_CANCELED, RESULT_OK (1) RESULT_CANCELED: Activity B fails to start, such as crash (2) RESULT_OK: the return value of Activity B after its successful operation
There is also a less commonly used value: RESULT_FIRST_USER, Android source code for this value is defined as “user-defined activity results” (user-defined), I in the source code global search, not many places to use, picked one or two places to use:
(1) Installfailed. Java under PackageInstaller (related page of apK installation failure)
protected void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); int statusCode = getIntent().getIntExtra(PackageInstaller.EXTRA_STATUS, PackageInstaller.STATUS_FAILURE); If (getIntent().getBooleanExtra(intent.extra_return_result, false)) { . setResult(Activity.RESULT_FIRST_USER, result); finish(); }Copy the code
(2) InstallStaging. Java under PackageInstaller
private void showError() { (new ErrorDialog()).showAllowingStateLoss(getFragmentManager(), "error"); / /... . setResult(RESULT_FIRST_USER, result); }Copy the code
Uninstalleractivity. Java under PackageInstaller (uninstall apK related pages) : there are several Settings in the onCreate method to RESULT_FIRST_USER. Therefore, my understanding is that the business itself is used in some error or invalid scenarios, as defined by the business itself.
3. If the new_task startup mode is set when Activity B is started, Activity A will immediately call back onActivityResult with A resultCode of 0 after Activity B is started. After returning from Activity B setResult, there is no more onActivityResult callback!