QT QMediaPlayer音频视频播放器

2023-11-03 19:59

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

用QT做了一个简单的媒体播放器,UI比较粗糙但用起来还行。功能有基本的播放暂停功能,并支持拖拽。具体步骤如下。

首先建一个QT GUI程序,widget选MainWindow或者Widget都可以,我选的是MainWindow。

建好后在pro文件中添加以下语句,为了引用QT多媒体:

QT       += multimedia multimediawidgets

绘制GUI如下:

上方一个widget,由QVideoWidget的子类提升而来。下方是一个QSlider,用来显示播放进度。最下面是三个按钮,用来打开和播放。继承QVideoWidget,widget提升时候用到。videowidget.h。

#ifndef VIDEOWIDGET_H
#define VIDEOWIDGET_H
#include <QVideoWidget>class VideoWidget : public QVideoWidget
{Q_OBJECT
public:VideoWidget(QWidget *parent = nullptr);~VideoWidget();
};#endif // VIDEOWIDGET_H

videowidget.cpp

#include "videowidget.h"
#include <QDebug>VideoWidget::VideoWidget(QWidget *parent) :QVideoWidget (parent)
{
}VideoWidget::~VideoWidget()
{}

头文件mainwindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H#include <QMainWindow>
#include <QMediaPlayer>
#include <QMediaPlaylist>
#include "videowidget.h"
#include <QFileDialog>
#include <QLabel>namespace Ui {
class MainWindow;
}class MainWindow : public QMainWindow
{Q_OBJECTpublic:explicit MainWindow(QWidget *parent = nullptr);~MainWindow();void addToPlaylist(const QStringList &fileNames);private slots:void openFile(QString filename = "");void playFile();void stopVideo();void positionChange(qint64 position);protected:void dragEnterEvent(QDragEnterEvent *);void dropEvent(QDropEvent *);void wheelEvent(QWheelEvent *event);bool eventFilter(QObject *obj, QEvent *event);private:Ui::MainWindow *ui;QMediaPlayer *m_player;QString m_fileName;QMediaPlaylist *m_playlist;QMediaPlayer::State m_playerState;bool b_moveSlider;QLabel *timeStatus;};#endif // MAINWINDOW_H

