一个是解决在onActivityResult
中判断requestCode的问题,第二个是让调用代码的地方就知道我是如何处理对方activity
的返回的。 首先我们有一个ResultActivityAdaptor,这个就封装了我的主要的逻辑

public class ResultActivityAdaptor {

    /**
* 起始requestCode,用于兼容有一些老的逻辑,不让request code冲突
*/
private final static int REQUEST_CODE_START=20000; //记录每一次请求的回调方法
private SparseArray<ResultActivityListener> requests=new SparseArray<ResultActivityListener>(); private Activity mActivity; //记录下一个请求的时候会生成的REQUEST_CODE
private int currentReqCode=REQUEST_CODE_START; /**
* 测试
*/
public ResultActivityAdaptor(Activity activity) {
this.mActivity = activity;
} /**
* @param i
* @param listener
*/
public void startActivityForResult(Intent i, ResultActivityListener listener){
currentReqCode++;
requests.put(currentReqCode,listener);
mActivity.startActivityForResult(i,currentReqCode);
} /**
* 调用
* @param requestCode
* @param resultCode
* @param data
*/
public boolean onResult(int requestCode,int resultCode,Intent data){
ResultActivityListener listener=requests.get(requestCode);
if(listener!=null) {
listener.onResult(requestCode, resultCode, data);
//请求完就清除掉
requests.remove(requestCode);
return true;
}
return false;
}
} public interface ResultActivityListener {
public void onResult(int requestCode,int resultCode,Intent data)
}

然后我们可以对我们的activity做如下的封装

/**
* BaseActivity
*/
public class BaseActivity extends Activity { protected ResultActivityAdaptor mResultActivityAdaptor=new ResultActivityAdaptor(this); protected void startActivityWithCallback(Intent intent, ResultActivityListener listener) {
mResultActivityAdaptor.startActivityForResult(intent, listener);
} @Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
mResultActivityAdaptor.onResult(requestCode,resultCode,data);
} /**
* 打开系统的图片选择
*/
protected void openSystemImageGallary(ResultActivityListener listener){
Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
intent.setType("image/*");
startActivityWithCallback(intent, listener);
}
}

这样封装之后,我们可以看到,我们在BaseActivity中调用代码的时候会轻松很多了,
一个是我们给用户隐藏了REQUEST_CODE的这种概念,第二个是我们把我们的调用操作
和我们的回调操作绑定到了一起,在代码阅读和重构/copy的时候带来了很大的便利性

http://www.fanjun.me/?p=582

简化Android的startActivityForResult调用的更多相关文章

  1. Android Fragment StartActivityForresult调用实例

    fragment里面的onActivityResult 怎样才能被调用,很简单,就一句话, startActivityForResult(intent, getActivity().RESULT_FI ...

  2. 使用Frida简化Android端应用安全测试

    @author : Dlive 在对Android应用进行Web漏洞测试时,经常遇到一种情况:HTTP传输的数据带有签名字段 处理这种情况的方法通常是逆向签名算法,但是如果算法在so中,而且so加壳了 ...

  3. Android之startActivityForResult

    作用:当aAty跳转之bAty时,需要bAty回传数据,使用startActivityForResult. 相关的函数: aAty:--跳转至bAty(intent可以传递数据) void andro ...

  4. Android上传图片之调用系统拍照和从相冊选择图片

    Android上传图片之调用系统拍照和从相冊选择图片 本篇文章已授权微信公众号 guolin_blog (郭霖)独家公布 前言: 万丈高楼平底起,万事起于微末.不知不觉距离上篇博文已近四个月,2015 ...

  5. 在Android开发中调用Rest web服务(转)

    首先从维基百科上拷贝一点Rest的基本概念给大家看看,然后我们再开始详解在Android中如何调用Rest服务.表象化状态转变(英文:Representational State Transfer,简 ...

  6. Android之startActivityForResult的使用

    在Android中startActivityForResult主要作用就是: A-Activity需要在B-Activtiy中执行一些数据操作,而B-Activity又要将,执行操作数据的结果返回给A ...

  7. Android 使用AIDL调用外部服务

    好处:多个应用程序之间建立共同的服务机制,通过AIDL在不同应用程序之间达到数据的共享和数据相互操作, 本文包括: 1 .创建AIDL 服务端.2 .创建AIDL 客户端. 3.客户端调用服务端提供的 ...

  8. Android使用KSOAP2调用WebService及正确导入jar包的问题(转)

    Android使用KSOAP2调用WebService及正确导入jar包的问题(转)     错误信息 最近在学Android使用KSOAP2调用现有的Webservice的方法,期间在网上找了很多代 ...

  9. [置顶] android利用jni调用第三方库——第三篇——编写库android程序整合第三方库libhello.so到自己的库libhelloword.so

    0:前言: 在第二篇中,我们主要介绍了丙方android公司利用乙方C++公司给的动态库,直接调用库中的方法,但是这样方式受限于: 乙方C++公司开发的动态库是否符合jni的规范,如果不规范,则不能直 ...

随机推荐

  1. 面试题之redis单线程为什么性能很高

    原因是,使用了多路复用技术. 什么是多路复用技术:多个客户端使用一个信道,并且通过一个信道进行传输

  2. js 打印二维码

    先简单说一下jquery-qrcode,这个开源的三方库(可以从https://github.com/jeromeetienne/jquery-qrcode 获取), qrcode.js 是实现二维码 ...

  3. FZOJ Problem 2110 Star

                                                                                                        ...

  4. php自动获取字符串编码函数mb_detect_encoding

    当在php中使用mb_detect_encoding函数进行编码识别时,很多人都碰到过识别编码有误的问题,例如对与GB2312和UTF- 8,或者UTF-8和GBK(这里主要是对于cp936的判断), ...

  5. POJ 3171 区间覆盖最小值&&线段树优化dp

    Cleaning Shifts Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 4715   Accepted: 1590 D ...

  6. (49)C# npoi-word

    //新建段落 XWPFParagraph p1 = doc.CreateParagraph(); //对齐方式 p1.SetAlignment(ParagraphAlignment.LEFT); p1 ...

  7. 洛谷——P1508 Likecloud-吃、吃、吃

    P1508 Likecloud-吃.吃.吃 题目背景 问世间,青春期为何物? 答曰:“甲亢,甲亢,再甲亢:挨饿,挨饿,再挨饿!” 题目描述 正处在某一特定时期之中的李大水牛由于消化系统比较发达,最近一 ...

  8. 串口VMIN VTIME 详解

    原文地址: 以前跟着做过VxWorks的开发,主要通信方式是串口,因为底层BSP包已经做好了,串口通信非常简单.后来接触Linux,在一块OK6410上跑Linux串口通信,才发现原来天真的以为甚是简 ...

  9. python生成器、迭代器、__call__、闭包简单说明

    1.生成器 这种一边循环一边计算的机制,称为生成器:generator,最简单的方法是把生成式的[]改为(). >>> l=(x * x for x in range(1, 11) ...

  10. free如何知道释放内存长度:vs与glibc分配内存时编译器内部处理

    鉴于网上这个资料实在太少,将以前整理过却未完全的一篇文章贴出来,希望大牛指正vs下内存管理方式.可联系gaoshiqiang1987@163.com vs分配内存 vs没有源码,编译器在分配内存时,分 ...