音视频项目—基于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 该函数将渲染器上下文中的内容显示到屏幕上,通常在渲染循环的末尾调用以完成绘制并显示结果。

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

好了,先讲到这里。

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

相关推荐
xmRao1 小时前
Qt+FFmpeg 实现 PCM 音频转 AAC 编码
qt·ffmpeg·pcm
xmRao1 小时前
Qt+FFmpeg 实现录音程序(pcm转wav)
qt·ffmpeg
晚霞的不甘2 小时前
CANN 编译器深度解析:TBE 自定义算子开发实战
人工智能·架构·开源·音视频
愚公搬代码2 小时前
【愚公系列】《AI短视频创作一本通》016-AI短视频的生成(AI短视频运镜方法)
人工智能·音视频
那个村的李富贵3 小时前
CANN赋能AIGC“数字人”革命:实时视频换脸与表情驱动实战
aigc·音视频
晚霞的不甘3 小时前
CANN 支持强化学习:从 Isaac Gym 仿真到机械臂真机控制
人工智能·神经网络·架构·开源·音视频
晚霞的不甘7 小时前
CANN 支持多模态大模型:Qwen-VL 与 LLaVA 的端侧部署实战
人工智能·神经网络·架构·开源·音视频
拾荒的小海螺15 小时前
开源项目:LTX2 高效可控的开源视频生成模型
开源·音视频
EasyGBS1 天前
视频画面模糊、卡顿、丢失?EasyGBS新增“视频质量诊断”功能,告别人工盯屏
视觉检测·音视频·gb28181·花屏·视频质量诊断·蓝屏检测
zhuweisky1 天前
ArkTS实现鸿蒙手机视频聊天、屏幕分享(HarmonyOS)
音视频·harmonyos·鸿蒙开发