首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Fffmpeg绘图过滤器,创建大的输出文件大小和占用高cpu?

Fffmpeg绘图过滤器,创建大的输出文件大小和占用高cpu?
EN

Stack Overflow用户
提问于 2019-07-09 12:20:09
回答 1查看 387关注 0票数 0

我有一个视频输入文件,我是在上面画一个用户图片文本。我可以使用ffmpeg的图形文本过滤器在视频文件上绘制文本,并且它可以工作文件,但主要问题出现在ffmpeg命令上。

也就是说,当我运行ffmpeg命令时,会发生三种情况:- 1.输出视频文件大小大于输入文件大小。2.输出视频文件比输入视频文件失去视频质量。3. cpu非常高。

使用的ffmpeg命令是-

代码语言:javascript
复制
ffmpeg -i input1.asf -vf drawtext="fontfile=/path/to/font.ttf: \text='Stack Overflow': fontcolor=white: fontsize=24: box=1: boxcolor=black@0.5: \boxborderw=5: x=10: y=10" -codec:a copy IndVsNZ.asf

为了避免视频质量的损失,我使用了这个参数"-c:v libx264 -crf 20“。

我正在努力实现的是,我可以在我的视频文件上绘制文本,而不损失质量,输出文件大小与输入文件相同,cpu较低(因为它挂起了我的系统)。

我在互联网上尝试过各种各样的解决方案,但没有发现问题。如果有任何与此相关的链接,请共享。我是新来的。

谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-07-09 17:58:59

您正在比较不同的格式、不同的编码器实现以及处理生成损失。

输出视频文件大小大于输入文件大小。 输出视频文件比输入视频文件失去视频质量。

您的输入视频流可能是一种现代、高效的格式,如H.264。然而,使用.asf输出ffmpeg的默认编码器是msmpeg4v3,它输出视频格式MPEG-4,第2部分,微软变体版本3。这是一个旧的,相对低效的编码器,带有糟糕的默认设置。由于它的效率较低,同样的质量需要更多的比特。这就是为什么添加-c:v libx264 -crf 20可以提高每比特的质量,因为这样可以获得更好的编码器和更现代的格式(H.264)。

您还需要重新编码有损输入中的压缩工件,这可能会进一步损害可压缩性。这叫做发电损失

如果您想要H.264视频,那么您可以做的是调整CRF值。给它提供一个可接受的质量的最高价值。试一试范围从18-26左右。使用最慢的-preset你有耐心。有关更多信息,请参见FFmpeg Wiki: H.264

cpu越来越高了。

这是意料之中的。视频编码在计算上是昂贵的。您可以使用-threads选项减少编码线程的数量,并/或使用单独的工具来控制CPU的使用,例如Linux上的nice。但这将使编码耗时更长。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56952469

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档