记录鸿蒙相机输出预览流报错问题(CAMERA_SERVICE_FATAL_ERROR)

问题背景

鸿蒙相机按照流程调用数据之后,想将相机数据输出预览画面到鸿蒙的XComponent上面,这里踩了一个坑了,一直报错CAMERA_SERVICE_FATAL_ERROR。这个问题通过官方文档查询错误原因是:相机服务异常。没有相机权限、相机服务重启、跨进程调用异常等。

问题排查

通过系统日志发现错误日志:

bash 复制代码
04-27 15:09:12.173   16262-16262   C01401/com.exa...s/Bufferqueue  com.examp...eancplus  E     <surface_utils.cpp:48-GetSurface>: Cannot find surface, uniqueId: 0.
04-27 15:09:12.173   16262-18181   C02B01/com.exa...ncplus/CAMERA  com.examp...eancplus  I     {OnCameraStatusChanged():197} OnCameraStatusChanged cameraId: device/0, status: 3
04-27 15:09:12.173   16262-16262   C02B01/com.exa...ncplus/CAMERA  com.examp...eancplus  E     {CreatePreviewOutput()-camera_manager_impl.cpp:542} Failed to get previewOutput surface

发现是没有找到surface。最后原因是我弄混了Xcomponent和Surface两个不同的概念,我将Xcomponent的Id作为Surface的Id作为入参surfaceId的值,函数无法找到相应的surface导致的。

关键代码

cpp 复制代码
static napi_value InitSurface(napi_env env, napi_callback_info info) {
    napi_value result;
    size_t typeLen = 0;
    size_t argc = 1;
    napi_value args[1] = {nullptr};
    napi_get_cb_info(env, info, &argc, args, nullptr, nullptr);
    webrtc::ohos::CameraRender *render = webrtc::ohos::CameraRender::getCameraInstance();
    napi_get_value_string_utf8(env, args[0], nullptr, 0, &typeLen);
    render->surfaceId = new char[typeLen + 1]; // 从外部取到surfaceId
    napi_get_value_string_utf8(env, args[0], render->surfaceId, typeLen + 1, &typeLen);
    napi_create_int32(env, argc, &result);
    return result;
}

int32_t OhosCamera::createOutputPreview(webrtc::ohos::CameraRender *render) {
   char* surfaceId = render->surfaceId; // 这里不能取XComponentID
   Camera_ErrorCode ret =  OH_CameraManager_CreatePreviewOutput(camera_manager_, preview_profile_, surfaceId, &preview_output_);
    if(ret != CAMERA_OK) {
        OH_LOG_ERROR(LOG_APP, "createOutputPreview failed.");
        return  -1;
    }
    return 0;
}
相关推荐
不爱吃糖的程序媛11 小时前
鸿蒙服务卡片实战:为新华字典应用添加桌面快捷查询卡片
华为·harmonyos
Davina_yu12 小时前
弹窗交互:AlertDialog与CustomDialog的创建与关闭(11)
harmonyos·鸿蒙·鸿蒙系统
90后的晨仔13 小时前
HarmonyOS 锁屏音频播放完整实践指南
harmonyos
90后的晨仔13 小时前
鸿蒙应用动态桌面图标功能实现完全指南
harmonyos
nashane13 小时前
HarmonyOS 6学习:JsCrash“闪退”法医指南——从FaultLog堆栈还原崩溃现场的终极手册
学习·华为·harmonyos
李二。15 小时前
鸿蒙OS NEXT 批量重命名工具:PC端文件管理的效率革命
华为·harmonyos
HwJack2015 小时前
鸿蒙背景下 Cocos Creator 的三大 JS 引擎:JIT 与热更新的十字路口
javascript·华为·harmonyos
提子拌饭13315 小时前
Column 嵌套布局:多级 Column 实现复杂纵向结构——鸿蒙 HarmonyOS ArkTS 原生学习应用
学习·华为·harmonyos·鸿蒙·鸿蒙系统
前端不太难17 小时前
鸿蒙 App 分布式数据同步:架构设计 + Demo 实现
分布式·状态模式·harmonyos