作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 FLUENT-FFMPEG 和 Node js 生成 Sprite 图像(组合缩略图/屏幕截图),图像看起来像这样。
这是我用于生成 Sprite 图像/缩略图的 Node js 脚本。
const ffmpegPath = require("@ffmpeg-installer/ffmpeg").path;
const ffmpegCommand = require("fluent-ffmpeg");
ffmpegCommand.setFfmpegPath(ffmpegPath);
let videoUrl =
"http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/ElephantsDream.mp4";
const filename = `output_image`;
ffmpegCommand(videoUrl)
.seekInput("00:00:01.000")
.outputOptions([
"-q:v",
"8",
"-frames:v",
"1",
"-vsync",
"0",
"-qscale",
"50",
"-vf",
"fps=1/10,scale=128:72,tile=11x11",
])
.addOption("-preset", "superfast")
.on("error", (err) => {
console.log("error", err);
reject(err);
})
.save(`./tmp/${filename}.png`);
不幸的是,生成这张非常糟糕的图像需要将近 3 分钟。
let videoUrl ="./videos/t.mp4";
然后生成缩略图需要不到 3 秒的时间。
let videoUrl ="http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/ElephantsDream.mp4";
很奇怪,根据视频的不同,生成超过 3 分钟的缩略图需要很长时间。
最佳答案
tl;博士使用 -discard nokey
输入选项
它需要很长时间,因为它正在解码所有视频帧以覆盖 1210 秒(约 2 分钟的内容)。 ...好吧,我不知道为什么您的设置需要 3 分钟...
无论如何,从 fps
开始filter 可以很好地减少过滤负载(仅对您要包含的帧执行缩放)但它不会阻止所有帧被解码,仅用于丢弃大部分帧(仅保留 1 个240)。
防止解码器处理所有帧的一种方法(唯一方法?)是告诉它忽略非关键帧。关键帧间隔应该足够紧,您仍然可以获得所需的效果。
我已经使用以下命令对其进行了测试:
ffmpeg -ss 1 -discard nokey -i "{inurl}" \
-vf fps=1/10,scale=128:72,tile=11x11 \
-an -frames:v 1 {outurl}
我的(大约 10 岁)电脑在没有
-discard nokey
的情况下花了 36.3 秒而这个选项只用了 2.7 秒。 (在 Python 中测试)
关于javascript - FFMPEG 需要 3 分钟生成缩略图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71878115/
我有一个具有可变数量子元素的固定大小的 div。我不知道 children 的大小。目标是缩小它们以适合父级。 例子: .parent { width: 100px; height: 100p
我是一名优秀的程序员,十分优秀!