首页
/ 封装与优化:优雅地管理`onActivityResult`

封装与优化:优雅地管理`onActivityResult`

2024-05-30 00:22:58作者:蔡怀权

项目介绍

在Android开发中,onActivityResult是一个常见的功能,用于接收启动其他Activity后返回的结果。然而,传统的使用方式往往会导致代码混乱,不易维护。为此,我们推荐一个开源项目——AvoidOnResult,它旨在解决这个问题,提供了一种更优雅、更简洁的方式来处理onActivityResult,让你的代码更具可读性和可维护性。

项目技术分析

该项目巧妙地使用了设计模式和AOP(面向切面编程)思想。核心是将startActivityForResult与处理返回结果的操作绑定在一起,通过回调或RxJava订阅的方式传递结果,从而避免在多个Activity之间重复编写onActivityResult方法。这一改进使得对第三方库中Activity的控制也成为可能,极大地提升了代码复用性。

应用场景

  • 当你需要从一个Activity跳转到另一个Activity并等待返回数据时,例如进行登录、选择图片、身份验证等操作。
  • 在复杂的业务流程中,如购物支付环节,需要在一个集中的地方处理各种结果,避免分散在各个Activity中。
  • 当你需要跨组件或模块共享代码逻辑,尤其是在处理用户交互结果时。

项目特点

  1. 简化回调:通过定义Callback接口,只需在回调中处理结果,无需在每个Activity里重写onActivityResult
  2. 支持RxJava:如果你的项目已经引入了RxJava,那么可以方便地通过链式操作来过滤和处理返回结果,使代码更加整洁、易读。
  3. 兼容性广泛:无论是自定义Activity还是第三方库中的Activity,都能轻松接入,实现结果的统一处理。
  4. 易于集成:添加Jitpack仓库和依赖项即可快速导入项目,无额外复杂配置。

集成步骤

  1. 在你的根级build.gradle文件中添加Jitpack仓库:

    allprojects {
        repositories {
            ...
            maven { url 'https://jitpack.io' }
        }
    }
    
  2. 在应用级别的build.gradle文件中添加依赖:

    dependencies {
        implementation 'com.github.AnotherJack:AvoidOnResult:1.0.0'
    }
    

使用示例

回调方式

new AvoidOnResult(activity).startForResult(XXActivity.class, new AvoidOnResult.Callback() {
    @Override
    public void onActivityResult(int resultCode, Intent data) {
        if (resultCode == Activity.RESULT_OK){
            // 获取并处理数据
        } else {
            // 处理其他结果
        }
    }
});

RxJava方式

new AvoidOnResult(activity).startForResult(XXActivity.class)
        .filter(new Predicate<ActivityResultInfo>() {
            @Override
            public boolean test(ActivityResultInfo activityResultInfo) throws Exception {
                return activityResultInfo.getResultCode() == Activity.RESULT_OK;
            }
        })
        .subscribe(new Observer<ActivityResultInfo>() {
            @Override
            public void onSubscribe(Disposable d) {}

            @Override
            public void onNext(ActivityResultInfo activityResultInfo) {}

            @Override
            public void onError(Throwable e) {}

            @Override
            public void onComplete() {}
        });

如果你正在寻找一种更好的方式来管理onActivityResult,不妨试试这个开源项目,让代码变得更加优雅。如果你觉得有用,别忘了给项目点个Star哦!

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
184
266
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
138
189
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
887
528
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
370
384
Git4ResearchGit4Research
Git4Research旨在构建一个开放、包容、协作的研究社区,让更多人能够参与到科学研究中,共同推动知识的进步。
HTML
19
0
kernelkernel
deepin linux kernel
C
22
6
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
337
1.11 K
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.08 K
0
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
84
4
harmony-utilsharmony-utils
harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
ArkTS
61
2