0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

【技术视界】学习指南:如何快速上手媒体生态一致体验开发

HarmonyOS开发者 来源:未知 2023-11-16 21:15 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

# 技术视界# 【技术视界】栏目为开发者提供华为研发专家对于HarmonyOS关键技术的专业解读,从不同角度、不同方面帮助开发者更好更快地掌握HarmonyOS相关开发知识。本期文章为大家带来的是华为媒体技术工程师的分享,希望为您的开发之路带来启发~

作者:chengcheng,华为媒体技术工程师

过去开发者们在使用多媒体能力时,往往会遇到这样的问题,比如:为什么我开发的相机不如系统相机的效果好?为什么我的应用和其他的音乐一起发声了,我要怎么处理?以及我应该怎么做才能在系统的播控中心里可以看到呢?对于开发者的这些疑问,HarmonyOS通过提供简单易用体验一致的生态接口,使得开发者可以轻松解决上述问题。下面会按照不同模块逐个进行介绍。

相机

1.1问题背景

相机应用在早期的版本开发时,会发现三方相机和系统相机拍照的效果会有较明显的不一致。如下图对比,可以看到,在色彩/饱和度/纹理细节等方面有一些明显的差异。

三方相机:

wKgaomVhpIaAY1wQAANLaF0w8u0434.png

系统相机:

wKgZomVhpKOAZjLfAAI4-Was4Fk585.png

1.2问题原因

那么这一问题是怎么产生的呢?主要有两个原因:

1、系统相机采用了私有通路,从而获取了更好的效果

wKgaomVWFwKAY8ZLAAC5SdN7a_M734.png

2、预览流拍照效果差

wKgaomVWFwKALiDYAACYO7MdFQc478.png

1.3问题解决

针对以上问题,系统提出了如下的解决思路:

1、统一接口,统一流程,统一效果:通过统一开发接口和流程,从而使得三方相机和系统相机获取一致的体验

wKgaomVWFwOAB75lAAEI_0QE8SM360.png

2、分离预览、拍照、录像,明确流定义,让正确的流做正确的事

wKgaomVWFwOAe975AAFU7-WV1vI111.png

3、相机管道流水线模型

wKgaomVWFwOAAqT7AAD6H9VGGPc052.png

1.4代码示例

1、相机基本控制流程如下:

wKgaomVWFwOAGdnpAACw7mwQejs802.png

2、示例参考:

使用PreviewOutput实现相机预览:

//1.创建预览视图XComponent,获取SurfaceId
surfaceId=xComponent.getXComponentSurfaceId();
//2.创建预览数据流输出PreviewOutput
previewOutput=createPreviewOutput(profile,surfaceId);
//3.添加预览数据流输出到相机会话
session.addOutput(previewOutput);

(左右滑动查看更多)

使用PhotoOutput实现相机拍照:

//1.创建图片接收器ImageReceiver,获取SurfaceId
surfaceId=imageReceiver.getReceivingSurfaceId();
//2.创建拍照数据流输出PhotoOutput
photoOutput=createPhotoOutput(profile,surfaceId);
//3.添加拍照数据流输出到相机会话
session.addOutput(photoOutput);

(左右滑动查看更多)

使用VideoOutput实现相机录像:

//1.创建视频编码器AVRecorder,获取SurfaceId
surfaceId=avRecorder.getInputSurface();
//2.创建录像数据流输出VideoOutput
videoOutput=createVideoOutput(profile,surfaceId);
//3.添加录像数据流输出到相机会话
session.addOutput(videoOutput);

(左右滑动查看更多)

更多详细的代码参考:

https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/media/camera-overview.md

音视频焦点

2.1问题背景

音视频应用开发中遇到的很常见的一个场景,就是并发播放,而并发播放的一般解决思路是各个应用对焦点的申请和处理。

传统的焦点管理方法,依赖应用遵守约定好的策略,如果有的应用不遵守,比如不响应或者滥用焦点,就可能会出现不发声或者乱发声的现象,影响了用户的体验。

2.2 解决思路

针对以上的问题,鸿蒙系统改进了焦点管理的设计,提供了统一的焦点处理策略,来规范应用对于焦点的使用,以达成统一的发声体验。

系统中的焦点管理模块会存储一个焦点策略表,定义了不同的场景下,哪些应用可以获取焦点进行播放,哪些应用会失去焦点而停止播放,等等其他策略。

wKgaomVWFwOAWpGiAADRPWs0QLc305.png

2.3代码示例

可以通过接口的使用来看一下实际处理策略。

首先,在A应用创建并使用AudioRenderer播放的时候,系统会自动为其申请焦点,这个是系统的行为。

A应用播放后,系统的焦点策略会进行判断,如果A应用可以抢到焦点,那就会使得失去焦点的应用暂停播放;同时被暂停的应用也会在INTERRUPT_FORCE的回调事件中,得到暂停的状态,应用在收到这个事件后,就需要存储并更新应用内的状态。

