前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >HarmonyOS 开发实践——基于CameraKit,通过avrecorder进行录像

HarmonyOS 开发实践——基于CameraKit,通过avrecorder进行录像

原创
作者头像
小帅聊鸿蒙
发布2024-11-21 13:58:17
发布2024-11-21 13:58:17
1350
举报
文章被收录于专栏:鸿蒙开发笔记鸿蒙开发笔记

1  场景描述

  录像是相机应用的最重要功能之一,录像是循环帧的捕获。本文通过CameraKit自定义相机并通过avrecorder进行录像。

2  效果图

3  自定义相机录像流程图

4 方案描述

4.1  整体描述:

   总体可分为:1、相机输入,2、同时输出预览流+录像流

1、通过cameraInputt,获取相机采集数据,创建相机输入

2、创建previewOutput,获取预览输出流,通过xcomponent的surfaceid连接,送显xcomponent

3、通过AVrecorder的surfaceid创建录像输出流VideoOutput输出到文件中

4.2   步骤一:通过CameraManager获取相机管理对象

 1、创建CameraManager对象

代码语言:ts
复制
let cameraManager: camera.CameraManager = camera.getCameraManager(context);

2、通过getSupportedCameras 获取相机列表

代码语言:ts
复制
let cameraArray: Array<camera.CameraDevice> = cameraManager.getSupportedCameras();

3、通过getSupportedSceneModes获取支持的模式类型

代码语言:ts
复制
let sceneModes: Array<camera.SceneMode> = cameraManager.getSupportedSceneModes(cameraArray[0]);

4.3 步骤二:通过 cameraManager.createCameraInput获取相机输入

创建相机输入

代码语言:ts
复制
let cameraInput: camera.CameraInput = cameraManager.createCameraInput(cameraArray[0]);

4.4   步骤三:通过cameraManager.createPreviewOutput获取预览输出流

代码语言:ts
复制
let previewOutput: camera.PreviewOutput = cameraManager.createPreviewOutput(previewProfilesArray[0], surfaceId);

4.5   步骤四:获取录像输出流

 4.5.1    步骤一:创建avRcorder的surface

代码语言:ts
复制
let avRecorder: media.AVRecorder = await media.createAVRecorder();
let videoSurfaceId = await avRecorder.getInputSurface();

4.5.2    步骤二: 配置AVRecorderProfile信息

代码语言:ts
复制
let aVRecorderProfile: media.AVRecorderProfile = {
  fileFormat : media.ContainerFormatType.CFT_MPEG_4, // 视频文件封装格式,只支持MP4
  videoBitrate : 100000, // 视频比特率
  videoCodec : media.CodecMimeType.VIDEO_AVC, // 视频文件编码格式,支持avc格式
  videoFrameWidth : 640,  // 视频分辨率的宽
  videoFrameHeight : 480, // 视频分辨率的高
  videoFrameRate : 30 // 视频帧率
};

 4.5.3    步骤三:创建视频录制的参数

代码语言:ts
复制
let aVRecorderConfig: media.AVRecorderConfig = {
  videoSourceType: media.VideoSourceType.VIDEO_SOURCE_TYPE_SURFACE_YUV,
  profile: aVRecorderProfile,
  url: "fd://" + file.fd,//获取文件的fd,且创建的文件要有读写权限
  rotation: 90 // 90°为默认竖屏显示角度,如果由于设备原因或应用期望以其他方式显示等原因,请根据实际情况调整该参数
};

注:预览流与录像输出流的分辨率的宽(videoFrameWidth)高(videoFrameHeight)比要保持一致

4.5.4   步骤四:创建avrecorder和录像输出流videoOutput

代码语言:ts
复制
// 创建avRecorder
let avRecorder: media.AVRecorder = await media.createAVRecorder();
// avRecorder准备
avRecorder.prepare(aVRecorderConfig);
// 创建VideoOutput对象
let videoOutput: camera.VideoOutput | undefined = undefined;
// createVideoOutput传入的videoProfile对象的宽高需要和aVRecorderProfile保持一致。
let videoProfile: undefined | camera.VideoProfile = videoProfilesArray.find((profile: camera.VideoProfile) => {
  return profile.size.width === aVRecorderProfile.videoFrameWidth && profile.size.height === aVRecorderProfile.videoFrameHeight;
});
videoOutput = cameraManager.createVideoOutput(videoProfile, videoSurfaceId);

4.6   步骤五:会话配置

代码语言:ts
复制
//创建会话
let videoSession: camera.CaptureSession | undefined = undefined;
videoSession.beginConfig();
// 向会话中添加相机输入流
videoSession.addInput(cameraInput);
// 向会话中添加预览输出流
videoSession.addOutput(previewOutput);
// 向会话中添加录像输出流
videoSession.addOutput(videoOutput);
// 提交会话配置
videoSession.commitConfig();
// 启动会话
videoSession.start();

4.7   步骤六:开始、停止录像

代码语言:ts
复制
// 启动录像输出流
videoOutput.start()
// 开始录像
avRecorder.start();
// 停止录像
avRecorder.stop();

4.8   步骤七:释放资源

代码语言:ts
复制
// 停止当前会话
videoSession.stop();
// 释放相机输入流
cameraInput.close();
// 释放预览输出流
previewOutput.release();
// 释放录像输出流
videoOutput.release();
// 释放会话
videoSession.release();
// 会话置空
videoSession = undefined;

写在最后

如果你觉得这篇内容对你还蛮有帮助,我想邀请你帮我三个小忙:

  • 点赞,转发,有你们的 『点赞和评论』,才是我创造的动力;
  • 关注小编,同时可以期待后续文章ing🚀,不定期分享原创知识;
  • 想要获取更多完整鸿蒙最新学习知识点,可关注B站:码牛课堂鸿蒙开发;

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1  场景描述
  • 2  效果图
  • 3  自定义相机录像流程图
  • 4 方案描述
    • 4.1  整体描述:
    • 4.2   步骤一:通过CameraManager获取相机管理对象
    • 4.3 步骤二:通过 cameraManager.createCameraInput获取相机输入
    • 4.4   步骤三:通过cameraManager.createPreviewOutput获取预览输出流
    • 4.5   步骤四:获取录像输出流
  • 写在最后
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档