鸿蒙手机cordova-plugin-camera不能拍照和图片不显示问题

鸿蒙手机cordova-plugin-camera不能拍照和图片不显示问题

一、运行环境

1、硬件

手机型号:NOVA 7

系统:HarmonyOS版本 4.0.0

2、软件

android SDK platforms:14.0(API Level 34)、13.0(API Level 33)

SDK Build-Tools: 33.0.3

JDK 17

Cordova-android-version:12.0.1

cordova-plugin-camera:7.0.0

二、运行拍照功能错误并且图片仅显示为图标

在基于cordova平台采用cemara最新版本插件开发拍照功能时,出现以下错误:

用推荐的FILE_URI模式,显示图库图片时,只显示为一个图标,不能正确显示图片;

并且运行"拍照"功能,会出现错误:

三、问题解决

对于FILE_URI只显示图标,可能原因为Android11后限制了目录访问权限?(有待研究)

解决方法:

1、拍照和显示图库都选为DATA_URL方式

2、拍照出错,根据harmonyOS和android的对应版本关系,harmonyOS对应android12(API Level31)

因此,在sdk manager中选择安装了SDK Platform:android12(API Level31)

然后重新新建工程、新增platform和插件,拷入源码运行,拍照功能正常!

目前系统运行环境为:

程序index.js的关键部分源码如下:

cpp 复制代码
document.addEventListener('deviceready', onDeviceReady, false);
function onDeviceReady() {
    // Cordova is now initialized. Have fun!
 document.getElementById("takePicture").addEventListener("touchend", function() {
        navigator.camera.getPicture(onSuccess, onFail, { 
            quality: 50,
            // destinationType: Camera.DestinationType.FILE_URI,
             destinationType: Camera.DestinationType.DATA_URL,
            sourceType: Camera.PictureSourceType.CAMERA,
            correctOrientation: true
        });
    });
    //Use from Library
    document.querySelector("#usePicture").addEventListener("touchend", function() {
        navigator.camera.getPicture(onSuccess, onFail, { 
            quality: 50,
            sourceType: Camera.PictureSourceType.PHOTOLIBRARY,
            destinationType: Camera.DestinationType.DATA_URL//FILE_URI会显示为图标
        });
    });
    function onSuccess(imageData) {
        var image = document.getElementById('myImage');
        image.src = "data:image/jpeg;base64," + imageData;//DATA_URL模式
        // image.src = imageData;//FILE_URI模式
    }

    function onFail(message) {
        alert('错误:'+message);
     }   
}
相关推荐
萌虎不虎1 小时前
【鸿蒙实现显示屏测试实现方法】
华为·harmonyos
用户5951433221774 小时前
HarmonyOS应用开发之滚动容器Scroll
harmonyos
用户5951433221774 小时前
HarmonyOS应用开发之瀑布流、上拉加载、无限滚动一文搞定
harmonyos
用户5951433221774 小时前
鸿蒙应用开发之@Builder自定义构建函数:值传递与引用传递与UI更新
harmonyos
不爱吃糖的程序媛5 小时前
Flutter 开发的鸿蒙AtomGit OAuth 授权应用
华为·harmonyos
xq952710 小时前
编程之路 2025年终总结 ,勇往直前 再战江湖
harmonyos
不爱吃糖的程序媛12 小时前
鸿蒙PC命令行开发 macOS 上解决 pkg-config 命令未安装的问题
macos·华为·harmonyos
二流小码农13 小时前
鸿蒙开发:自定义一个圆形动画菜单
android·ios·harmonyos
yumgpkpm13 小时前
Cloudera CDP7、CDH5、CDH6 在华为鲲鹏 ARM 麒麟KylinOS做到无缝切换平缓迁移过程
大数据·arm开发·华为·flink·spark·kafka·cloudera
不爱吃糖的程序媛13 小时前
解决鸿蒙PC命令行编译 macOS 上 cp 命令参数冲突问题
macos·harmonyos·策略模式