QT——视频播放

该博客介绍如何在QT界面使用QPainter绘制ffmpeg解码后的每一帧图片,通过设置渲染提示和调整图片大小以适应窗口,实现视频帧在透明背景的QWidget上平滑播放。解码部分使用了ffmpeg库,解码后的图像经过转换并发射信号传递到界面进行显示。
摘要由CSDN通过智能技术生成

在我的另一篇博客中介绍了硬解码和软解码,ffmpeg解码
在这篇文章中,主要介绍软解码获取的图片,在QT界面中播放,
获取解码后的每一帧图片,将图片通过QT中Qwidget自带的paintEvent事件,绘制到界面上

void PondingVideoWidget::paintEvent(QPaintEvent * )
{
	QPainter painter(this);
	painter.setRenderHint(QPainter::Antialiasing);
	painter.setRenderHint(QPainter::TextAntialiasing);
	painter.setRenderHint(QPainter::SmoothPixmapTransform);
	painter.setRenderHint(QPainter::HighQualityAntialiasing);
	painter.setBrush(Qt::black);
	painter.drawRect(0, 0, this->width(), this->height());
	if (mImage.size().width() <= 0) return;
	QImage img = mImage.scaled(this->size(), Qt::KeepAspectRatio);
	int x = this->width() - img.width();
	int y = this->height() - img.height();
	x = x / 2;
	y = y / 2;
	painter.drawImage(QPoint(x, y), img);
}

在这里做一个简单的实现方式

首先创建一个QWidge界面,getFrame是一个槽函数,这里没有写,

#include "ponding_video_widget.h"
#include "video_blending/video_blender.h"
#include "customize_files/mymessage.h"

PondingVideoWidget::PondingVideoWidget(QString name, QString path, QWidget *parent) :QWidget(parent)
{
	setFixedSize(622, 350);
	setAttribute(Qt::WA_StyledBackground, true);
	setAttribute(Qt::WA_TransparentForMouseEvents, true);
	setWindowFlags(Qt::FramelessWindowHint);
	setAttribute(Qt::WA_TranslucentBackground);
	setAttribute(Qt::WA_DeleteOnClose);

}
void PondingVideoWidget::paintEvent(QPaintEvent * )
{
	QPainter painter(this);
	painter.setRenderHint(QPainter::Antialiasing);
	painter.setRenderHint(QPainter::TextAntialiasing);
	painter.setRenderHint(QPainter::SmoothPixmapTransform);
	painter.setRenderHint(QPainter::HighQualityAntialiasing);
	painter.setBrush(Qt::black);
	painter.drawRect(0, 0, this->width(), this->height());
	if (mImage.size().width() <= 0) return;
	QImage img = mImage.scaled(this->size(), Qt::KeepAspectRatio);
	int x = this->width() - img.width();
	int y = this->height() - img.height();
	x = x / 2;
	y = y / 2;
	painter.drawImage(QPoint(x, y), img);
}
void PondingVideoWidget::getFrame()
{
	mImage = frame.img;
	this->update();
}

解码部分,只写一部分,对比解码文章就可以了
这里将图面通过信号发射出去,每一帧发射一次信号,然后界面接收,并绘制,

if (got_picture)
			{
				sws_scale(imgConvertCtx,
					(uint8_t const * const *)pFrame->data,
					pFrame->linesize, 0, pCodecCtx->height, pFrameBGR->data,
					pFrameBGR->linesize);

				VideoFrame frame;
				frame.width = pFrame->width;
				frame.height = pFrame->height;
				frame.data = QByteArray((char *)outBuffer, byteNum * sizeof(uint8_t));
				QImage tmpImg((uchar *)outBuffer, pCodecCtx->width, pCodecCtx->height, QImage::Format_RGB32);
				frame.img = tmpImg.convertToFormat(QImage::Format_RGB888, Qt::NoAlpha);
                emit frame.img;
				frameQueue->push_back(frame);
			}

不懂的话,可以私信交流

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值