源文件videowidget.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QtDebug>
#include <QDragEnterEvent>
#include <QDropEvent>
#include <QList>
#include <QMimeData>
#include <QTime>
#include <QWheelEvent>MainWindow::MainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::MainWindow)
{ui->setupUi(this);setWindowIcon(QIcon("://cd"));setAcceptDrops(true);m_player = new QMediaPlayer;m_playlist = new QMediaPlaylist;m_player->setPlaylist(m_playlist);m_player->setVideoOutput(ui->widget);b_moveSlider = false;//绑定信号槽connect(ui->bt_Open, SIGNAL(clicked()), this, SLOT(openFile()));connect(ui->bt_Play, SIGNAL(clicked()), this, SLOT(playFile()));connect(ui->bt_Stop, SIGNAL(clicked()), this, SLOT(stopVideo()));connect(m_player, SIGNAL(positionChanged(qint64)), this, SLOT(positionChange(qint64)));connect(m_player, &QMediaPlayer::mediaStatusChanged, this, [=] (QMediaPlayer::MediaStatus status) {if (status == QMediaPlayer::MediaStatus::EndOfMedia){playFile();}});timeStatus = new QLabel(this);timeStatus->setFrameStyle(QFrame::Box|QFrame::Sunken);ui->statusBar->addPermanentWidget(timeStatus);ui->progressBar->installEventFilter(this);
}MainWindow::~MainWindow()
{delete ui;
}void MainWindow::addToPlaylist(const QStringList &fileNames)
{foreach (QString const &name, fileNames){QFileInfo fileInfo(name);if (fileInfo.exists()){QUrl url = QUrl::fromLocalFile(fileInfo.absoluteFilePath());if (fileInfo.suffix().toLower() == "m3u"){m_playlist->load(url);}else{m_playlist->addMedia(url);}}}
}void MainWindow::openFile(QString filename)
{QStringList fileNames;if (filename.length() > 0){fileNames.append(filename);}else {fileNames = QFileDialog::getOpenFileNames(this, tr("Open Files"));}if (fileNames.length() <= 0){return;}int index = m_playlist->currentIndex();if (index >= 0){m_player->pause();m_playerState = QMediaPlayer::PausedState;m_playlist->removeMedia(index);}addToPlaylist(fileNames);playFile();positionChange(0);setWindowTitle(m_player->currentMedia().canonicalUrl().fileName());//在title处显示文件名
}void MainWindow::playFile()
{if (m_player->playlist()->isEmpty()){return;}if (m_playerState != QMediaPlayer::PlayingState){m_playerState = QMediaPlayer::PlayingState;m_player->play();ui->bt_Play->setText(tr("暂停"));}else{m_playerState = QMediaPlayer::PausedState;m_player->pause();ui->bt_Play->setText(tr("播放"));}}void MainWindow::stopVideo()
{m_playerState = QMediaPlayer::StoppedState;m_player->stop();ui->bt_Play->setText(tr("播放"));positionChange(0);
}
void MainWindow::positionChange(qint64 position)
{if(m_player->duration()/1000 != ui->progressBar->maximum()){ui->progressBar->setMaximum(static_cast<int>(m_player->duration()/1000));}ui->progressBar->setValue(static_cast<int>(position/1000));QTime initTime(0, 0, 0);QTime curtime = initTime.addMSecs(static_cast<int>(position));QTime totaltime = initTime.addMSecs(static_cast<int>(m_player->duration()));timeStatus->clear();timeStatus->setText(curtime.toString() + "/" +totaltime.toString());
}void MainWindow::dragEnterEvent(QDragEnterEvent *event)
{event->acceptProposedAction();QWidget::dragEnterEvent(event);
}void MainWindow::dropEvent(QDropEvent *event)
{QList<QUrl> urls = event->mimeData()->urls();if (urls.isEmpty()){return;}openFile(urls.first().toLocalFile());QWidget::dropEvent(event);
}void MainWindow::wheelEvent(QWheelEvent *event)
{QPoint numDegrees = event->angleDelta();int volume = m_player->volume();if (numDegrees.y() > 0){volume++;}else{volume--;}m_player->setVolume(volume);QMainWindow::wheelEvent(event);
}bool MainWindow::eventFilter(QObject *obj, QEvent *event)
{if (obj == ui->progressBar){if (event->type() == QEvent::MouseButtonRelease){//获取当前鼠标位置int currentX = static_cast<QMouseEvent*>(event)->x();//计算当前位置占整个slider的百分比double percentage = currentX*1.0/ui->progressBar->width();//计算具体只int value = percentage*(ui->progressBar->maximum() - ui->progressBar->minimum()) + ui->progressBar->minimum();ui->progressBar->setValue(value);qDebug()<<ui->progressBar->value();qint64 newValue = ui->progressBar->value() * 1000;if (!m_player->currentMedia().isNull()){m_player->setPosition(newValue);}}else if (event->type() == QEvent::MouseButtonPress){return true;}}return QMainWindow::eventFilter(obj, event);
}

直接获得媒体长度是0,需要用connect(m_player, SIGNAL(positionChanged(qint64)), this, SLOT(positionChange(qint64)));来获得positionChanged信号,才能得到媒体长度以及播放位置。

在用鼠标拖动slider更改播放位置时,如果移动鼠标到某个位置不放,会有播放位置来回跳动的问题。解决方法是移动鼠标时候断开positionChanged()信号,等放开鼠标后再连接。

2023.7.4:修正了鼠标设置播放位置不正确的问题,修正了播放结束状态不正确的问题。

QTgithub地址Q

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



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

相关文章

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

python与QT联合的详细步骤记录

《python与QT联合的详细步骤记录》:本文主要介绍python与QT联合的详细步骤,文章还展示了如何在Python中调用QT的.ui文件来实现GUI界面,并介绍了多窗口的应用,文中通过代码介绍... 目录一、文章简介二、安装pyqt5三、GUI页面设计四、python的使用python文件创建pytho

QT实现TCP客户端自动连接

《QT实现TCP客户端自动连接》这篇文章主要为大家详细介绍了QT中一个TCP客户端自动连接的测试模型,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录版本 1:没有取消按钮 测试效果测试代码版本 2:有取消按钮测试效果测试代码版本 1:没有取消按钮 测试效果缺陷:无法手动停

基于Qt实现系统主题感知功能

《基于Qt实现系统主题感知功能》在现代桌面应用程序开发中,系统主题感知是一项重要的功能,它使得应用程序能够根据用户的系统主题设置(如深色模式或浅色模式)自动调整其外观,Qt作为一个跨平台的C++图形用... 目录【正文开始】一、使用效果二、系统主题感知助手类(SystemThemeHelper)三、实现细节

Qt实现文件的压缩和解压缩操作

《Qt实现文件的压缩和解压缩操作》这篇文章主要为大家详细介绍了如何使用Qt库中的QZipReader和QZipWriter实现文件的压缩和解压缩功能,文中的示例代码简洁易懂,需要的可以参考一下... 目录一、实现方式二、具体步骤1、在.pro文件中添加模块gui-private2、通过QObject方式创建

Qt QWidget实现图片旋转动画

《QtQWidget实现图片旋转动画》这篇文章主要为大家详细介绍了如何使用了Qt和QWidget实现图片旋转动画效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、效果展示二、源码分享本例程通过QGraphicsView实现svg格式图片旋转。.hpjavascript

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏

【QT】基础入门学习

文章目录 浅析Qt应用程序的主函数使用qDebug()函数常用快捷键Qt 编码风格信号槽连接模型实现方案 信号和槽的工作机制Qt对象树机制 浅析Qt应用程序的主函数 #include "mywindow.h"#include <QApplication>// 程序的入口int main(int argc, char *argv[]){// argc是命令行参数个数,argv是

Python QT实现A-star寻路算法

目录 1、界面使用方法 2、注意事项 3、补充说明 用Qt5搭建一个图形化测试寻路算法的测试环境。 1、界面使用方法 设定起点: 鼠标左键双击,设定红色的起点。左键双击设定起点,用红色标记。 设定终点: 鼠标右键双击,设定蓝色的终点。右键双击设定终点,用蓝色标记。 设置障碍点: 鼠标左键或者右键按着不放,拖动可以设置黑色的障碍点。按住左键或右键并拖动,设置一系列黑色障碍点