Flutter插件开发过程中,经常会遇到需要集成第三方aar包的场景。按照正常的Flutter插件的开发流程开发完Flutter插件之后,我们直接运行插件工程,会报一个下面的错误;而直接运行Androidflutter开发的app有哪些工程是不会报错的。

关于Flutter 插件依赖其他aar文件编译报错的解决方案
上面报错信息说的是,在构建Flutter aar中不能依赖flutter面试题其他aar。不过,我的情况是本地可以编译apandroid/harmonyosk,但是运行的时候直接奔溃gradle教程。解决问题之前,我们先看android/harmonyos一下Android apk的构建流程。

关于Flutter 插件依赖其他aar文件编译报错的解决方案

从上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 插件依赖其他aar文件编译报错的解决方案

最后,我们再次运行flutter_appgradle安装与配置,就可以正常运行了。