首页
/ 封装与优化:优雅地管理`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哦!

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

项目优选

收起
kernelkernel
deepin linux kernel
C
27
11
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
466
3.47 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
10
1
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
65
19
flutter_flutterflutter_flutter
暂无简介
Dart
715
172
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
203
81
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.26 K
695
rainbondrainbond
无需学习 Kubernetes 的容器平台,在 Kubernetes 上构建、部署、组装和管理应用,无需 K8s 专业知识,全流程图形化管理
Go
15
1
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
1