利用ffmpeg截图和生成gif

从视频中截取指定数量的图片 

ffmpeg -i input.mp4 -ss 00:00:10 -vframes 1 output.jpgffmpeg -i input.mp4 -ss 00:00:10 -vframes 180 output.jpg
-vframes 180代表截取180帧,
实测后发现如果视频是60fps,那么会从第10秒截取到第13秒
  • -i input.mp4:指定输入视频文件。
  • -ss 00:00:10:定位到视频的第10秒。
  • -vframes 1:指定只提取一帧。
  • output.jpg:输出截图文件。

从视频中提取多帧截图

ffmpeg -i input.mp4 -vf fps=1/60 output_%03d.jpg
  • fps=1/60fps=帧数/秒 的形式

  • 1/60 表示 1 帧每 60 秒(即每分钟 1 张图),通常用于长视频中低频截图(比如做缩略图或监控抽帧)

截取多张图时,通配符文件名规则

output_%03d.jpg:输出文件命名格式,%03d表示三位数字编号
举例:
output_%03d.jpg
输出
output_001.jpg
output_002.jpg
output_003.jpg

 从视频中提取特定时间段的截图

ffmpeg -i input.mp4 -ss 00:01:00 -to 00:02:00 -vf fps=1/10 output_%03d.jpg-vf 是 -filter:v 的简写,表示对视频流使用视频滤镜。fps=1/10 指每10秒提取一帧。意味着1分钟内截6张图
  • -ss 00:01:00:开始时间,从第1分钟开始。
  • -to 00:02:00:结束时间,到第2分钟结束。
  • -vf fps=1/10:每10秒提取一帧,如果视频有1分钟,那么仅截图6张图

截图时长说明-t与-to区别

参数顺序影响行为​

-t是相对时间(持续时间)和-to​绝对时间

  • ​推荐将 -ss 和 -t/-to 放在 -i 之前​​:
    这样 FFmpeg 会直接跳转到指定时间点(快速但不精确,依赖关键帧)。
  • ​将 -ss 放在 -i 之后​​:
    FFmpeg 会解码到指定时间点(速度慢但精确到帧)。
  • #举例说明
    # 快速截取(依赖关键帧,可能不精确)
    ffmpeg -ss 10 -to 15 -i input.mp4 output.mp4# 精确截取(逐帧解码,速度慢)
    ffmpeg -i input.mp4 -ss 10 -to 15 output.mp4

设置截图质量

 如果需要提取高质量的截图,可以指定输出图片的质量:

ffmpeg -i input.mp4 -ss 00:00:10 -vframes 1 -q:v 2 output.jpg
  • -q:v 2:设置输出图片的质量,数值越小质量越高,范围是1-31。

截图并设置分辨率

ffmpeg -i input.mp4 -ss 00:00:10 -vframes 1 -s 640x360 output.jpg
  • -s 640x360:设置输出图片的分辨率为640x360。

关键帧限制​:若视频关键帧间隔大,快速定位(-ss-i前)可能无法精确到非关键帧。,所以为了精确,需要先-i然后再-ss

截取第5秒的第1帧(快速定位,可能不精确)

ffmpeg -ss 5 -i input.mp4 -vframes 1 -q:v 2 output.jpg

特点​​:-ss-i前,优先用关键帧定位,速度快但可能不精确。

精确截取第5秒的帧(较慢但准确)

ffmpeg -i input.mp4 -ss 5 -vframes 1 -q:v 2 output.jpg
  • ​特点​​:-ss-i后,逐帧解码到指定时间,速度慢但更精确。

截取第5.5秒的帧(精确到小数)

ffmpeg -ss 5.5 -i input.mp4 -vframes 1 output.png

 输出PNG格式并设置图片品质

ffmpeg -ss 5 -i input.mp4 -vframes 1 -compression_level 0 output.png-compression_level:取值范围:0 到 9含义:0:最小压缩,生成的文件较大,但处理速度快9:最大压缩,文件体积小,但处理速度慢默认值:-compression_level 6

