ffplay播放器剖析(7)----音视频暂停模块分析

文章目录

  • [1. 暂停触发流程](#1. 暂停触发流程)
  • [2. toggle_pause](#2. toggle_pause)
  • [3. stream_toggle_pause](#3. stream_toggle_pause)

1. 暂停触发流程

1.通过SDL触发事件调用toggle_pause

2.toggle_pause调用stream_toggle_pause

3.stream_toggle_pause修改暂停变量

2. toggle_pause

c 复制代码
static void toggle_pause(VideoState *is)
{
    stream_toggle_pause(is);
    is->step = 0;
}

3. stream_toggle_pause

c 复制代码
static void stream_toggle_pause(VideoState *is)
{
    // 如果当前是暂停 -> 恢复播放
    // 正常播放 -> 暂停
    if (is->paused) {// 当前是暂停,那这个时候进来这个函数就是要恢复播放
        /* 恢复暂停状态时也需要恢复时钟,需要更新vidclk */
        // 加上 暂停->恢复 经过的时间
        is->frame_timer += av_gettime_relative() / 1000000.0 - is->vidclk.last_updated;
        if (is->read_pause_return != AVERROR(ENOSYS)) {
            is->vidclk.paused = 0;
        }
        // 设置时钟的意义,暂停状态下读取的是单纯pts
        // 重新矫正video时钟

        set_clock(&is->vidclk, get_clock(&is->vidclk), is->vidclk.serial);
    }
    set_clock(&is->extclk, get_clock(&is->extclk), is->extclk.serial);
    // 切换 pause/resume 两种状态
    is->paused = is->audclk.paused = is->vidclk.paused = is->extclk.paused = !is->paused;
    printf("is->step = %d; stream_toggle_pause\n", is->step);
}

这个函数可以知道,如果当前状态是暂停的话,那么就会进入if函数

看一下if函数流程,首先我们知道我们

is->frame_timer += av_gettime_relative() / 1000000.0 - is->vidclk.last_updated;

这个就是在之前的基础上加上暂停到开始的时间

set_clock(&is->vidclk, get_clock(&is->vidclk), is->vidclk.serial);

get_clock当是暂停状态时就是获取时钟的pts

set_clock(&is->extclk, get_clock(&is->extclk), is->extclk.serial);

同理是设置外部时钟的

is->paused = is->audclk.paused = is->vidclk.paused = is->extclk.paused = !is->paused;

就是将paused取反

看一下这4个pause会影响那些函数

  1. video_refresh 如果是暂停并且没有强制刷新的话就不会调用该函数,什么时候强制刷新之前有说过,比如修改ffplay窗口大小
  2. read_thread中的pause只会对网络流有效,而其他情况下pause并不会对read_thread有影响,而是继续读数据写入到队列中
  3. get_master_clock中会调用get_clock,而get_clock中如果是paused状态的话就会直接返回pts
  4. audio_decode_frame函数会受到paused影响,会直接返回-1,然后sdl_audio_callback接受到会进行判断,然后输出静音数据,并未有暂停
相关推荐
LeonIter36 分钟前
视频判重需求:别为同一内容花两次钱!
音视频·特征提取·重复判定
二川bro2 小时前
第24节:3D音频与空间音效实现
3d·音视频
算家云2 小时前
腾讯最新开源HunyuanVideo-Foley本地部署教程:端到端TV2A框架,REPA策略+MMDiT架构,重新定义视频音效新SOTA!
人工智能·音视频·算家云·hunyuanvideo·模型部署教程·镜像社区
我是海飞7 小时前
Tensorflow Lite 的yes/no语音识别音频预处理模型训练教程
python·学习·tensorflow·音视频·嵌入式·语音识别
音视频牛哥7 小时前
具身智能的工程落地:视频-控制闭环的实践路径
人工智能·音视频·人工智能+·具身智能rtsp方案·具身智能rtmp方案·智能机器人rtsp方案·智能机器人rtmp低延迟
lichong9518 小时前
【混合开发】Android+Webview+VUE播放视频之视频解析工具mediainfo-Macos
android·macos·架构·vue·音视频·api·postman
百度智能云技术站18 小时前
百度智能云「智能集锦」自动生成短剧解说,三步实现专业级素材生产
人工智能·音视频
HelloRevit21 小时前
让B站视频4倍速度播放
前端·javascript·音视频
Ai工具分享21 小时前
视频增强AI哪个效果好?实战对比帮你找到最适合的工具
人工智能·音视频
wan5555cn1 天前
【警惕】疑似一种新型金融黑灰产骗局大规模爆发
笔记·深度学习·音视频·生活