摘要:生成插件打开窗口,双击,生成文件生成目录三在宿主应用中加载插件将生成的插件推送通过网络或者等到手机指定路径,如。在宿主应用中加载调用中的未加载插件源码地址
VirtualApk引入步骤:
一、宿主应用引入VirtualApk 1、在项目的build.gradle文件中加入依赖:dependencies { classpath "com.didi.virtualapk:gradle:0.9.8.6" }
完整的gradle文件如下:
// Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript { repositories { google() jcenter() } dependencies { classpath "com.android.tools.build:gradle:3.1.4" classpath "com.didi.virtualapk:gradle:0.9.8.6" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files } } allprojects { repositories { google() jcenter() } } task clean(type: Delete) { delete rootProject.buildDir }2、在app的build.gradle文件中加入依赖:
apply plugin: "com.didi.virtualapk.host" dependencies { implementation "com.didi.virtualapk:core:0.9.8" }
完整的gradle文件如下:
apply plugin: "com.android.application" apply plugin: "com.didi.virtualapk.host" android { compileSdkVersion 28 defaultConfig { applicationId "com.wangyz.virtualapk.host" minSdkVersion 21 targetSdkVersion 28 versionCode 1 versionName "1.0" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro" } } } dependencies { implementation fileTree(dir: "libs", include: ["*.jar"]) implementation "com.android.support:appcompat-v7:28.+" implementation "com.android.support.constraint:constraint-layout:1.0.2" testImplementation "junit:junit:4.12" androidTestImplementation "com.android.support.test:runner:1.0.1" androidTestImplementation "com.android.support.test.espresso:espresso-core:3.0.1" implementation "com.didi.virtualapk:core:0.9.8" }3、新建项目的Application,继承自Application,并在attachBaseContext方法中初始化
public class App extends Application{ @Override protected void attachBaseContext(Context base) { super.attachBaseContext(base); PluginManager.getInstance(base).init(); } }4、在AndroidManifest.xml中引入自定义的Application
5、申明权限
二、Plugin中引入VirtualApk 1、在项目的build.gradle文件中加入依赖:
dependencies { classpath "com.didi.virtualapk:gradle:0.9.8.6" }
完整的gradle文件如下:
// Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript { repositories { google() jcenter() } dependencies { classpath "com.android.tools.build:gradle:3.1.4" classpath "com.didi.virtualapk:gradle:0.9.8.6" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files } } allprojects { repositories { google() jcenter() } } task clean(type: Delete) { delete rootProject.buildDir }2、在app的build.gradle文件中加入依赖:
apply plugin: "com.didi.virtualapk.plugin" virtualApk{ packageId = 0x6f targetHost = "../../VirtualAPKHost/app"//宿主应用的app模块路径 applyHostMapping = true }3、在app的build.gradle文件中加入签名配置
signingConfigs{ release{ storeFile file("../../android.keystore") storePassword "android" keyAlias "android" keyPassword "android" } } buildTypes { release { minifyEnabled false signingConfig signingConfigs.release proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro" } }
完整的gradle文件如下:
apply plugin: "com.android.application" apply plugin: "com.didi.virtualapk.plugin" android { compileSdkVersion 28 defaultConfig { applicationId "com.wangyz.virtualapk.plugin" minSdkVersion 21 targetSdkVersion 28 versionCode 1 versionName "1.0" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" } signingConfigs{ release{ storeFile file("../../android.keystore") storePassword "android" keyAlias "android" keyPassword "android" } } buildTypes { release { minifyEnabled false signingConfig signingConfigs.release proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro" } } } dependencies { implementation fileTree(dir: "libs", include: ["*.jar"]) implementation "com.android.support:appcompat-v7:28.+" implementation "com.android.support.constraint:constraint-layout:1.0.2" testImplementation "junit:junit:4.12" androidTestImplementation "com.android.support.test:runner:1.0.1" androidTestImplementation "com.android.support.test.espresso:espresso-core:3.0.1" } virtualApk{ packageId = 0x6f targetHost = "../../VirtualAPKHost/app" applyHostMapping = true }
注意:Plugin应用的资源文件不能和宿主的资源文件重名,否则在生成插件APK时会报错:
建议各模块资源命名以模块名开头。
4、生成插件APK打开gradle窗口,双击assemblePlugin,生成APK
文件生成目录:app/build/outputs/plugin/release/
三、在宿主应用中加载插件APK 1、将生成的插件APK推送(通过网络或者adb等)到手机指定路径,如/sdcard/Plugin.apk。 2、在宿主应用中加载APKprivate static final String PLUGIN_PACKAGE_NAME = "com.wangyz.virtualapk.plugin"; private static final String PLUGIN_NAME = "com.wangyz.virtualapk.plugin.MainActivity"; private void loadPlugin() { try { String pluginPath = Environment.getExternalStorageDirectory().getAbsolutePath().concat("/Plugin.apk"); File plugin = new File(pluginPath); PluginManager.getInstance(this).loadPlugin(plugin); } catch (Exception e) { e.printStackTrace(); } }3、调用APK中的Activity
public void loadPlugin(View view) { if (PluginManager.getInstance(this).getLoadedPlugin(PLUGIN_PACKAGE_NAME) == null) { Toast.makeText(getApplicationContext(), "未加载插件", Toast.LENGTH_SHORT).show(); return; } Intent intent = new Intent(); intent.setComponent(new ComponentName(PLUGIN_PACKAGE_NAME, PLUGIN_NAME)); startActivity(intent); }
源码地址:https://github.com/milovetingting/Samples/tree/master/VirtualAPK
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/2467.html
摘要:本文是我的重构之旅的第三篇,也是让我最为头疼的一篇,在本文中,我将会和大家聊一聊插件化的概念,以及我们在插件化框架上的选择与碰到的一些问题。 随着项目的不断成长,即便项目采用了 MVP 或是 MVVM 这类优秀的架构,也很难跟得上迭代的脚步,当 APP 端功能越来越庞大、繁琐,人员不断加入后,牵一发而动全局的事情时常发生,后续人员如同如履薄冰似的维护项目,为此我们必须考虑团队壮大后的开...
摘要:第五点更重要,做插件化需要控制两个地方。因此不符合插件化的需求,不作考虑。支持加载外部的或者文件,正好符合文件化的需求,所有的插件化方案都是使用来加载插件中的文件的。方案简单,适用于自身少量代码的插件化改造。年月是手机助手实现的一种插件化 最近几年移动开发业界兴起了「 插件化技术 」的旋风,各个大厂都推出了自己的插件化框架,各种开源框架都评价自身功能优越性,令人目不暇接。随着公司业务快...
摘要:方法,是一个对象是从构造函数中赋值。上面我们分析到会执行构造函数,在构造函数会将的赋值给的。传入的是返回对象也是继承,其是。参考插件化技术原理篇中详解你所不知道的更深层次的理解 Android插件化在国内已不再是几个巨头公司团队在玩了,陆续有团队开源其解决方案,例如 Small,VirtualAPK,RePlugin,Atlas,甚至Lody开发的VirtualApp。另外我司也在玩,...
摘要:再附一部分架构面试视频讲解本文已被开源项目学习笔记总结移动架构视频大厂面试真题项目实战源码收录 Java反射(一)Java反射(二)Java反射(三)Java注解Java IO(一)Java IO(二)RandomAccessFileJava NIOJava异常详解Java抽象类和接口的区别Java深拷贝和浅拷...
摘要:什么样的对象容易找到静态变量和单例。在一个进程之内,静态变量和单例变量是相对不容易发生变化的,因此非常容易定位,而普通的对象则要么无法标志,要么容易改变。 前言 为了实现 App 的快速迭代更新,基于 H5 Hybrid 的解决方案有很多,由于 webview 本身的性能问题,也随之出现了很多基于 JS 引擎实现的原生渲染的方案,例如 React Native、weex 等,而国内一线...
阅读 3620·2021-11-25 09:43
阅读 2288·2021-11-24 10:20
阅读 3413·2021-11-22 15:27
阅读 1729·2021-10-08 10:05
阅读 2278·2021-09-10 10:51
阅读 3266·2021-09-06 15:02
阅读 2886·2019-08-30 15:55
阅读 2728·2019-08-29 18:34