时间精度​:支持毫秒级时间(如00:00:05.500

文件名通配符

ffmpeg -ss 5 -i input.mp4 -vframes 1 output_%03d.jpg
  • 效果​​:生成 output_001.jpg
  • ​占位符说明​​:
    • %03d:3位数字编号(如 001002)。
    • %d:无填充编号(如 12)。

每秒截n张图

ffmpeg -i input.mp4 -r 7.5 -q:v 2 output_%03d.jpg

参数详解:

-r n表示一秒内我一共想提取n帧,也就是每秒的帧率,即fps

可理解为:视频的fps/n=每隔x帧截取一次图片

  • -r 7.5表示如果原视频是 30fps,每 4 帧截图一次,30/4= 7.5fps。

  • 如果原视频是 60fps,每5帧截图一次,60/5=12

把视频直接做成gif

体积小
./ffmpeg -ss 00:00:00 -to 00:00:10 -i ../input.mp4 -filter_complex "[0:v]fps=20,scale=400:-1" output_20fps.gif颜色质量高,体积适宜,需要分2步
第一步:生成调节板
./ffmpeg -ss 00:00:00 -to 00:00:10 -i ../coe33.mp4 -vf "fps=10,scale=400:-1:flags=lanczos,palettegen" palette.png
第二步:参考调班板生成图片
./ffmpeg -ss 00:00:00 -to 00:00:10 -i ../input.mp4 -i palette.png -filter_complex "[0:v]fps=20,scale=400:-1:flags=lanczos[x];[x][1:v]paletteuse"  output_20fps.gif以下命令无需预先生成调色板#生成黑白色gif
./ffmpeg -ss 00:00:00 -to 00:00:10 -i ../input.mp4 -filter_complex "[0:v]fps=20,scale=400:-1,split[a][b];[a]palettegen=max_colors=2:reserve_transparent=0[p];[b][p]paletteuse=dither=floyd_steinberg" blackwhite.gif#256色
./ffmpeg -ss 00:00:00 -to 00:00:10 -i ../input.mp4 -filter_complex "[0:v]fps=20,scale=400:-1,split[a][b];[a]palettegen=max_colors=256[p];[b][p]paletteuse=dither=floyd_steinberg" o256colors.gif

多个参数混用

./ffmpeg -ss 00:00:00 -to 00:00:10 -i ../input.mp4 -filter_complex "[0:v]fps=20,scale=400:-1:flags=lanczos,split[a][b];[a]palettegen=max_colors=256:stats_mode=diff[p];[b][p]paletteuse=dither=floyd_steinberg" o256colors.gif

上述代码的关键参数解析

  1. split[a][b]
    将视频流拆分为两个分支 [a] 和 [b],分别用于生成调色板和应用调色板。

  2. palettegen=max_colors=256

    • max_colors=256:设置调色板最大颜色数量(默认 256,GIF 支持的最大值)。
    • 若需减小文件体积,可降低此值(如 max_colors=128)。
  3. paletteuse=dither=floyd_steinberg

    • dither=floyd_steinberg:使用高质量抖动算法(推荐保留颜色过渡)。
    • 若需减小体积,可改用 dither=none 或 dither=bayer

dither=none表示不使用抖动,直接使用调色板中最接近的颜色替换原颜色。这会导致颜色过渡生硬,出现色带,但文件体积小,适合颜色简单的图像。

dither=bayer使用拜耳矩阵抖动,通过有序的图案扩散误差,模拟更多颜色。这种方法在低颜色深度下能减少色带,但可能引入可见的图案,体积比none大但比floyd_steinberg小。

实测发现生成gif体积排序是bayer>floyd_steinberg>none

如何选择?​

  • ​优先体积​​:选 dither=none(如生成文件大小敏感的 LOGO)。
  • ​优先画质​​:选 dither=floyd_steinberg(误差扩散算法,更平滑)。
  • ​平衡方案​​:选 dither=bayer(动态 GIF 或分辨率较高的静态图)。

dither=bayer时,bayer_scale可控制gif大小

paletteuse=dither=bayer:bayer_scale=0

./ffmpeg -ss 00:19:50 -t 5 -i ../input.mp4  -filter_complex "[0:v]fps=15,scale=700:-1:flags=lanczos,split[a][b];[a]palettegen=max_colors=128:stats_mode=diff[p];[b][p]paletteuse=dither=bayer:bayer_scale=5" output.gif

bayer_scale取值范围[0,5],实测发现0体积最大,5体积最小

缩小gif体积的方法

1上文中提到的调色板

2:使用 gifsicle 后处理压缩​

# 安装 gifsicle(macOS: brew install gifsicle, Linux: apt-get install gifsicle)
gifsicle -O3 --lossy=80 input.gif -o output_compressed.gif参数说明​​:
-O3:最高级别压缩优化。
--lossy=80:有损压缩(值越大,压缩率越高,画质损失越大)。

3:动态区域裁剪​

-vf "crop=300:200:20:50"  # 截取 300x200 区域(从坐标 x=20,y=50 开始)
-filter_complex后面也可以用crop
例如
./ffmpeg -ss 00:19:50 -t 5 -i ../input.mp4 -filter_complex "[0:v]scale=300:-1,crop=130:120:70:70" output.gif

避免 -fs​:除非接受尾部截断,否则不要使用 -fs

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/81935.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

系统架构设计师案例分析题——数据库缓存篇

一.核心知识 1.redis和MySQL的同步方案怎么做的? 读数据:先查询缓存,缓存不存在则查询数据库,然后将数据新增到缓存中写数据:新增时,先新增数据库,数据库成功后再新增缓存;更新和删…

什么是智能体?

什么是智能体? 智能体(AI Agent)是一种能够自主感知环境、做出决策并执行任务的智能实体,其核心依赖大型语言模型(LLM)或深度学习算法作为“大脑”模块。它通过感知模块(如多模态输入&#xff…

企业数字化转型是否已由信息化+自动化向智能化迈进?

DeepSeek引发的AI热潮迅速蔓延到了各个行业,目前接入DeepSeek的企业,涵盖了科技互联网、云服务、电信、金融、能源、汽车、手机等热门领域,甚至全国各地政府机构也纷纷引入。 在 DeepSeek 等国产 AI 技术的推动下,众多企业已经敏锐…

广州卓远VR受邀参加2025智能体育典型案例调研活动,并入驻国体华为运动健康联合实验室!

近日,“2025年智能体育典型案例调研活动”在东莞松山湖成功举办。本次调研活动由国家体育总局体育科学研究所和中国信息通信研究院联合主办,旨在深入贯彻中央关于培育新型消费的战略部署,通过激活智能健身产品消费潜力,加快运动健…

springboot+vue实现鲜花商城系统源码(带用户协同过滤个性化推荐算法)

今天教大家如何设计一个 鲜花商城 , 基于目前主流的技术:前端vue3,后端springboot。学习完这个项目,你将来找工作开发实际项目都会又很大帮助。文章最后部分还带来的项目的部署教程。 系统有着基于用户的协同过滤推荐算法,还有保证…

【android bluetooth 协议分析 02】【bluetooth hal 层详解 3】【高通蓝牙hal主要流程介绍-上】

1. 背景 本节主要讨论 高通 蓝牙 hal 中,的一些流程。 看看你是否都清楚如下问题: 高通芯片电如何控制?串口是在哪里控制的?固件如何下载?初始化流程是怎么样的? 如果你已经对上述讨论的问题&#xff0c…

JavaEE 初阶文件操作与 IO 详解

一、文件操作基础:File 类 作用:操作文件或目录(创建、删除、获取信息)。 核心方法: exists():文件是否存在createNewFile():创建新文件mkdir():创建目录delete():删除…

C++(27): 标准库 <iterator>

目录 1. 核心概念 2. 基本语法 3. 特点 4. 特有成员函数与工具 5. 内存与性能 6. 示例代码 7. 成员函数与类型 8. 使用场景 9. 注意事项 1. 核心概念 迭代器(Iterator) 是 C++ 中用于访问和遍历容器元素的通用接口,类似于指针,但支持更丰富的操作。 抽象访问机制:…

谈谈 Kotlin 中的构造方法,有哪些注意事项?

在 Kotlin 中,构造方法分为主构造方法(Primary Constructor)和次构造方法(Secondary Constructor)。 1 主构造方法 主构造方法是类的核心构造方法,直接在类头声明,位于类名之后。 1.1 基本语…

年会招标抽奖活动软件———仙盟创梦IDE

年会是企业一年的总结与欢庆时刻,而抽奖环节更是点燃全场气氛的关键。如何让抽奖环节既大气又充满仪式感?选对抽奖软件至关重要!本文精心挑选了 3 款兼具实用性与氛围感的年会抽奖软件,从界面设计到功能特色,全方位为你…

安全软件检测进程异常行为-Postgresql应用执行异常指令whoami

文章目录 环境症状问题原因解决方案 环境 系统平台:UOS(海光) 版本:4.5.8 症状 数据库安装包: 安全软件告警中提示“sh -c whoami”命令,是由数据库发出的,安全软件捕获到了postgres.exe–fo…

车载诊断架构 --- LIN 节点 ECU 故障设计原则

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 钝感力的“钝”,不是木讷、迟钝,而是直面困境的韧劲和耐力,是面对外界噪音的通透淡然。 生活中有两种人,一种人格外在意别人的眼光;另一种人无论…

GPU加速的AlphaFold3蛋白质复合体预测:如何在64GB显存下跑超大规模模型(混合精度+模型并行实战技巧)

一、AlphaFold3的超大规模挑战与优化方向 AlphaFold3作为当前生物计算领域的革命性工具,其核心架构基于扩散模型,能够预测包含蛋白质、核酸、小分子配体等复杂生物复合物的三维结构。然而,模型参数量级(典型配置超百亿级&#xf…

Qt功能区:Ribbon控件

控件 1. 按钮1.1 多选按钮1.2 2. 下拉列表框SARibbonComboBox2.1 简介2.2 代码实现 1. 按钮 1.1 多选按钮 软件功能:用于实现Category的名称居中。 SARibbonCheckBox继承于QCheckBox,使用方法完全相同。 SARibbonCheckBox* checkBox new SARibbonChe…

一个由微软开源的 Python 工具,用于将多种文件格式转换为 Markdown 格式

📚 Markitdown 由微软开源的 Python 工具,用于将多种文件格式转换为 Markdown 格式 支持:PDF、PowerPoint、Word、Excel、图像、音频、HTML、文本格式(CSV、JSON、XML)、ZIP 文件的转换。 它旨在提供一个简单且灵活的…

Linux的进程概念

目录 1、冯诺依曼体系结构 2、操作系统(Operating System) 2.1 基本概念 2.2 目的 3、Linux的进程 3.1 基本概念 3.1.1 PCB 3.1.2 struct task_struct 3.1.3 进程的定义 3.2 基本操作 3.2.1 查看进程 3.2.2 初识fork 3.3 进程状态 3.3.1 操作系统的进程状态 3.3…

export和import的书写方式

一、导出模块(export) 1. 命名导出(Named Exports) // math.js export const PI 3.14159; // 导出单个常量 export function sum(a, b) { return a b; } // 导出单个函数 export class Calculator { /* ..…

HOW - 结合 AI 进行 Tailwind 样式开发

文章目录 情况 1:使用 Tailwind CSS 与手写传统 CSS 的开发效率对比情况 2:AI Tailwind 自动生成 UI 的效率如何?总结 在 WHAT - Tailwind 样式方案(不写任何自定义样式) 中我们已经简单介绍过 Tailwind。今天主要认识…

java面试每日一背 day1

1.什么是缓存穿透 缓存穿透是指查询一个数据库中根本不存在的数据,导致这个查询请求绕过缓存直接访问数据库的情况。这种情况如果频繁发生,会对数据库造成不必要的压力。 典型特征: (1)查询的数据在数据库和缓存中都…

ngx_http_realip_module 模块概述

一、使用场景 日志记录 记录真实客户端 IP 而非反向代理的 IP,有助于流量分析和安全审计。访问控制 基于真实 IP 实现防火墙规则(allow/deny)或限流,而非误将上游 IP 视为客户端。GeoIP、WAF、限速等功能 模块化的上游真实 IP 支…