当A应用停止播放,之前被暂停的应用也会收到一个恢复播放的事件,这个事件会在INTERRUPT_SHARE中,应用可以进行恢复播放的操作,或者忽略,这个非强制行为。

// 1.AudioRenderer进行播放时,系统会申请焦点
audioRenderer.start((err) => {});
// 2.注册音频打断事件的回调
audioRenderer.on('audioInterrupt', (event) => {
  if (event.forceType === audio.InterruptForceType.INTERRUPT_FORCE) {
      // 3.强制打断类型:音频相关处理已由系统执行,应用需更新自身状态
  } else if (event.forceType === audio.InterruptForceType.INTERRUPT_SHARE) {
      // 4.共享打断类型:应用可自主选择执行相关操作或忽略打断事件
}});

(左右滑动查看更多)

更多详细的代码参考:

https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/media/audio-playback-concurrency.md

低时延播放

3.1问题背景

游戏、K歌、乐器等应用,对于音频的输出时延要求很高,常规的播放通路一般只能达到60ms左右甚至更高的时延,无法满足这些应用的使用诉求。

3.2解决思路

鸿蒙系统提供了低时延通路的设计。如下图所示,在系统中的普通通路之外,新增了一条垂直打通硬件的低时延通路,通过bypass 框架层直接在DSP进行混音,可以达成最低20ms的音频输出时延。

同时,为了简化应用的接入,通过在接口中提供不同的参数配置,使开发者可以用一套接口同时支持低时延和普通通路两种播放模式。

wKgaomVWFwOALUhOAAEOGBo7olg541.png

3.3代码示例

可以通过OH_AudioStreamXXX接口来进行低时延通路的创建,通过传入不同参数可以设置低时延模式,亦可以设置普通模式,从而使用一套接口来适配不同场景。

同时,低时延模式一般采用来pull模式来获取数据,这里提供了一个callback,需要应用创建并填入。

// 1.创建音频流构造器,设置参数
OH_AudioStreamBuilder_Create(&builder, AUDIOSTREAM_TYPE_RENDERER);
OH_AudioStreamBuilder_SetSamplingRate(builder, rate); // 其他参数设置…
// 2.设置低延时模式和数据回调
OH_AudioStreamBuilder_SetLatencyMode(builder, AUDIOSTREAM_LATENCY_MODE_FAST) ;
OH_AudioStreamBuilder_SetRendererCallback(builder, callback, nullptr);
// 3.构造播放的音频流并使用
OH_AudioStreamBuilder_GenerateRenderer(builder, &audioRenderer);
OH_AudioRenderer_Start(audioRenderer);•OH_AudioRenderer_Release(audioRenderer);

(左右滑动查看更多)

更多详细的代码参考:

https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/media/using-ohaudio-for-playback.md

播控能力

4.1系统能力

通过前面所说的焦点管理策略,系统解决了音视频应用并发播放的问题;对于播放中的应用的控制,系统也提供了规范支持。

系统提供了C/S模式的播控管理的框架,应用作为客户端,接入AVSession的会话端,设置必要的信息;系统的播控中心获取与之对应的会话控制器,获取信息进行展示,以及对应用发送控制命令。

通过标准接口的接入,规范了应用的播放行为;同时通过统一的播控中心的入口,使得用户对于播放的控制做到一键直达。

wKgaomVWFwSAZpjcAAEL-L5GYnM102.png

4.2 代码示例

import AVSessionManager from '@ohos.multimedia.avsession';
// 开始创建并激活媒体会话
// 创建session
let context: Context = getContext(this);
async function createSession() {
  let type: AVSessionManager.AVSessionType = 'audio';
  let session = await AVSessionManager.createAVSession(context, 'SESSION_NAME', type);
  await session.activate();
}
async function setSessionInfo() {
  // 播放器逻辑··· 引发媒体信息与播放状态的变更
  // 设置必要的媒体信息
  let metadata: AVSessionManager.AVMetadata = {
    assetId: '0',
    title: 'TITLE',
    artist: 'ARTIST'
  };
  session.setAVMetadata(metadata).then(() => {
  }).catch((err: BusinessError) => {
  });
  // 简单设置一个播放状态 - 暂停 未收藏
  let playbackState: AVSessionManager.AVPlaybackState = {
    state:AVSessionManager.PlaybackState.PLAYBACK_STATE_PAUSE,
    isFavorite:false
  };
  session.setAVPlaybackState(playbackState, (err) => {
  });
}
async function setListenerForMesFromController() {
  // 一般在监听器中会对播放器做相应逻辑处理
  // 不要忘记处理完后需要通过set接口同步播放相关信息,参考上面的用例
  session.on('play', () => {
    // do some tasks ···
  });
  session.on('pause', () => {
    // do some tasks ···
  });
}

(左右滑动查看更多)

更多详细的代码参考:

https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/media/avsession-overview.md

更多推荐


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • HarmonyOS
    +关注

    关注

    80

    文章

    2157

    浏览量

    36287

原文标题:【技术视界】学习指南:如何快速上手媒体生态一致体验开发

