startActivityForResult()的用法(超好用啊)

startActivityForResult()的用法(超好用啊)最近做的一个小东西遇到这样的情况,我从一个页面MainActivity修改一些内容,需要跳转到一个新的EditActivity去做修改操作,修改完成后就回到之前的MainActivity,因为信息被修

大家好,又见面了,我是你们的朋友全栈君。

最近做的一个小东西遇到这样的情况,我从一个页面MainActivity修改一些内容,需要跳转到一个新的EditActivity去做修改操作,修改完成后就回到之前的MainActivity,因为信息被修改了,最好还是从服务器上重新获取一下,那么就要在MainActivity里重新获取,假如把重新获取数据的操作放在MainActivity的onStart()方法里,那么MainActivity跳转到其它的地方再回来不需要请求数据的,它也必然会又请求一次,这样就白白的增大了服务器的压力。

也就是说,要能有一个东西能判断,是从哪里跳转回到MainActivity的,这样就能判断是否需要重新进行网络请求了。

这里就要介绍startActivityForResult()方法了。

startActivityForResult(Intent, int)

第一个参数Intent,和普通的startActivity()里的Intent一样,里面放要请求的Activity和可能需要放的数据。

第二个参数int,是一个请求代码,整型的,这个可以自己随便定义,但这个数要大于等于0才行。因为MainActivity有可能会跳转到多个页面,如果这几个页面使用完之后,都需要返回一些信息,那么就必须要有个标识符来表示返回来过的是哪个页面的信息。

 

第二个方法:

setResult(int),setResult(int, Intent)

第一个参数int,是一个返回代码,整型的,这个也是自己随便定义,用来表示这个页面执行之后是个什么情况,是成功还是失败了,还是其它什么的,反正返回一个整型数,自己知道它的含义就行了。

第二个可选参数是一个Intent,可以用来存放数据。

 

第三个方法:

onActivityForResult(int, int, Intent)

这个方法是请求的Activity完成任务被finish()之后,会调用这个,前提是,你启动那个Activity是通过startActivityForResult()来启动的。

第一个参数int,是请求代码,就是startActivityForResult()里面的请求代码。

第二个参数int,是返回代码,就是setResult()方法里面的设置的参数。

第三个参数Intent,就是setResult(int, Intent)里面的放置数据的Intent。

 

详细使用请看下面的demo。

首先是MainActivity.java文件,里面有两个按钮,分别跳转两个Activity。

public class MainActivity extends Activity {
    
    public static final int REQUEST_A = 1;
    public static final int REQUEST_B = 2;
    
    private Button btnA = null;
    private Button btnB = null;
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        //findViewById()云云
        
        //A按钮的监听器
        btnA.setOnClickListener(new OnClickListener() {
            
            @Override
            public void onClick(View arg0) {
                
                //跳转到ActivityA页面
                Intent i = new Intent(MainActivity.this, ActivityA.class);
                
                //发送请求代码REQUEST_A
                startActivityForResult(i, REQUEST_A);
            }
        });
        
        //B按钮的监听器
        btnB.setOnClickListener(new OnClickListener() {
            
            @Override
            public void onClick(View v) {
                
                //跳转到ActivityB页面
                Intent i = new Intent(MainActivity.this, ActivityB.class);
                
                //发送请求代码REQUEST_B
                startActivityForResult(i, REQUEST_B);
            }
        });
    }

    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        
        //先判断是哪个页面返回过来的
        switch (requestCode) {
        case REQUEST_A:
            
            //再判断返回过来的情况,是成功还是失败还是其它的什么……
            switch (resultCode) {
            case ActivityA.RESULT_SUCCESS:
                //成功了
                break;
            case ActivityA.RESULT_FAILED:
                //失败了
                break;
            }
            break;
        case REQUEST_B:
            //同上……
            break;
        }
    }
}

 

接下来是ActivityA.java,这个类里面具体处理一件事情。然后成功失败,把结果返回到MainActivity里面就行了。

public class ActivityA extends Activity {
    
    public static final int RESULT_SUCCESS = 0;
    public static final int RESULT_FAILED = 1;
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //找控件各种……
        
        //我正在干些事情,修改数据啊,各种啊。
        
