QT实现MP4播放器

2024-08-31 21:12
文章标签 实现 qt 播放器 mp4

本文主要是介绍QT实现MP4播放器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、实现功能

 播放本地MP4文件。

1、可以将文件添加到列表中,双击列表中的歌曲进行播放。

2、实现视频的播放与暂停。

3、上一首和下一首的按钮选择功能。

4、视频名称的滚动显示。

5、当前的播放时长和总时长。

6、播放模式的选择:单曲循环、随机播放、顺序播放。

7、使用了水平和垂直布局。

8、视频音量的控制。

9、使用非UI界面实现。

2、项目环境

Qt Creator 5.0.2 

3、widget.h

#ifndef WIDGET_H
#define WIDGET_H#include <QWidget>
#include <QDebug>
#include <QListWidget>
#include <QVideoWidget>
#include <QMediaPlayer>
#include <QLabel>
#include <QPushButton>
#include <QComboBox>
#include <QMessageBox>
#include <QHBoxLayout>
#include <QFileDialog>
#include <QTime>
#include <QTimer>
#include <QResizeEvent>
#include <QSizePolicy>
#include <QListWidgetItem>
class Widget : public QWidget
{Q_OBJECTpublic:Widget(QWidget *parent = nullptr);~Widget();
private slots:void get_duration(qint64 duration);void update_playslidexvalue(qint64 position);void basic();private slots:void on_select_btn_clicked();void on_pre_btn_clicked();void on_next_btn_clicked();void onComboBoxIndexChanged(int index);void on_itemDouble_clicked(QListWidgetItem *item);void on_play_btn_clicked();void on_play_slidex_sliderMoved(int position);
private:QListWidget *list;QVideoWidget *video;QLabel *name_lab;QLabel *time_lab;QSlider *slider1;QSlider *slider2;QPushButton *select_btn;QPushButton *play_btn;QPushButton *pre_btn;QPushButton *next_btn;QComboBox *combox;QHBoxLayout *hbox1;QHBoxLayout *hbox2;QHBoxLayout *hbox3;QVBoxLayout *vbox;QMediaPlayer *player;QTimer *timer;QString song_name;int index;int lon;int hua;int mode;
};
#endif // WIDGET_H

 4、widget.cpp

