记录鸿蒙相机输出预览流报错问题(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;
}
相关推荐
爱吃大芒果7 小时前
从零搭建完整 HarmonyOS 应用实战教程
华为·typescript·harmonyos
richard_yuu7 小时前
鸿蒙首页实战开发|ArkTS 从零搭建治愈系首页、动态问候与功能模块
华为·harmonyos
音视频牛哥11 小时前
SmartMediaKit 鸿蒙NEXT GB28181设备接入SDK
华为·harmonyos·鸿蒙gb28181·鸿蒙next gb28181·鸿蒙gb28181接入·鸿蒙接入gb28181平台·鸿蒙执法记录仪gb28181
key_3_feng14 小时前
鸿蒙车规级MCU开发方案
单片机·华为·harmonyos
大雷神15 小时前
HarmonyOS APP<<古今职鉴定>>开源教程第14篇:碰一碰分享:NFC 近场通信
华为·华为云·harmonyos
想你依然心痛15 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与HMAF的“智流工坊“——低代码可视化智能体编排平台
低代码·华为·harmonyos
richard_yuu16 小时前
鸿蒙ArkUI组件化实战|公共组件封装、复用解耦与上架级UI规范落地
ui·华为·harmonyos
KKei163816 小时前
Flutter for OpenHarmony 学习专注模式APP技术文章
学习·flutter·华为·harmonyos
想你依然心痛16 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与HMAF的“数字孪生工坊“——工业制造AI智能体协同平台
人工智能·制造·harmonyos
UnicornDev16 小时前
【Flutter x HarmonyOS 6】挑战功能的业务逻辑实现
flutter·华为·harmonyos·鸿蒙·鸿蒙系统