Android Small插件化

作者: SimpleFunc | 来源:发表于2019-06-30 14:50 被阅读46次

    2016-05-05 14:00:00

    关于Small

    Small是2015年底新出来的一个插件化App开发方案,适用于将一个APK拆分为多个公共库插件、业务模块插件的场景。

    Small的实现方式:

    . Small的gradle插件生成的是.so包,在初始化的时候会通过.so文件生成zip文件,在由zip文件生成Dex,反射添加到宿主类加载器的dexPathList里面

    . 资源文件处理:Small插件的资源是可以共享的,所有插件可以通过共用一个AssetManager互相访问资源文件,而且通过修改aapt解决了资源Id冲突的问题。

    . 之前的插件化方案都是到宿主工程里先注册Activity占位,然后通过占位Activity将生命周期回调传递给插件的Activity.而Small则是通过替换Activity里 的mInstrumentation对象,在Instrumentation的newActivty实现中实例化了插件的Activity.

    Small的优点:

    1. 所有插件可内置于宿主包中

    2. 插件可以独立开发与调试

    3. 资源彻底分离,并且可以互相访问

    4. 通过URI,宿主可以启动本地化插件,web组件,现在网页和任何自定义的插件,并传递参数

    5. 跨平台,目前已经支持android,IOS及Html5

    使用:

    1.使用Android studio创建一个项目

    2.添加small,在Project的build.gradle中添加

    buildscript {
        repositories {
            jcenter()
        }
        dependencies {
            classpath 'com.android.tools.build:gradle:1.3.0'
            classpath 'net.wequick.tools.build:gradle-small:1.1.0-beta3'
        }
    }
    
    apply plugin: 'net.wequick.small'
    

    3.创建Module:
    因为 Small会根据包名对插件进行归类,所以要求:

    模块命名:”app.*” ,”lib.*” 或 “web.*”

    包名包含:“.app.”, “.lib.” 或 “.web.”

    lib.* 为Android Library模块,app.*为Phone & Tablet模块

    4.配置签名
    在app模块的build.gradle中增加签名配置

    signingConfigs {
        release {
            storeFile file('../sign/release.keystrore’)
            storePassword “…..”
            keyAlias “…”
            keyPassword “…”
        }
    }
    buildTypes {
        release {
            signingConfig signingConfigs.release
        }
    }
    

    5.在app模块增加共享的依赖库,例如support类库
    6.在app模块的Application中配置:

    @Override
    public void onCreate() {
      super.onCreate();
      Small.preSetUp(this);
    }
    

    7.在app模块的assert/bundle.json中声明插件,格式:

    {
      "version": "1.0.0",
      "bundles": [
        {
          "uri": "lib.utils",
          "pkg": "net.wequick.example.small.lib.utils"
        },
        {
          "uri": "app.module1”,
          "pkg": "com.example.mysmall.lib.style"
        }
        {
          "uri": "home",
          "pkg": "net.wequick.example.small.app.home",
          "rules"{
              "page1",".MyPage1",
              "page2","net.wequick.example.small.app.home.MyPage2"
           }
        }
    }
    

    Small 跳转插件页面是通过uri来指定的,一个uri唯一对应一个插件. pkg为包名,若一个插件有多个页面供其他插件或宿主调用,则用rules区分。

    例如:

    启动home插件界面:

    Small.openUri("home", context);
    

    启动home插件中的page1:

    Small.openUri("home/page1", context);
    

    调用的时候也可以传参数:

    Small.openUri("home?from=main", context);
    

    获取参数:

    Uri uri = Small.getUri(this);
    if (uri != null) {
        String from = uri.getQueryParameter("from");
    }
    

    调用Fragment:

    Fragment fragment = Small.createObject("fragment-v4", uri, context);
    

    获取Intent:

    不是直接打开界面,而是从别的地方进入页面,如点击通知

    Intent intent = Small.getIntentOfUri("main",context)
    

    8.编译

    编译插件:

    ./gradlew Build libraries  -q
    

    -q 为安静模式,可以忽略

    打包所有组件:

    ./gradlew buildBundle
    

    编译单个组件:

    ./gradlew :app.main:assembleRelease
    

    然后就可以运行App了

    相关文章

      网友评论

        本文标题:Android Small插件化

        本文链接:https://www.haomeiwen.com/subject/thlbcctx.html