手写一个模块化框架SimpleModuleRouter

简介

SimpleModuleRouter,路由式框架,为多模块开发提供了便利,方便主app与module之间,以及各module之间像http请求一样(包含请求url,参数,回调)调用各自的功能,并且可以像rxjava一样控制调用功能和回调功能执行的线程。话不多说,直接上代码

 //请求地址
            String url = "kb51://module1/fun1";

            // 拼接参数
            SmrParamsBody smrParamsBody = new SmrParamsBody()
                    .set("p1", "我是主壳传来的数据")
                    .set("p2", "ssss");

            // 发起请求module1的功能,带有线程切换
            SmrRequestClient.build().
                    requestOnThread(SchedulerType.MAIN_THREAD).
                    responseOnThread(SchedulerType.MAIN_THREAD).
                    call(this, url, smrParamsBody, new SmrResponseCallBack() {
                        @Override
                        public void response(Object data)  {
                            Log.v("smr1", "responsethread" + Thread.currentThread().getName());
                            tv1.setText("当前处于主壳页面,module1返回的数据是:" + ((SmrParamsBody) data).get("m1"));
                        }
                    });

为什么要搞这框架呢?
随着公司app参入的模块越来越多,一个app分成了商场模块,认证模块等等,越来越不适合放到一个模块里,并且,业务逻辑上的这些模块,也需要互相调用,正好笔者以前也看过些butterKnife,Rxjava这些主流框架的源码,就迫不及待想小试牛刀。

假如不适用模块化框架,把业务上划分的模块独立成例如module1和modul2,开发的时候,可能modul和module之间,module和主app module1之间少不了互相调用

使用前.png

使用后.png

工程目录如下划分的:


目录一.png

使用步骤:

  1. 配置apt
    (1) .工程整体的build.gradle中配置如下
buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.3.0'
        classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

(2) .主壳的build.gradle中配置如下

apply plugin: 'com.android.application'
apply plugin: 'com.neenbedankt.android-apt'
.......
dependencies {
   ........
    compile project(':SimpleModuleRouter')
    compile project(':SimpleModuleRouter-annotations')
    apt project(':SimpleModuleRouter-compiler')
    compile project(':Module1')
    compile project(':Module2')
}

2.模块也就是示例中的modul1和modul2中的build.gradle中导入SimpleModuleRoute

dependencies {
   ........
    apt project(':SimpleModuleRouter-compiler')
   }

3.注册模块功能
示例如下代码:在Module1中,实现一个SmrModule的实现类,在register注册这个模块要提供的功能,和启动url

public class SmrModuleApp implements SmrModule {


    @Override
    public void register(SmrApplication app) {

        app.register("kb51://module1/fun1", new SmrHandler() {
            @Override
            public void handle(SmrRequestContext smrRequestContext) throws Exception {

                //Log.v("smr1",smrRequestContext.getParams().get("p1").toString());

                //返回数据给调用方
                //smrRequestContext.responseCall(new SmrParamsBody().set("md1","模块1发回的数据"));

                Navigation.navigateToMain(smrRequestContext);

            }
        });

    }

}

在主壳Application中注解添加全限定命

@SmrLoadModule(modules={"zm.myp.smr.m1.SmrModuleApp","zm.myp.smr.module2.SmrModuleApp"})
public class App extends Application {

    @Override
    public void onCreate() {
        super.onCreate();
        //启动加载组件
        SmrApplication.loadModules(this);
    }
}

注册好之后,这样无论主壳app还是module2都可以调用这个功能,调用如下
4.调用

 //请求地址
            String url = "kb51://module1/fun1";

            // 拼接参数
            SmrParamsBody smrParamsBody = new SmrParamsBody()
                    .set("p1", "我是主壳传来的数据")
                    .set("p2", "ssss");

            // 发起请求module1的功能,带有线程切换
            SmrRequestClient.build().
                    requestOnThread(SchedulerType.MAIN_THREAD).
                    responseOnThread(SchedulerType.MAIN_THREAD).
                    call(this, url, smrParamsBody, new SmrResponseCallBack() {
                        @Override
                        public void response(Object data)  {
                            Log.v("smr1", "responsethread" + Thread.currentThread().getName());
                            tv1.setText("当前处于主壳页面,module1返回的数据是:" + ((SmrParamsBody) data).get("m1"));
                        }
                    });

如果不用reqesutOnThread和responseOnThread,那么默认在主线程中

具体工程代码请查看github链接:
https://github.com/zmMyp/SimpleModuleRouter

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容