在一个 Activity 中改变另一个 Activity 的 UI

在一个 Activity 中更改另一个 Activity 的 UI 可以让两个 Activity 共享一个 Handler 达到其效果,这里介绍的是另一种方法。
使用场景是点击主界面的按钮进入第二个界面,在第二个页面进行相关操作返回后,主界面的 UI 或数据会发生改变。

主要用到的方法是 startActivityForResult

Demo

第一个页面的设置

1. 在主布局文件中创建一个 Button(用于进入第二个 Activity),一个 TextView (用于在启动第二个 Activity 后显示改变 Text)
1
2
3
4
5
6
7
8
9
10
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="点击进入另一个 Activity "
android:id="@+id/botton_aty"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!"
android:id="@+id/textView" />
2. 为 Button 设置点击事件
1
2
3
4
5
6
7
8
9
10
11
12
button = (Button) findViewById(R.id.botton_aty);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
switch (view.getId()){
case R.id.botton_aty:
Intent intent = new Intent(MainActivity.this,AnotherAty.class);
requesdCode = 0; //需提前定义一个:‘private int requesdCode;’
startActivityForResult(intent,requesdCode); //这里用 startActivityForResult 的主要原因就是它可以回传数据。
}
}
});

第二个页面的设置

1. 设置另一个 Activity 的布局文件
1
2
3
4
5
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="改变第一个 Activity 中 TextView 的值"
android:id="@+id/button"/>
2.设置另一个 Activity 的 Java 文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
public class AnotherAty extends AppCompatActivity {
private int requesdCode = 0;
private Button button;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_another_aty);
button = (Button) findViewById(R.id.button);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent();
setResult(requesdCode,intent);
finish();
}
});
}
}
3. 设置回调方法
1
2
3
4
5
6
7
8
9
//从第二个页面回来的时候会执行 onActivityResult 这个方法 
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
switch (requestCode){
case 0:
textView.setText("发生变化");
textView.setTextSize(50);
}
}

欢迎关注我的博客简书CSDNGitHub