音视频项目—基于FFmpeg和SDL的音视频播放器解析(二十)

介绍

在本系列,我打算花大篇幅讲解我的 gitee 项目音视频播放器,在这个项目,您可以学到音视频解封装,解码,SDL渲染相关的知识。您对源代码感兴趣的话,请查看基于FFmpeg和SDL的音视频播放器

如果您不理解本文,可参考我的前一篇文章音视频项目---基于FFmpeg和SDL的音视频播放器解析(十九)

解析

接着上文,我们继续解析 videooutput 的函数。

videoRefresh
cpp 复制代码
void VideoOutput::videoRefresh(double* remaining_time){
    AVFrame* frame = nullptr;
    frame = frame_queue->Front();
    if(frame){
        double pts = frame->pts * av_q2d(time_base);
        double diff = pts - avsync->GetClock();
        if(diff > 0){
            *remaining_time = FFMIN(*remaining_time, diff);
            return;
        }
        rect.x = 0;
        rect.y = 0;
        rect.w = video_width;
        rect.h = video_height;
        SDL_UpdateTexture(texture, &rect, frame->data[0], frame->linesize[0],
                          frame->data[1], frame->linesize[1],
                          frame->data[2], frame->linesize[2]);
        SDL_RenderClear(renderer);
        SDL_RenderCopy(renderer, texture, NULL, &rect);
        SDL_RenderPresent(renderer);
        frame = frame_queue->Pop(1);
        av_frame_free(&frame);
    }
}

这个函数负责渲染帧。

首先,frame = frame_queue->Front();取出视频帧队列的头部数据。

然后,double pts = frame->pts * av_q2d(time_base); 计算出这一帧在时间的显示位置

diff 是该帧显示时间与当前时间的差值

当 diff 大于 0 时,说明当前帧比较快,要等一会播放。FFMIN 是取最小值的宏定义

cpp 复制代码
#define FFMIN(a,b) ((a) > (b) ? (b) : (a))

remaining_time 就是取两者的最小值。然后返回,等待。

rect.x = 0;窗口的左上角的横向偏移值为 0

rect.y = 0;窗口的左上角的纵向偏移值为 0

rect.w = video_width;设置窗口的宽度

rect.h = video_height;设置窗口的高度

SDL_UpdateTexture 更新纹理

SDL_RenderClear 清除屏幕上的旧内容,为绘制新的帧做准备

SDL_RenderCopy 用于将一个表面(surface)复制到当前的渲染目标(destination)。这通常用于在屏幕上显示图像或纹理。

SDL_RenderPresent 该函数将渲染器上下文中的内容显示到屏幕上,通常在渲染循环的末尾调用以完成绘制并显示结果。

最后,弹出帧队列数据,并释放数据。

好了,先讲到这里。

欲知后事如何,请听下回分解。

相关推荐
昨日之日20061 小时前
LatentSync V8版 - 音频驱动视频生成数字人说话视频 更新V1.6版模型 支持50系显卡 支持批量 一键整合包下载
人工智能·音视频
知舟不叙3 小时前
基于OpenCV实现视频运动目标检测与跟踪
opencv·目标检测·目标跟踪·音视频
allnlei5 小时前
修改FFMpeg的日志函数av_log,使其在记录日志时能显示调用该函数的位置(文件名和行号)
ffmpeg
sukalot6 小时前
window 显示驱动开发-处理视频帧
驱动开发·音视频
Sherlock Ma7 小时前
Seedance:字节发布视频生成基础模型新SOTA,能力全面提升
人工智能·深度学习·计算机视觉·aigc·音视频·扩散模型·视频生成
Everbrilliant8910 小时前
音视频之H.264/AVC编码器原理
音视频·h.264·h.264编解码·h.264帧内预测·h.264帧间预测·h.264的sp/si帧技术·h.264码率控制
s_little_monster10 小时前
【Linux开发】海思摄像头内部视频处理模块
linux·运维·经验分享·学习·音视频·嵌入式开发·海思
vfvfb19 小时前
视频音频去掉开头结尾 视频去掉前n秒后n秒 电视剧去掉开头歌曲
音视频·批量去掉视频开头·批量去掉崇·去掉mp3开头几秒·批量去掉视频结尾歌曲
Coovally AI模型快速验证19 小时前
SLAM3R:基于单目视频的实时密集3D场景重建
神经网络·算法·3d·目标跟踪·音视频
no_work1 天前
深度学习小项目合集之音频语音识别-视频介绍下自取
pytorch·深度学习·cnn·音视频·语音识别·梅卡尔