文章出处:【微信号:HarmonyOS_Dev,微信公众号:HarmonyOS开发者】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    CubeSuite+ 快速上手指南

    CubeSuite+ 快速上手指南 在电子开发领域,CubeSuite+ 是款强大且实用的工具。本文将详细介绍 CubeSuite+ 的安装、连接、项目创建、编程调试等内容,帮助电子
    的头像 发表于 03-19 16:50 298次阅读

    为什么国产MCU的工程生态很难统

    背景 国产 MCU 种类多、厂商众多,生态碎片化明显。 主要原因 厂商 SDK 不统 :API、驱动结构差异大 开发工具闭源 :无法统配置流程 工程模板缺失 :初始化步骤、外设配置
    发表于 01-28 09:25

    Renesas Starter Kit for RX113快速上手指南

    Renesas Starter Kit for RX113快速上手指南 在电子开发领域,Renesas Starter Kit for RX113是款备受关注的
    的头像 发表于 12-29 17:00 818次阅读

    Renesas EK - RA8D2评估套件快速上手与定制开发指南

    Renesas EK - RA8D2评估套件快速上手与定制开发指南 在嵌入式开发领域,款好的评估套件能极大地加速
    的头像 发表于 12-26 15:50 632次阅读

    RAA2P4200评估套件快速上手:硬件与软件设置指南

    RAA2P4200评估套件快速上手:硬件与软件设置指南 在电子设计的世界里,能够快速评估和验证新设备的性能是加速产品开发的关键。瑞萨电子(R
    的头像 发表于 12-26 14:55 652次阅读

    快速上手FRDM-KE17Z512开发板:开启高效MCU开发之旅

    快速上手FRDM-KE17Z512开发板:开启高效MCU开发之旅 作为电子工程师,在MCU开发的道路上,拥有
    的头像 发表于 12-24 16:50 483次阅读

    探索NXP LPC5536-EVK评估板:快速上手指南

    探索NXP LPC5536-EVK评估板:快速上手指南 作为电子工程师,在日常的设计和开发工作中,我们经常需要借助各种评估板来验证和实现新的想法。今天就来和大家分享下NXP的LPC5
    的头像 发表于 12-24 15:55 609次阅读

    探索NXP FRDM - MCXN947开发板:快速上手指南

    探索NXP FRDM - MCXN947开发板:快速上手指南 在当今电子技术飞速发展的时代,款性能优越、易于
    的头像 发表于 12-24 15:00 1630次阅读

    NTAG X DNA 快速上手:安全认证 IC 的开发指南

    NTAG X DNA 快速上手:安全认证 IC 的开发指南 在物联网时代,设备的安全认证至关重要。NTAG X DNA 作为款安全认证 IC,为设备认证提供了可靠的解决方案。今天,我
    的头像 发表于 12-24 11:05 760次阅读

    想体验鸿蒙生态,该怎么获取鸿蒙开发板?有哪些途径?

    如何快速上手体验鸿蒙生态? 想体验鸿蒙生态,该怎么获取鸿蒙开发板?有哪些途径?
    发表于 11-29 08:40

    自动驾驶感知不一致是怎么发生的?

    ,可能会造成感知不一致。所谓感知不一致,就是车上不同“眼睛”对同件事看法不一致。打个比方,摄像头说前面有个人,激光雷达回来的点云却很稀疏,毫米波雷达也测到
    的头像 发表于 09-17 12:45 938次阅读
    自动驾驶感知不<b class='flag-5'>一致</b>是怎么发生的?

    镜头不一致的问题原因分析

    在机器视觉系统的视界,镜头一致性犹如维系整个生态的隐形生命线,贯穿于光学成像、图像处理到智能决策的全链路,其细微波动足以颠覆整个检测系统的可靠性。当工业界热衷于讨论算法精度与算力突破时,镜头这
    的头像 发表于 09-11 09:45 1457次阅读

    HarmonyOS入门指南

    OpenHarmony三方库中心仓 坚果派 童长老仓库中心 鸿蒙宝典 快速学习鸿蒙的电子书 promises-book JavaScript Promise迷你书。 harmony-utils
    的头像 发表于 06-27 00:11 918次阅读

    零基础学习LuatOS编程:快速上手开发实战教程!

    无论你是刚接触物联网编程的新手,还是希望拓展技能的技术爱好者,本教程将为零基础的读者提供条清晰的LuatOS学习路径。从安装开发工具到编写第
    的头像 发表于 06-13 17:27 743次阅读
    零基础<b class='flag-5'>学习</b>LuatOS编程:<b class='flag-5'>快速</b><b class='flag-5'>上手</b><b class='flag-5'>开发</b>实战教程!

    CAN总线采样点不一致的危害

    、遵循行业标准 CiA推荐采样点为87.5%,并提供详细的位定时指南(如CiA 601-3文档)。工程师应参考这些标准,确保所有节点配置一致。 为确保网络可靠性,工程师必须为所有节点配置一致的位定时
    发表于 06-07 08:55