uni-app 从小白的角度谈谈Android集成5+SDK的几种方式的应用场景
uni-app 从小白的角度谈谈Android集成5+SDK的几种方式的应用场景
背景
前一段时间因为项目需求,需要从Hbuilder中转移到原生层做开发,无奈只是熟悉一些java概念,但几乎没接触过Android开发,所以折腾了好久的离线打包。在你决定看这片文章之前,应该也要做好使劲折腾的心理准备。同时,最好看这篇文章之前对集成5 +sdk要有一些基本的概念,所以最好先看看下面这几篇文章,可能就不用继续看我的这点东西了。
官方文档
- 最新SDK下载地址
- 独立应用方式集成
- Android平台以Widget方式集成HTML5 SDK方法
- Android平台以WebView方式集成HTML5 SDK方法
- Android平台使用AndroidStudio离线打包说明
- Android平台第三方插件开发指导
开发者分享文章
- 【交流分享】Android独立应用方式集成HTML5 SDK,Widget方式离线打包,空项目讲解
- 【交流分享】Android集成HTML5 SDK,Runtime方式离线打包,空项目讲解
- Android以Widget方式集成自己的hbuilder项目-----Anroid Studio版
相关集成概念
结合所有的官方文档以及官方SDK中的Hello-Integrate项目。我认为,官方对于离线打包有下面的这几种概念(叫法):
- WebView集成方式
- Widget集成方式
- 独立应用集成方式
- runtime集成方式
- webApp集成方式
(截图取自官方文档及运行后的Hello-Integrate项目)
相信我,对于我这种首次接触集成SDK的小白来说,看到这一大堆名词及概念的时候,我是这样的
我猜想这么多的概念(叫法)也许是HB的开发者在开发的过程中遗留的问题,可能是项目组成员变动啊,文档整理人员变动啊巴拉巴拉导致的最终概念没有统一,纯属瞎猜。but……项目需求摆在那里,任务摆在那里,你总要解决对吧,懵逼也得硬着头皮上啊。我们开始折腾吧,先不管上面提到的五种叫法或者概念,直接开搞。
开搞
参照上面的那些文档中的方式,每一种集成弄他至少一遍,折腾的过程中可以查查资料,了解一下安卓原生开发的一些基本概念,比如Activity(关于Activity此处可以参考**@AronWOng** 分享的文章,简洁的介绍了Activity的意思 Android开机自启应用)。或者熟悉下项目的包结构,哪些文件是干啥的,比如Androidmanifest.xml是个什么鬼。折腾了好长一段时间之后,得出了以下的几个结论,注意此结论中并未指定集成方式的叫法(概念),暂时先直接讲要怎么做:
-
如果你只需要离线打包,比如在无法使用HB的云端打包情况下,那么就使用该篇文章中的方式 集成方式a1, 或者集成方式a2,该模式下,不涉及到自己写原生代码,只要按照官方介绍,将自己HB中的项目集成到eclipse或者Android Studio中打包。换种说法就是,如果你没有任何涉及原生开发的需求,并且需要在eclipse或者Android Studio中打包,就采用该模式。
-
如果你有需求会涉及到原生开发,同时又要集成5 + app。以我的项目需求为例,我需要在PDA上开发5 + app,这款PDA就是个基于Android的手机,但是多了一个硬件:扫描器。我需要在App中监听到PDA上的扫描器相关事件,初始化扫描头,开始扫描,获取扫描结果等,并将扫描结果传入5 + App。由于NJS无法实现(或者可以说我不知道怎么使用NJS实现),这个时候我就要采用下面的文章中的做法 集成方式b1或者 集成方式b2。具体实现思路是,我在5 + App对应的Activity中,用java实现对扫描头的监听,并将扫描结果传入5 + app指定的webView,触发js事件,实现5 +app的监听(关于如何在集成SDK后,从java层获取指定webView并传入参数、触发js方法,参考android webApp集成方式 原生主动调用JS方法,此处感谢**@DCloud_SDK_骁骑** 和 @杰世 的无私帮助与解答)
-
如果你已经在原生层开发好了了App,但是可能在原生层的某些需求中,比如单个页面需要使用5 + 的能力,这种时候采用下面文章中的做法集成方式c。
-
如果你需要在5 +App或者说5 +App的某个特定的webView中,通过js调用原生层的方法,并将原生层方法的执行结果返回至js。还是以我的项目为例,还是说PDA,我需要在5 App中主动调用扫描头,并将扫描头扫描的结果传回5 +App,触发相关js方法。那么采用下面文章中的的方式集成方式d。
总结
讲到这里,相信大家会对目前官方的提供的几种操作方式有一定的了解,那么,现在用我的理解来套用官方的概念(叫法)
- 离线打包:只要不是在HB中进行云端打包,其他方式我们都可以理解为离线打包,因为你都要涉及到将5 +SDK集成到原生层。即便是最傻瓜式的该方法 集成方式a1,也是相当于把集成的工作给你做好了而已。
- runtime集成方式,就是离线打包,就是集成方式a1,就是集成方式a2
- 独立应用集成方式,就是Widget集成方式,就是官方SDK中的Hello-Integrate项目里的webApp集成方式,就是 集成方式b1,就是 集成方式b2
- WebView集成方式,就是集成方式c,也可以理解为集成方式d,此处参考官方SDK中的Hello-Integrate项目里的WebView集成方式
- Android平台第三方插件开发指导,就是集成方式d。
最后的话
作为HB的用户已经三个月了,感谢DC提供一款如此好用的工具,衷心希望DC越走越好。同时,该文章参考了论坛中很多其他开发者的总结,在此一并感谢。第一次写,文章格式看起来有点乱,审美比较差导致……最后如果我的总结没有太严重的错误的话,那我觉得官方文档中关于5 +SDK的部分概念说明,是时候改改了,也希望大家指出我的错误
在uni-app中集成5+ SDK(DCloud提供的增强型API集合,主要用于扩展App的原生能力)对于提升应用性能和丰富功能至关重要。对于小白开发者来说,理解不同集成方式及其调用应用场景5是快速上手的关键。以下是几种常见的集成方式及其代码示例,帮助你更好地理解如何在实际项目中使用它们。
1. 直接+ API
这是最简单直接的方式,适用于大部分基础功能集成。uni-app已经封装了大量5+ API,你可以直接在JavaScript代码中调用。
// 示例:调用5+ API获取设备信息
if (window.plus) {
const deviceInfo = plus.device.getInfo();
console.log("设备型号:" + deviceInfo.model);
} else {
console.log("5+ API不可用");
}
2. 使用条件编译
条件编译允许你在不同平台上编写特定代码,对于Android平台特有的功能集成非常有用。
// #ifdef APP-PLUS
// 仅在5+ App平台上运行的代码
plus.android.importClass('android.widget.Toast');
var Toast = plus.android.runtimeMainActivity().getSystemService(plus.android.importClass('android.content.Context').TOAST_SERVICE);
Toast.makeText(plus.android.runtimeMainActivity(), "Hello Android", Toast.LENGTH_SHORT).show();
// #endif
3. 自定义原生插件
当5+ API无法满足需求时,你可以通过自定义原生插件来扩展功能。这种方式适用于复杂或特定硬件相关的功能集成。
步骤简述:
- 创建原生插件(Java/Kotlin编写)。
- 编译插件并生成
.aar
或.jar
文件。 - 在uni-app项目中配置并调用插件。
插件调用示例(假设已配置好插件):
// 调用自定义原生插件的方法
const MyPlugin = window.plus.android.importClass('com.example.MyPlugin');
const myPluginInstance = new MyPlugin();
myPluginInstance.someNativeMethod();
4. 通过Manifest配置
有时需要在manifest.json
中配置一些权限或特性,以便5+ SDK能够正常工作。例如,请求网络权限:
"permissions": {
"AndroidPermissions": [
"android.permission.INTERNET"
]
}
总结
选择哪种集成方式取决于你的具体需求和应用场景。对于基础功能,直接调用5+ API是最简单的方法;对于平台特定的功能,条件编译提供了灵活性;而自定义原生插件则适用于更复杂或特定硬件相关的功能。理解并灵活运用这些集成方式,将帮助你更好地利用uni-app和5+ SDK构建高性能、功能丰富的移动应用。