欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

AppCan 项目导入 Android Studio

程序员文章站 2022-05-15 23:39:32
...

PS - 2019/7/7:AppCan AS 项目模板: AppCanBaseProject


只针对最新版本的 AppCan, 重要的还是 具体问题具体分析

我解决问题的几个关键点

  • 看反编译的包
  • 看 Android 跑起来的 log,分析 log
  • 看 appcan-android 的 source code, 看 appcan js source code
  • 缩小问题范围

1. 反编译 AppCan 官方给你打的包

  • 获取反编译后的资源文件

AppCan 项目导入 Android Studio

  • assets 中的目录:
    AppCan 项目导入 Android Studio
  1. error 目录 和 info.xml 以及 widget 这个文件夹是 AppCan 替你生成的,把这些资源原封不动 copy 到你 AS 项目中。清空 widget 文件夹(请务必确保 widget 文件夹中文件没有乱码)

  2. 记住 lib 文件夹下的 .so 文件,这都是要放到你 Android Studio 项目中的, eg:

AppCan 项目导入 Android Studio
3. 导入你在 AppCan 上使用的插件,需要 jar 包 或者通过 build gradle 导入:

AppCan 项目导入 Android Studio
AppCan 项目导入 Android Studio

PS: 添加 .jar 包的时候文件夹中有 AndroidManifest.xmlplugin.xml, AndroidManifest.xml 中代码就添加至项目的 AndroidManifest.xml 文件。 plugin.xml 添加至 res/xml/plugin.xml 中,文件不存在就创建一个。缺失的 jar 包想办法下载,

AppCan 项目导入 Android Studio

2. 代码 copy 到 AS assets\widget 目录下

AppCan 项目导入 Android Studio

3. 几个坑

//设置侧滑
    appcan.window.setSlidingWindow({
        rightSliding : {
            width : 240,
            url : "uexWindow_right.html"
        },
        animationId : '1', //仿QQ侧滑
        bg : '' //仿QQ侧滑;注:res目录为js文件夹同级目录wgtRes
    });

运行这个代码的时候会 crash, 报错 Resources not found, 原因是 AppCan 打包的时候自己添加了一些资源文件到 我们的 .apk 文件中,然后运行时引用。我们新建的 AS 里没有这资源文件,所以报错

(function($) {

    alert("ready  end!");

    appcan.ready(function(){
        alert("ready  ready!");
    }
    window.uexOnload = function(){
                    alert("ready  ready!");
        }
})($);

其中

    appcan.ready(function(){
        alert("ready  ready!");
    }

不运行, 目前不清楚原因,但是代码替换成

    window.uexOnload = function(){
                    alert("ready  ready!");
        }

就可以了

参考链接