在Flutter插件开发过程中,经常会遇到需要集成第三方aar包的场景。按照正常的Flutter插件的开发流程开发完Flutter插件之后,我们直接运行插件工程,会报一个下面的错误;而直接运行Androidflutter开发的app有哪些工程是不会报错的。
上面报错信息说的是,在构建Flutter aar中不能依赖flutter面试题其他aar。不过,我的情况是本地可以编译apandroid/harmonyosk,但是运行的时候直接奔溃gradle教程。解决问题之前,我们先看android/harmonyos一下Android apk的构建流程。
从上appearance图可以知道,编译器会把source code、jar包、aar包编译到dex文件中去,然后再生成apk。那前面出现的问题是怎么造成的呢,要了解这个,我们看两个问题:
1,问:为什么Flutter Plugin依赖aar编译会报错,而Android原生开发中module依赖aar不会报错? 答: Flutter Application的编译流程中,会把每个plugin中的android相关文件编译成aar,造成了依赖的冲突。对于这种问题,可以使用compileOnly依赖解决。下面看一下implgradle依赖冲突强制指定ementation、api、comflutter开发的app有哪些pileOnly这三者依赖的一个android下载区别:
- implementgradleation:该依赖方式所依赖的库不会传递,只会在当前module中生效。
- api:该依赖方flutter有必要学吗式会传递所依flutter菜鸟教程赖的库,当其他module依赖了该module时,可以flutter面试题使用该module下使用apiflutter是什么意思依赖的库。
- compileOnly只在编译时有效,不会参与打包。
2,问:有什么办法绕过aar编译到Flutter Plugin中吗? 答:我的解决思路是:把aar文件依赖到Android Application中去编译,Plugin中仅仅做compileOnly依赖,然后把aar解压成jar和资源文件放入flutter_plugin中。
为了达到这一目的,我们需要自定义gradle脚本,在build.gradle文件gradle项目绕过plugin中编译aargradle是什么,自定义的aar_toolgradle文件夹可以删吗s.gflutteringradle代码如下:
static aarFileCopy(String srcPathStr, String desPathStr) {
try {
FileInputStream fis = new FileInputStream(srcPathStr)
FileOutputStream fos = new FileOutputStream(desPathStr)
byte[] datas = new byte[1024 * 8]
int len = 0;
while ((len = fis.read(datas)) != -1) {
fos.write(datas, 0, len)
}
fis.close()
fos.close()
} catch (Exception e) {
e.printStackTrace()
}
}
copyAar2Host('com.avatr.track_flutter')
void copyAar2Host(String pluginGroup) {
Project currentProject = null
Project appProject = null
rootProject.allprojects.each {
p ->
boolean isApp = p.plugins.hasPlugin("com.android.application")
if (p.group == pluginGroup) {
currentProject = p
}
if (isApp) {
appProject = p
}
}
Set aarFiles = new HashSet<>()
if (appProject != null && currentProject != null) {
File libs = new File("${currentProject.projectDir}", 'libs')
if (libs.isDirectory()) {
libs.listFiles().each {
f ->
if (f.name.endsWith('.aar')) {
aarFiles.add(f)
}
}
}
if (!aarFiles.isEmpty()) {
File applibs = new File("${appProject.projectDir}${File.separator}libs");
if (!applibs.isDirectory()) {
applibs.mkdirs()
}
aarFiles.each {
f ->
File copyAar = new File("${appProject.projectDir}${File.separator}libs", f.name)
if (!copyAar.exists()) {
copyAar.createNewFile()
aarFileCopy(f.path, copyAar.path)
} else {
// 可以读取aar中的manifest处理aar包版本的问题,
}
}
appProject.dependencies {
implementation fileTree(dir: "${appProject.projectDir}${File.separator}libs", include: ['*.jar', '*.aar'])
}
}
}
}
repositories {
flatDir {
dirs 'libs'
}
}
注意修改里面对应的插件的名称,然后将这个自定义的aar_tools.gradle放到和build.gradle一级的目录android是什么手机牌子,然后在build.gradle中引入自定义的aar_tools.gradle。
apply from : './aar_tools.gradle'
如下图。
最后,我们再次运行flutter_appgradle安装与配置,就可以正常运行了。