Activity1进入Activity2,Activity2开启Activity3,需要Activity3直接返回数据给Activity1
2016-05-06 08:46
295 查看
android开发中经常会需要处理一些数据传递的问题:
简单的两个activity之间的数据回显,用onActivityResult就行了,这里不多做描述。`
但也有一些情况下是需要在三个activity之间进行数据传递的。如:
Activity1进入Activity2,Activity2开启Activity3,需要Activity3直接返回数据给Activity1,并且关闭activity2,activity3。
首先:
1.在Manifest中将Activity1的启动模式设置为singleTask:
2.从activity3返回到activity1时,不要用finish,直接startActivity,并将数据放进Intent中:
4.注意:由于在activity3返回到activity1时,activity1有可能会被回收,需要在oncreate方法中也要执行下操作:
详情:/article/5355438.html
原理:
1. activity1的启动方式为singleTask时,在栈中存在此activity1,不需要再去重新创建一个实例,而是将activity1置顶,并将上面的所有activity1清空。(因此不用去finish activity2和activity3)
2. launchMode为singleTask的时候,activity3通过Intent开启到activity1,系统已经存在一个activity1实例,系统就会将请求发送到原来的activity1实例上,但这个时候,系统就不会再调用通常情况下我们处理请求数据的onCreate方法,而是调用onNewIntent方法
3. 但是不要忘记,系统可能会随时杀掉后台运行的Activity,如果这一切发生,那么系统就会调用onCreate方法,而不调用onNewIntent方法,一个好的解决方法就是在onCreate和onNewIntent方法中调用同一个处理数据的方法。
简单的两个activity之间的数据回显,用onActivityResult就行了,这里不多做描述。`
但也有一些情况下是需要在三个activity之间进行数据传递的。如:
Activity1进入Activity2,Activity2开启Activity3,需要Activity3直接返回数据给Activity1,并且关闭activity2,activity3。
首先:
1.在Manifest中将Activity1的启动模式设置为singleTask:
android:launchMode="singleTask"
2.从activity3返回到activity1时,不要用finish,直接startActivity,并将数据放进Intent中:
public void click(View view){ Intent intent = new Intent(this, Activity1.class); intent.putExtra("data", "activity3---->回传到activity2"); startActivity(intent); }
3.最重要的一步:在activity1中重写onNewIntent方法: 在方法中将接收到的intent存储起来setIntent; 然后就可以通过getIntent方法进行获取数据的操作了。
@Override protected void onNewIntent(Intent intent) { // TODO Auto-generated method stub super.onNewIntent(intent); setIntent(intent);//一定要有这个方法,否则getIntent收不到数据 Toast.makeText(this,getIntent().getStringExtra("data")+"在onNewIntent中", 0).show(); }
4.注意:由于在activity3返回到activity1时,activity1有可能会被回收,需要在oncreate方法中也要执行下操作:
@Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setContentView(R.layout.activity1); Toast.makeText(this,getIntent().getStringExtra("data")+"在onctreate方法中", 0).show(); }
详情:/article/5355438.html
原理:
1. activity1的启动方式为singleTask时,在栈中存在此activity1,不需要再去重新创建一个实例,而是将activity1置顶,并将上面的所有activity1清空。(因此不用去finish activity2和activity3)
2. launchMode为singleTask的时候,activity3通过Intent开启到activity1,系统已经存在一个activity1实例,系统就会将请求发送到原来的activity1实例上,但这个时候,系统就不会再调用通常情况下我们处理请求数据的onCreate方法,而是调用onNewIntent方法
3. 但是不要忘记,系统可能会随时杀掉后台运行的Activity,如果这一切发生,那么系统就会调用onCreate方法,而不调用onNewIntent方法,一个好的解决方法就是在onCreate和onNewIntent方法中调用同一个处理数据的方法。
相关文章推荐
- java XML转JSON格式
- java.Servlet.GenericServlet中的init方法
- 火车头采集器 页面图片等信息采集
- 大数据实验室(大数据基础培训)——Zookeeper的安装、配置及基础使用
- PHP自学no00007数据类型字符串型之界定符
- 《java入门第一季》之面向对象(final关键字)
- 《java入门第一季》之面向对象(final关键字)
- 最小二乘法
- 大数据实验室(大数据基础培训)——Spark的安装、配置及基础使用
- python实现HTTP 请求
- 大数据实验室(大数据基础培训)——Hadoop的安装、配置及基础使用
- 动态对象创建(new/delete & malloc/free)
- WebView methods on same thread error
- 大数据实验室(大数据基础培训)——基础概念
- php复习-连接数据库做表
- 机器学习、计算机视觉书籍推荐
- 《C++精英内参之程序员高效指南》-1如何管理你的任务
- 基于jquery实现即时检查格式是否正确的表单
- Redis学习总结
- Assertion failure in -[UIApplication _runWithMainScene:transitionContext:completion:], /BuildRoot/Li