记录鸿蒙相机输出预览流报错问题(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;
}
相关推荐
鸿蒙开发19 小时前
鸿蒙(HarmonyOS NEXT)表单校验别再手撸正则了 —— 我写了个 ArkTS 版 zod
harmonyos
TrisighT19 小时前
ArkTS 的 @BuilderParam 你八成只用了皮毛——那个尾随闭包写法差点被我当 bug 删了
harmonyos·arkts·arkui
ONEDAY2 天前
HarmonyOS 多 Product 构建实践:一套代码生成多个产物
harmonyos
TT_Close2 天前
别劝退了!5秒搞定 Flutter 鸿蒙 FVM 起跑线
flutter·harmonyos·visual studio code
TrisighT2 天前
ArkTS 列表滚动时为什么会闪现旧数据?我扒了 LazyForEach 的复用逻辑
harmonyos·arkts·arkui
MonkeyKing2 天前
鸿蒙ArkTS深度剖析:ArkTS与TS/JS核心差异、静态强类型实战优势
typescript·harmonyos
TrisighT2 天前
Electron鸿蒙PC上写日志文件,我被权限和路径坑了两次
electron·harmonyos
TrisighT3 天前
一个下午搞定 ArkTS 折叠面板?结果我从两点写到晚上九点
harmonyos·arkts·arkui
花椒技术5 天前
HJPusher / HJPlayer SDK 实践:我们为什么把直播推播链路拆成一套可复用能力
设计模式·harmonyos·直播
一维Ace6 天前
HarmonyOS ArkTS 按钮组件全解:Button、Toggle 状态交互实战
harmonyos