赞
踩
官方文档:https://nativesupport.dcloud.net.cn/NativePlugin/course/android
刚开始接手uniapp项目的时候遇到一些uniapp无法实现的功能,需要调用原生安卓方法,官方文档看的我一头雾水。
查阅大量文章后总结出一套切实可行的方案
下载uniapp安卓官方SDK,是个百度云链接,做好心理准备。解压完成如下图所示
打开Android Studio File->new->Import Project ->选择UniPlugin-Hello-AS工程,等待Gradle同步完成
同步完成如图所示
原工程没有添加AndroidX支持,需要先转化为AndroidX工程,点击Android Studio Refactor->Migrate to AndroidX
点击Migrate等待即可
以上如果没有问题的话就可以开发原生插件了,下面以uniapp调用安卓原生相册为例:
选择Android Library
填写相关信息Finish
等待Gradle同步完成
拷贝app/lib目录下uniapp-release.aar文件到module/lib中
引入aar文件,module/build.gradle添加如下代码,等待同步完成
在module中创建文件,继承WXModule类,点击OK
在文件中添加方法
- JSCallback jsCallback;
- String path="";
- @JSMethod(uiThread = true)
- public void setImage(JSCallback jsCallback){
- this.jsCallback=jsCallback;
- if(mWXSDKInstance != null && mWXSDKInstance.getContext() instanceof Activity) {
- Intent intent = new Intent();
- intent.setAction(Intent.ACTION_PICK);
- intent.setType("image/*");
- ((Activity)mWXSDKInstance.getContext()).startActivityForResult(intent, 0);
- }
- }
-
- @Override
- public void onActivityResult(int requestCode, int resultCode, Intent data) {
- if(requestCode == 0) {
- Uri uri=data.getData();
- path =RealPathFromUriUtils.getRealPathFromUri(mWXSDKInstance.getContext(), data.getData());
- jsCallback.invoke(path);
- }
- super.onActivityResult(requestCode, resultCode, data);
- }
在app/dcloud_uniplugins.json文件中添加插件信息
打开HBuilderX,务必保证使用最新uniapp安卓原生SDK以及HBuilderX最新版本
新建uniapp项目,写一个按钮用于打开相册
使用uniapp方法显示选择照片的路径
选择本地打包 等待编译完成
将整个文件夹复制到app/apps目录下
点击Android Studio的运行按钮,安装自定义基座,如下图所示
运行自定义基座
点击按钮跳转原生页面
显示照片路径
1.本地打包之前需要登录dcloud账号,如果出现appid不一致的问题,需要到uniapp工程中的mainifest.json中重新获取appid
2.调用原生Activity交互,和创建普通Activity一样,只不过需要继承Activity而不能继承AppCompatActivity否则出现白屏问题
3.有任何问题私信我
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。