#include "widget.h"Widget::Widget(QWidget *parent): QWidget(parent)
{this->setGeometry(0, 0, 800, 600);/*------------------------------------*/this->list =new QListWidget(this);//设置视频展示列表/*------------------------------------*/this->video =new QVideoWidget(this);//设置视频播放this->video->setWindowTitle("视频播放器");this->video->setStyleSheet("border:2px solid black");/*------------------------------------*/this->name_lab =new QLabel(this);//设置视频名滚动this->name_lab->setGeometry(10,380,200,40);this->name_lab->setText("视频名");/*------------------------------------*/this->time_lab =new QLabel(this);//设置播放时间this->time_lab->setGeometry(500,380,200,40);this->time_lab->setText("     ");/*------------------------------------*/this->slider1 = new QSlider(this);//播放时间的滑块this->slider1->setOrientation(Qt::Horizontal);this->slider1->setGeometry(10,440, 780, 30);/*------------------------------------*/this->select_btn =new QPushButton(this);//添加到列表this->select_btn->setGeometry(10,520,100,40);this->select_btn->setText("添加到列表");/*------------------------------------*/this->play_btn =new QPushButton(this);//  播放/暂停this->play_btn->setGeometry(130,520,100,40);this->play_btn->setText("播放");/*------------------------------------*/this->pre_btn =new QPushButton(this);//this->pre_btn->setGeometry(250,520,100,40);this->pre_btn->setText("上一首");/*------------------------------------*/this->next_btn =new QPushButton(this);//this->next_btn->setGeometry(370,520,100,40);this->next_btn->setText("下一首");/*------------------------------------*/this->combox =new QComboBox(this);//this->combox->setGeometry(500,520,100,50);this->combox->addItem("单曲循环");this->combox->addItem("顺序播放");this->combox->addItem("随机播放");/*------------------------------------*/this->slider2 = new QSlider(this);//播放声音的滑块this->slider2->setOrientation(Qt::Horizontal);this->slider2->setGeometry(620,520, 130, 40);/*------------------------------------*///准备一个水平布局//给水平布局添加组件对象this->hbox1 = new QHBoxLayout;this->hbox1->addWidget(this->list,1);this->hbox1->addStretch();this->hbox1->addWidget(this->video,3);/*------------------------------------*/this->hbox2 = new QHBoxLayout;this->hbox2->addWidget(this->name_lab);this->hbox2->addWidget(this->time_lab);/*------------------------------------*/this->hbox3 = new QHBoxLayout;this->hbox3->addWidget(this->select_btn);this->hbox3->addWidget(this->play_btn);this->hbox3->addWidget(this->pre_btn);this->hbox3->addWidget(this->next_btn);this->hbox3->addWidget(this->combox);this->hbox3->addWidget(this->slider2);/*------------------------------------*///准备一个垂直布局this->vbox = new QVBoxLayout;//给垂直布局添加组件、添加布局this->vbox->addLayout(this->hbox1);this->vbox->addLayout(this->hbox2);this->vbox->addWidget(this->slider1);this->vbox->addLayout(this->hbox3);/*------------------------------------*///给界面设置布局为垂直布局this->setLayout(this->vbox);/*------------------------------------*///实例化播放器对象this->player=new QMediaPlayer(this);/*------------------------------------*/this->timer=new QTimer(this);//实例化定时器对象/*------------------------------------*/this->index=0;//实例化Indexthis->lon=0;//实例化lonthis->hua=0;//实例化huathis->mode=0;//实例化mode  默认为单曲循环this->player->setVolume(0);//声音默认为0/*------------------------------------*///槽函数与信号关联connect(this->select_btn,&QPushButton::clicked,this,&Widget::on_select_btn_clicked);// connect(this->select_btn,&QPushButton::clicked,this,&Widget::on_select_btn_clicked);connect(this->list, &QListWidget::itemDoubleClicked, this,&Widget::on_itemDouble_clicked);connect(this->play_btn,&QPushButton::clicked,this,&Widget::on_play_btn_clicked);connect(this->player,&QMediaPlayer::durationChanged,this,&Widget::get_duration);connect(this->player,&QMediaPlayer::positionChanged,this,&Widget::update_playslidexvalue);//  位置改变connect(this->slider1,&QSlider::sliderMoved,this,&Widget::on_play_slidex_sliderMoved);connect(this->pre_btn,&QPushButton::clicked,this,&Widget::on_pre_btn_clicked);connect(this->next_btn,&QPushButton::clicked,this,&Widget::on_next_btn_clicked);connect(this->combox, SIGNAL(currentIndexChanged(int)), this, SLOT(onComboBoxIndexChanged(int)));connect(this->timer,&QTimer::timeout,this,[=](){//获取当前的播放时长以及歌曲的总时长qint64 pos =this->player->position();qint64 dur =this->player->duration();QString str = QTime(0,0,0,0).addMSecs(pos).toString("mm:ss")+"/"+ QTime(0,0,0,0).addMSecs(dur).toString("mm:ss");//设置给时间标签去显示this->time_lab->setText(str);//歌曲名称的滚动显示this->index++;if(this->index==this->song_name.size()){this->index=0;}QString name=this->song_name.mid(this->index);this->name_lab->setText(name);if(dur==pos){if(this->mode==0){this->player->stop();this->player->play();}else if(this->mode==1){this->player->pause();if(this->hua<this->lon-1){this->hua++;}else{this->hua=0;}basic();}else if(this->mode==2){this->hua=rand()%this->lon;basic();}}});connect(this->slider2, &QSlider::sliderMoved, this->player, [=](qint64 position)
{//改变音量滑块的位置,调节音量的大小this->player->setVolume(position);
});}Widget::~Widget()
{}void Widget::get_duration(qint64 duration)
{ //获取歌曲时长//给滑块设置取值范围this->slider1->setRange(0,duration);
}//根据歌曲的播放位置变化改变滑块的位置
void Widget::update_playslidexvalue(qint64 position)
{// 改变滑块的值this->slider1->setValue(position);}void Widget::basic()
{//给播放器设置媒体资源QListWidgetItem *item = this->list->item(this->hua);QString filePath = item->data(Qt::UserRole).toString();this->player->setMedia(QMediaContent(QUrl(filePath)));//给播放器设置画面输出this->player->setVideoOutput(this->video);//给滑块设置取值范围this->slider1->setValue(0);//获取歌曲名称this->song_name="                          "+QFileInfo(filePath).fileName();this->timer->start(1000);this->player->play();this->play_btn->setText("暂停");
}void Widget::on_select_btn_clicked()
{//选择歌曲资源QStringList filePaths = QFileDialog::getOpenFileNames(this,"选择","./","MP4(*.mp4)");for(int i=0;i<filePaths.size();i++){QString filePath=filePaths.at(i);QString fileName = QFileInfo(filePaths.at(i)).fileName();QListWidgetItem *item = new QListWidgetItem(QIcon("./icon/opn.jfif"), fileName);//将文件的完整路径存储在 QListwidgetItem 的用户数据中item->setData(Qt::UserRole,filePath);item->setData(Qt::UserRole+1,this->lon);this->lon++;this->list->addItem(item);}
}void Widget::on_itemDouble_clicked(QListWidgetItem *item)
{this->player->pause();QString filePath = item->data(Qt::UserRole).toString();this->hua= item->data(Qt::UserRole + 1).toInt();basic();
}void Widget::on_play_btn_clicked()
{if(this->lon!=0){if(this->play_btn->text()=="播放"){//启动定时器this->timer->start(1000);this->player->play();this->play_btn->setText("暂停");}else if(this->play_btn->text()=="暂停"){this->player->pause();this->timer->stop();this->play_btn->setText("播放");}}else{QMessageBox::information(this, "播放", "请先选择视频");}
}void Widget::on_pre_btn_clicked()
{this->player->pause();if(this->hua>0){this->hua--;basic();}else{QMessageBox::information(this, "上一首", "这是第一首了");}
}void Widget::on_next_btn_clicked()
{this->player->pause();if(this->hua<this->lon-1){this->hua++;basic();}else{QMessageBox::information(this, "下一首", "这是最后一首了");}
}void Widget::onComboBoxIndexChanged(int index)
{this->mode=index;switch (index){case 0:qDebug() << "单曲循环模式被选中";break;case 1:qDebug() << "顺序播放模式被选中";break;case 2:qDebug() << "随机播放模式被选中";break;default:break;}
}//根据滑块的位置变化改变歌曲的播放位置
void Widget::on_play_slidex_sliderMoved(int position)
{//改变歌曲的播放位置this->player->setPosition(position);
}

这篇关于QT实现MP4播放器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1125010

相关文章

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

Conda虚拟环境的复制和迁移的四种方法实现

《Conda虚拟环境的复制和迁移的四种方法实现》本文主要介绍了Conda虚拟环境的复制和迁移的四种方法实现,包括requirements.txt,environment.yml,conda-pack,... 目录在本机复制Conda虚拟环境相同操作系统之间复制环境方法一:requirements.txt方法

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja