音视频基础学习之【08.添加播放列表】

2024-03-21 19:50

本文主要是介绍音视频基础学习之【08.添加播放列表】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

添加播放列表

界面设计

sqlite使用

添加文件到播放列表

加载数据库并设置播放列表

双击列表中的文件播放

清空播放列表

播放下一个视频


添加播放列表

  • 界面设计

补充前面的播放控制,添加播放列表的ui设计

 

点击列表按钮实现显示/隐藏播放列表

播放列表采用轻量级数据库sqlite存储本地播放文件

每次运行时读取数据库中的内容添加到本地播放列表中

  • sqlite使用

将sqlapi文件复制到目录下

在工程配置文件Youku.pro中添加包含

选用sqlite的原因

sqlite是轻量级数据库,一般用在嵌入式产品中,占用资源非常低,支持跨平台,并且处理速度快,是文件存储类型的数据库

采用数据库存储是为了标准化存储方式,如果自己编写文件存储,增加了开发成本,别人阅读代码很困难,用数据库就可以有规范化的流程

  • 添加文件到播放列表

首先创建一个存放文件路径的数组m_playList 和 记录列表视频数量的变量m_videoCount;

对右上角的加号添加处理函数

用一个字符串数组存储文件名,定义宏MAX_PLAY_LIST 100为列表最大文件个数,数组大小为MAX_PLAY_LIST

添加到列表的操作如下:

两层循环,外层为选中的所有文件,内层遍历整个数组,如果选中的路径名与数组中已经存在的路径名相同,通过将标志位hasSame置为true判断重复,跳出内循环,不添加该文件到列表

每次外循环时都将标志位置为false,如果遍历列表中所有路径发现没有相同的(即hasSame为false),则将其添加到播放列表中,并将文件名、路径插入到sqlite数据库

//添加文件到播放列表
void Youku::on_pb_addlist_clicked()
{//弹出窗口,选择视频文件,获取文件的绝对路径 存路径需要字符数组//1.父类 2.标题 3.默认路径QStringList path =  QFileDialog::getOpenFileNames(this,"选择要播放的文件","F:/","视频文件 (*.flv *.rmvb *.avi *.MP4 *.mkv);; 所有文件(*.*);;");//去重bool hasSame = false;for(int i=0;i<path.count();++i){hasSame = false;//遍历所有歌曲for(int j=0;j < m_videoCount;++j){//如果选中的视频名与缓存列表中的视频名相同if(path[i] == m_playList[j]){hasSame = true;break;}}//如果遍历结束 播放列表中没有与当前加入的同名的视频if(!hasSame){//将歌曲加入到歌曲列表m_playList[m_videoCount] = path[i];m_videoCount++;//同时将 视频名 添加到控件QFileInfo info(path[i]);//info.baseName();    //  获取到文件名 /music/稻香.mp3 --->baseName:稻香ui->lw_playlist->addItem(info.baseName());//插入sqlQString sqlStr =QString("insert into t_PlayList (videoName,videoPath) values('%1','%2')").arg(info.baseName()).arg(path[i]);//格式化字符串m_sqlite->UpdateSql(sqlStr);}}
}
  • 加载数据库并设置播放列表

这个函数在启动程序时的构造函数中调用,每次启动程序,从数据库中加载文件名及路径到播放列表中

在项目工程中固定路径(当前路径下/sql/playlist.db)建立数据库文件

先查看路径是否存在,如果不存在,创建该路径,如果存在,查看是否有数据库文件

如果有文件,加载数据库,从数据库中查已经存放的文件名和路径,插入到数组中

如果没有文件,创建数据库文件,建立表结构

