「技术分享」音乐-CD播放介绍(cd播放是什么意思)
zhezhongyun 2025-05-02 14:50 27 浏览
音乐(deepin-music)是deepin自研的一款音频播放软件,能广泛支持播放本地或外部媒介中的音频文件,其中就包括对CDDA(Compact Disc-Digital Audio)标准的支持。CDDA标准主要用于光盘存储数字高保真音乐,深受音乐发烧友的喜爱。
本文将站在技术实现的角度,介绍音乐(deepin-music)应用是如何播放CD光盘中的美妙音乐的。
1. 整体流程
简单的说,音乐(deepin-music)播放CD流程整体分为三个部分:
- 检测CD光盘;
- 解析CD数据;
- 播放CD;
图一 deepin-music CD光盘处理流程
2. 检测CD光盘
2.1 识别光驱设备
对光驱设备的识别,主要源于对CD光盘状态的检测。依托于 `libudisks2-qt5-dev` 开源库的DDiskManager 类,即可实现对块设备状态监控,具体使用如下:
DDiskManager diskManager;
//获取块设备状态
diskManager.setWatchChanges(true);
//初始化获取当前所有设备localPath
QStringList allDevices = diskManager.blockDevices(QVariantMap());
//根据cdrom关键字,找出光驱设备
foreach (QString tmpstr, allDevices)
{
if (tmpstr.compare("sr0") == 0) //sr0是cdrom关键字
return tmpstr; //localPath
}
Linux系统中, "sr0" 主要指光驱设备(s= scsi;r= rom ;数字0代表光驱设备编号)。如需判断当前光驱是否被插拔,则可通过DDiskManager 类以下信号进行监听:
void blockDeviceAdded(const QString &path);
void blockDeviceRemoved(const QString &path);
3. 解析CD数据
3.1 解析CD节点
识别到光驱设备后,接下来就是获取CD光盘的节点数据,这里可引用依赖库`libvlc-dev`和`libvlccore-dev`,具体代码实现如下:
// 将tmpstr 转化为"cdda:///dev/sr0"这种形式
QString strcda = QString("cdda: ///dev/%1").arg(tmpstr.mid(tmpstr.lastIndexOf("/") + 1, tmpstr.size() - tmpstr.lastIndexOf("/"))) ;
// 获取sr0
input_item_t *p_input =
input_item_NewExt(strcda.toUtf8().data(), "access_demux", 0, ITEM_TYPE_DISC, ITEM_LOCAL);
//打开sr0,读取流
libvlc_instance_t *_vlcInstance = vlc_new(0, nullptr); //创建libvlc_instance_t对象
libvlc_media_player_t *_vlcMediaPlayer = vlc_media_player_new(_vlcInstance); // player_t
stream_t * pstream = vlc_stream_NewURL((vlc_object_t *)_vlcMediaPlayer, strcda.toUtf8().data()); //根据sr0,获取流
//创建cda节点
input_item_node_t * p_items = input_item_node_Create(p_input);
//将数据流读到节点中
vlc_stream_ReadDir(pstream, p_items);
//释放数据流、节点
vlc_stream_Delete(pstream); //释放数据流
input_item_Release(p_input); //释放输入设备
最终产生的p_items,就包含有CD节点数据。
3.2 检索CD歌曲信息
一般而言,获取了CD节点数据已经足以支持音乐的完整播放,但在某些场景下有的用户希望知悉CD歌曲的完整信息(比如:专辑、歌曲名称、歌手),而这部分信息并不在CD光盘里,那么怎么才能获取呢?
可以考虑查询远程CD数据库(CDDB),远程CD数据库有gundb、Gracenote和微软CDDB等。这里只介绍gundb使用方法,在连接数据库时需要依赖`libcddb2-dev`库,代码实现如下:
#include <cddb/cddb.h>
#include <linux/cdrom.h>
//打开/dev/sr0设备文件
int fd=open(“/dev/sr0”, O_RDONLY | O_NONBLOCK);
//获取CD数据
int status = ioctl(fd, CDROM_DISC_STATUS, CDSL_CURRENT);
if ((CDS_AUDIO==status || CDS_MIXED==status) && 0==ioctl(fd, CDROMREADTOCHDR, &th)){
m_disc = cddb_disc_new(); //生成disc
cddb_disc_calc_discid(m_disc); //创建discid,后面的查找就是根据它
}
//创建数据库连接
QString host("gnudb.gnudb.org"); //Location
int port = 80;//port
cddb_conn_t *connection = cddb_new(); //创建cddb_conn_t 对象
cddb_cache_disable(connection);
cddb_set_server_name(connection, host.toLatin1().constData()); //设置服务名
cddb_set_server_port(connection, port); //设置端口
//创建服务
cddb_cache_disable(connection);
cddb_set_server_name(connection, QString("gnudb.gnudb.org").constData());
cddb_set_server_port(connection, 80);
//设置http服务
cddb_set_http_proxy_server_name(connection, hostName().toLatin1().constData());
cddb_set_http_proxy_server_port(connection, port());
cddb_http_proxy_enable(connection);
cddb_query(connection, m_disc); //查询
cddb_read(connection, m_disc); //读取
cddb_disc_get_title(m_disc); //读取专辑标题
cddb_disc_get_artist(m_disc); //读取专辑作者
cddb_track_t *trk=cddb_disc_get_track(m_disc, t); //获取cd中的第t首歌
cddb_track_get_title(trk); //获取歌曲标题
cddb_track_get_artist(trk); //获取歌曲作者
cddb_query_next(connection, m_disc); //查询下一条数据
注:CDDB(光盘数据库)服务器,是可以被 CD翻录器和CD 播放器等应用程序查询,提供给定CD 的作者、专辑、曲目列表和其他信息。
4. 播放CD
音频播放会沿用3.1章节的相关依赖库,使用`libvlc_instance_t` 和 `libvlc_media_player_t `等接口播放CD音频文件。
//在3.1节中,已经初始化得到libvlc_instance_t *_vlcInstance、
//libvlc_media_player_t *_vlcMediaPlayer
//location路径“cdda:///dev/sr0”
libvlc_media_t* _vlcMedia = libvlc_media_new_location(_vlcInstance, path.toUtf8().data());
//设置与libvlc_media_player_t关联的媒体描述
libvlc_media_player_set_media(_vlcMediaPlayer, _vlcMedia);
//track为CD中歌曲的编号,可以自定义指定,cdda-track为CD标识
config_PutInt((vlc_object_t *)_vlcMediaPlayer, "cdda-track", track);
//播放
libvlc_media_player_play(_vlcMediaPlayer);
以上便是deepin-music播放CD光盘的完整处理流程,希望此篇文章能对感兴趣的朋友起到抛砖引玉的作用。
相关推荐
- css 垂直居中的几种实现方式(css怎么实现垂直居中)
-
前言设计是带有主观色彩的,同样网页设计中的css一样让人摸不头脑。网上列举的实现方式一大把,或许在这里你都看到过,但既然来到这里我希望这篇能让你看有所收获,毕竟这也是前端面试的基础。实现方式备注:...
- CSS 中各种居中你真的玩明白了么(css中的居中属性)
-
页面布局中最常见的需求就是元素或者文字居中了,但是根据场景的不同,居中也有简单到复杂各种不同的实现方式,本篇就带大家一起了解下,各种场景下,该如何使用CSS实现居中前言页面布局中最常见的需求就是元...
- 浅谈3种css技巧——两端对齐(css两侧对齐)
-
在出里文字比较多的网页,文字对齐其中采用的两端对齐,两端对齐的方法有三种方法,如下:1.使用text-align:justifytext-align:justify属性是全兼容的,使用它实现两端对...
- 从零开发HarmonyOS(鸿蒙)运动手表小游戏—数字华容道
-
本个demo将从零基础开始完成鸿蒙小游戏APP在可穿戴设备上的编译,此处以运动手表为例,在项目中我们所使用到的软件为DevEcoStudio,下载地址为:DevEcoStudio下载、DevEco...
- 教师如何制作随机点名系统,活跃课堂气氛
-
上课点名抽学生回答问题,做游戏……由老师口头点名,点谁回答总有点老师本人的情绪,且显得毫无趣味,但做一个点名系统,就不一样了,电脑随机抽出的名字,不仅公平,还会给孩子们带来一种不一样的感受。那么怎么做...
- 看京铁人如何破解电煤运输"烤"验
-
“天气太热了!空调是我的避暑必备神器再往冰箱里冻些雪糕和西瓜电风扇也要24小时上岗了”近日京津冀地区迎来高温天气小伙伴们都在分享解暑妙招但这些妙招背后都离不开一个字——“电”为确保电力平稳“迎峰度夏”...
- 回家的路就是最美的风景 幸福就在前方
-
2025年春运启动以来,无数在外游子踏上归乡旅程。为了帮助更多旅客按时回家过年,还有很多人不分昼夜、不辞辛苦地奔波在铁路线上。“我的列车飞驰而过,那是梦想的前方,回家的路就是最美的风景。”END&l...
- 如何做出一个香消玉殒的网页文字特效
-
最近,迷上了CSS3特效,空闲时间学一些小案例,非专业,爱好。不断学习也能掌握一些更为全面的html,css,JavaScript的知识,以小博大,从兴趣出发再掌握更多网页开发知识。闲言少叙,直接开怼...
- 第1000篇原创,我想对你说______(2021我想对你说1000)
-
亲爱的小伙伴今天您看到的这篇推送是“北京铁路”发布的第1000篇原创作品!这不仅是一个数字的跨越更是我们一路走来与每一位关注者共同铸就的辉煌里程碑每一篇文章都承载着我们的心血与热情每一次传播都离不开大...
- 动车组的“家”在哪里?(动车组的"家"在哪里?举例说明)
-
夜幕降临随着动车组列车驶入站台乘客陆续离开动车组也完成了一天的工作准备启程回“家”有小伙伴儿会问“为什么大多数动车组列车夜间不运行呢?”这是因为白天行驶一天的动车组要利用晚上的时间进行全面检查、维修和...
- 这套铁路“高考”卷,请你来作答(郑州铁路职业技术学院高考河南录取分数线)
-
今天是2025年全国高考的第一天小编为大家准备了一套北京铁路版的试卷满分120分共12道单选题快来试试你能得多少分吧!·<animateattributeName="opacity"begi...
- HarmonyOS Text组件Span间距解决方案
-
HarmonyOSText组件Span间距解决方案一、问题分析在HarmonyOS开发中,Text组件内的Span子组件无法直接设置margin/padding属性,需要通过文本级属性实现间距控制。...
- 考“火车驾驶证”,难不难?(火车驾驶证怎么考需要什么条件)
-
····<animateattributeName="height"begin="0.1"dur="0.01s"fill="freeze"to="0"/>00:0002:59未加...
- 高温?京铁人:我有“物理外挂”!(点开看有多爽)
-
近几日华北地区气温不断上升高温来袭坚守岗位的京铁人开启清凉避暑的“物理外挂”快动动手指点开看看吧·<animateattributeName="opacity"begin="click+0....
- 2025年Top30 CSS面试题及答案(css常考面试题)
-
概述CSS(层叠样式表)是构建美观、响应式网站的关键技术。无论您是在准备前端开发者面试还是复习知识,这里都有一份精心挑选的2025年每个开发者都应该知道的30个CSS面试题及答案。1.什么是CSS...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 教程 (33)
- HTML 简介 (35)
- HTML 实例/测验 (32)
- HTML 测验 (32)
- JavaScript 和 HTML DOM 参考手册 (32)
- HTML 拓展阅读 (30)
- HTML常用标签 (29)
- HTML文本框样式 (31)
- HTML滚动条样式 (34)
- HTML5 浏览器支持 (33)
- HTML5 新元素 (33)
- HTML5 WebSocket (30)
- HTML5 代码规范 (32)
- HTML5 标签 (717)
- HTML5 标签 (已废弃) (75)
- HTML5电子书 (32)
- HTML5开发工具 (34)
- HTML5小游戏源码 (34)
- HTML5模板下载 (30)
- HTTP 状态消息 (33)
- HTTP 方法:GET 对比 POST (33)
- 键盘快捷键 (35)
- 标签 (226)
- HTML button formtarget 属性 (30)
- CSS 水平对齐 (Horizontal Align) (30)