零基础入门多媒体音频(4)-GENIVIProjectAudioManager总览

GENIVI Project的AudioManager是一个专门设计用于汽车信息娱乐系统的音频管理解决方案。它负责管理和控制车辆内的音频源和音频路径,确保各种音频信号能够正确、高效地在车辆的音响系统中传输和播放。

AudioManager的核心功能包括音频源的管理、音频路径的控制以及音频信号的处理。它能够识别和管理多种音频源,如收音机、CD播放器、蓝牙设备、USB接口等,并根据用户的选择或系统的设定,将音频信号传输到相应的音响设备,如扬声器、耳机等。

此外,AudioManager还具备音频信号处理的能力,可以对音频信号进行放大、均衡、混响等处理,以提升音频的音质和听感。它还能够根据车辆的行驶状态和环境噪声,自动调整音频的音量和音质,确保驾驶者和乘客在任何情况下都能获得最佳的听觉体验。

总的来说,GENIVI Project的AudioManager是一个功能强大、灵活可配置的音频管理解决方案,适用于各种汽车信息娱乐系统的开发和集成。它能够为驾驶者和乘客提供高品质的音频体验,同时满足车辆制造商对于音频系统的特殊需求。

GENIVI Project AudioManager共可以分为两个部分:audiomanager,audiomanagerplugins。audiomanager是项目的核心框架层,包含了守护进程daemon的启动;各插件的加载,初始化;提供基础特性支持,包括调试信息管理(DLT),数据库(sqlLite),跨进程通行(Dbus,CAPI);插件间的调用传递。audiomanagerplugins是项目提供的扩展插件。共包含三部分,command(项目软件与项目以外的软件的信息传递,调用传递),control(音频功能的核心决策层,负责业务逻辑的处理),routing(音频业务的具体执行者)。commandsender主要用于audiomanager向外床底系统中状态的变化,如系统加/删的主链接,sink/source数量变化,sink/source状态变化,系统增/删sink/source。我们发散一下思维,再android音频中扮演commandsender角色的模块是什么呢?

就是audioservcie里面的各类广播消息。这两者都实现了将音频系统状态的变化传递给系统的关注者。让这些利益相关者做出响应。本质上使用了观察者模式。

commandreceiver类是audiomanager对外暴露的功能接口。(也就是外部软件(某种程度上plugin也在此列)可以调用audiomanager做哪些功能)。我们可以类比到android的audiomanager,audiosystem,audiotrack等接口。虽然commandsender和commandreceiver从名字上看来只是调用方向的相反,但是实际上实现的功能和设计目的时完全不一样的。不免让人觉得设计者是纯粹为了简单和对称进行这样命名的。

下面是截取的一些典型代码片段。

commandreceiver

复制代码
   am_Error_e connect(const am_sourceID_t sourceID, const am_sinkID_t sinkID, am_mainConnectionID_t& mainConnectionID);
    am_Error_e disconnect(const am_mainConnectionID_t mainConnectionID);
    am_Error_e setVolume(const am_sinkID_t sinkID, const am_mainVolume_t volume);
    am_Error_e volumeStep(const am_sinkID_t sinkID, const int16_t volumeStep);

commandsender

复制代码
id cbNewMainConnection(const am_MainConnectionType_s mainConnection);
    void cbRemovedMainConnection(const am_mainConnectionID_t mainConnection);
    void cbNewSink(am_SinkType_s sink);
    void cbRemovedSink(const am_sinkID_t sink);
    void cbNewSource(const am_SourceType_s source);
    void cbRemovedSource(const am_sourceID_t source);
    void cbNumberOfSinkClassesChanged();
    void cbNumberOfSourceClassesChanged();

RoutingReceiver的作用是routing插件向audiomanager主进程通知route相关元素状态的变化,比如注册/注销音频域,注册/注销音频网关,注册/注销音频转化器等。以及ack从routingsender送过来的命令执行情况。

routingsender是用于audiomanager主进程操作route元素。包括链接source和sink。设置source/sink属性(音量,节点状态)等。

ControlReceiver的作用是让contro插件能调用audiomanager提供的数据库,打印等基础功能,间接调用routingplugin插件实现的功能。

ControlSender的作用是让contro插件能够在audiomanager执行重要功能逻辑时注入自己想要附加的逻辑。

相关推荐
Monkey的自我迭代10 小时前
背景建模(基于视频,超炫)项目实战!
opencv·计算机视觉·音视频
骄傲的心别枯萎14 小时前
RV1126 NO.30:RV1126多线程获取音频AI的PCM数据
linux·ffmpeg·音视频·pcm·视频编解码
别来这个网址14 小时前
FreeLong-无需训练即可延长视频生成时长
音视频
2501_9275393016 小时前
Permute 媒体文件格式转换【音视频图像文件转换】(Mac电脑)
macos·音视频·媒体·格式转换
嘀咕博客16 小时前
Guidde:AI驱动的视频文档创建工具
人工智能·音视频·ai工具
DuHz21 小时前
Stable Video Diffusion:将潜在视频扩散模型扩展到大规模数据集——论文阅读
论文阅读·人工智能·深度学习·神经网络·算法·音视频
q24985969321 小时前
h.265格式的视频在浏览器无法正常播放,使用ffprobe转为h.264
音视频·h.265·h.264
补补234561 天前
解决漫步者H180Plus(TypeC)耳机连接三星手机后每次播放音频出现滴滴声
android·音视频·三星·typec·edifier·h180plus·滴滴声
无损去水印精灵1 天前
视频去水印方法总结,如何去除抖音视频水印
音视频
顾道长生'1 天前
(Arxiv-2025)OmniInsert:无遮罩视频插入任意参考通过扩散 Transformer 模型
深度学习·音视频·transformer