//加载数据库 并设置播放列表
void Youku::loadSqliteAndSetList()
{//首先获取路径 设置sql//拼接 数据库文件保存路径QString DBDir = QDir::currentPath() + "/sql/";QString FileName = "playlist.db";QDir tempDir;tempDir.setPath(DBDir);//查看路径是否存在 没有—创建if(!tempDir.exists(DBDir)){//路径不存在,创建qDebug()<<"不存在该路径"<<endl;tempDir.mkdir(DBDir);}//查看有没有数据库QFile tempFile;if(tempFile.exists(DBDir+FileName)){//有—加载数据库//连接数据库 传入数据库的绝对路径m_sqlite->ConnectSql(DBDir+FileName);QStringList resList;//查询QString sqlStr = "select videoName,videoPath from t_PlayList;";bool res = m_sqlite->SelectSql(sqlStr,2,resList);if(!res){//没有查询到结果return ;}//把查到的结果放到数组和控件中for(int i = 0; i < resList.count(); i += 2){ui->lw_playlist->addItem(resList[i]);m_playList[m_videoCount] = resList[i+1];m_videoCount++;}}else{//没有—创建数据库tempFile.setFileName(DBDir+FileName);//创建文件if(!tempFile.open(QIODevice::WriteOnly | QIODevice::Text)){qDebug()<<"数据库创建失败"<<endl;QMessageBox::about(this,"提示","播放列表数据库创建失败");}else{qDebug()<<"数据库创建成功"<<endl;tempFile.close();//连接数据库 传入数据库的绝对路径m_sqlite->ConnectSql(DBDir+FileName);//创建表QString sqlStr = "create table t_PlayList(videoName varchar(260),videoPath varchar(260));";m_sqlite->UpdateSql(sqlStr);}}
}
  • 双击列表中的文件播放

取到 listWidget 焦点处的路径,通过路径打开文件播放

//双击列表播放
void Youku::on_lw_playlist_doubleClicked(const QModelIndex &index)
{//获取当前列表选中项的绝对地址QString path = m_playList[ui->lw_playlist->currentIndex().row()];if(!path.isEmpty()){slot_play(path);}else{//没取到路径,打开失败QMessageBox::information( this, "提示" , "打开文件失败");}}
  • 清空播放列表

先清除数据库中的记录,再清空存储文件路径的数组和控件,停止播放

//清空播放列表
void Youku::on_pb_clearlist_clicked()
{//清空数据库//列表中没有视频-->无法删除if(m_videoCount <= 0)   return;//删除数据库记录QString sqlStr = QString("delete from t_PlayList");m_sqlite->UpdateSql(sqlStr);for(int i = 0 ; i < m_videoCount-1; ++i){//清空数组m_playList[i].clear();//清空控件ui->lw_playlist->clear();}m_videoCount = 0;//停止播放decode->stop(true);
}
  • 播放下一个视频

通过焦点处的index+1获取下一个视频的路径进行播放

当处于列表最后一个位置时,通过循环取余实现列表循环

//播放下一个
void Youku::on_pb_next_clicked()
{//异常处理,列表中没有视频的情况if(m_videoCount == 0){//停止decode->stop(true);}//切换到下一曲    最后一首歌切换到第一首//获取当前列表选中项的绝对地址  循环取余QString path = m_playList[(ui->lw_playlist->currentIndex().row() + 1) % m_videoCount];//QString path = [ui->lw_playlist->currentIndex().row()];slot_play(path);//UI切换  设置当前焦点ui->lw_playlist->setCurrentRow((ui->lw_playlist->currentIndex().row() + 1) % m_videoCount);}

 

这篇关于音视频基础学习之【08.添加播放列表】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/833736

相关文章

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

C#基础之委托详解(Delegate)

《C#基础之委托详解(Delegate)》:本文主要介绍C#基础之委托(Delegate),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 委托定义2. 委托实例化3. 多播委托(Multicast Delegates)4. 委托的用途事件处理回调函数LINQ

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

通过C#和RTSPClient实现简易音视频解码功能

《通过C#和RTSPClient实现简易音视频解码功能》在多媒体应用中,实时传输协议(RTSP)用于流媒体服务,特别是音视频监控系统,通过C#和RTSPClient库,可以轻松实现简易的音视... 目录前言正文关键特性解决方案实现步骤示例代码总结最后前言在多媒体应用中,实时传输协议(RTSP)用于流媒体服