        //假设数据提交失败了
        boolean result = false;
        
        //设置返回的结果,常量上面都定义好了
        if (result) {
            setResult(RESULT_SUCCESS);
        } else {
            setResult(RESULT_FAILED);
        }
        
        //结束,返回到MainActivity了
        finish();
    }
}

 

ok,说明都写在注释里了,希望对大家有所帮助。

转载请注明出处,哇哈哈哈:http://www.cnblogs.com/kross/p/3469305.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154188.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • DFS 图遍历路径优化分析「建议收藏」

    DFS 图遍历路径优化分析「建议收藏」深度优先搜索是图的遍历的一种重要方法,在一些网络拓补结构、DNA网络等复杂图形分析中有很广泛的应用。传统的深度优先搜索,从某一节点开始,依次遍历此节点所有相邻且未被访问的节点,其下一跳节点的选择往往不是最优的。文章通过对当前节点所有未被访问的下一跳节点计算其到所有未访问节点路径总和,选择最优的一个节点作为下一跳节点,使得深度优先搜索在图的遍历过程中总的搜索路径大大减少。深度优先搜索算法对图的遍历分析图的遍历是指从图的某个节点开始,沿着某条路径对图中所有节点依次访问。解决图的遍历问题,目前主要.

    2022年6月11日
    54
  • 英文斜体复制_斜体英文转换器,斜体英文26个字母可复制

    英文斜体复制_斜体英文转换器,斜体英文26个字母可复制斜体英文在网上用得越来越多,《复仇者联盟4》上映时,很多人在微博上都看到过它里面的经典台词:????????????????????????????????,????????????????????????????????????????????????????????????????????????.还可能看到过:?????????????????????????????????????????????????????????????????????????????????????

    2022年4月29日
    2.0K
  • 智能优化算法:麻雀搜索算法-附代码「建议收藏」

    2020智能优化算法:麻雀搜索算法-附代码文章目录2020智能优化算法:麻雀搜索算法-附代码1.算法原理2.算法结果3.参考文献4.Matlab代码摘要:麻雀搜索算法(SparrowSearchAlgorithm,SSA)是于2020年提出的。SSA主要是受麻雀的觅食行为和反捕食行为的启发而提出的。该算法比较新颖,具有寻优能力强,收敛速度快的优点1.算法原理建立麻雀搜索算法的数学模型,主要规则如下所述:发现者通常拥有较高的能源储备并且在整个种群中负责搜索到具有丰富食物的区域,为所有的加

    2022年4月9日
    44
  • qt创建线程的几种方式_创建一个新线程的方法

    qt创建线程的几种方式_创建一个新线程的方法Java中创建线程主要有三种方式:一、继承Thread类创建线程类(1)定义Thread类的子类,并重写该类的run方法,该run方法的方法体就代表了线程要完成的任务。因此把run()方法称为执行体。(2)创建Thread子类的实例,即创建了线程对象。(3)调用线程对象的start()方法来启动该线程。publicclassFirstThreadTestextendsThread{inti=0;//重写run方法,run方法的方法体就是现场执行体

    2022年8月30日
    1
  • 何时使用或何时不使用malloc函数

    何时使用或何时不使用malloc函数在初学数据结构时,我们往往不太清楚在定义一个结构体指针时要不要使用malloc函数。例如以下的代码:LINKLIST*initlinklist(){LINKLIST*H=NULL;LINKLIST*S;intx;printf(“请输入链表元素或以-1结束输入”)while(x!=-1){s=(LINKLIST*

    2022年6月7日
    30
  • 不安装cudnn可不可以_cuDNN安装「建议收藏」

    不安装cudnn可不可以_cuDNN安装「建议收藏」这个系列写了好几篇文章,这是相关文章的索引,仅供参考:去年上半年配置了一台GTX1080深度学习主机:深度学习主机攒机小记,然后分别写了两篇深度学习环境配置的文章:深度学习主机环境配置:Ubuntu16.04+NvidiaGTX1080+CUDA8.0和深度学习主机环境配置:Ubuntu16.04+GeForceGTX1080+TensorFlow,得到了很多同学留言,不过这个一年…

    2022年5月6日
    184

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号