gpt4 book ai didi

linux - FFmpeg 截屏录制 : which codecs to use?

转载 作者:太空狗 更新时间:2023-10-29 11:10:30 25 4
gpt4 key购买 nike

我一直在尝试使用 FFmpeg 的 X11grab 模块录制截屏视频,到目前为止,它或多或少地工作得很好。我知道 a/v 编码是一个复杂的过程,有很多细节,但我正在尽我最大的努力学习。

我想对视频流进行“轻量级”录制,这样可以在录制流时尽可能减少对系统的压力。我用 pacat 和 sox 分别录制两个音频流。后来,整个事情被过滤、规范化、编码,并组合到一个 Matroska 容器中。

现在,我正在让 ffmpeg 记录一个原始视频流以提供给 x264 的 yuv4 多路分解器。我之前尝试过 ffv1 和直接 x264 录制。我的系统无法在我想要的最终流设置上使用 x264 进行实时编码,因此我必须在录制完成后单独重新压缩。我发现 ffv1 和 yuv4 都给我带来了可怕的丢帧,但不那么严重。我怀疑这是由于硬盘速度所致,即使我坐在专门用于保存记录数据的 SATA3 Caviar Black 中也是如此。

问题是,我应该查看哪种视频编解码器组合?直接在 x264 中录制并稍后重新压缩为“更好的”x264?原始视频,然后压缩?我将如何着手查明问题,例如我遇到的丢帧问题?

编辑:这是我目前使用的 ffmpeg 行。

ffmpeg -v warning -f x11grab -s 1920x1080 -r 30000/1001 -i :0.0\
-vcodec rawvideo -pix_fmt yuv420p -s 1280x720\
-threads 0\
recvideo.y4m

最佳答案

你试过了吗http://en.wikipedia.org/wiki/Huffyuv

您确定您的问题是 CPU 还是磁盘带宽?您尝试写入磁盘的数据速率是多少?在您的比特率和设置下,ffmpeg 的编解码器需要多少 CPU?我假设您没有记录空闲的计算机 - 它有多少资源可用于记录?

为了测试磁盘写入性能,只需分配 100MB,从 /dev/urandom 读取 100MB 到其中,然后在磁盘空闲时将缓冲区写入该磁盘上的文件。测量写入需要多长时间(从 urandom 读取需要时间)。 Linux 具有写回功能,这意味着它每 5 秒将脏页刷新到磁盘,而不是在您写入时立即刷新。使用 fdatasync(或完整的 fsync)将为您提供实时信息,直到数据存入磁盘。

为什么看不到ffmpeg的cpu使用情况?录制一分钟显示 top 的终端窗口怎么样?如果没有,在终端中 perf record -a sleep 60 怎么样,然后切换到你所做的,记录一分钟,然后是 perf report

编辑:我使用了avconv -v warning -f x11grab -s 1680x1050 -r 30000/1001 -i :0.0 -vcodec ffvhuff -s 1280x720 -threads 0 capture.mkv 并且用 RGB 记录效果很好。然后,您可以离线转码为 YUV 中的 H.264,双 channel 以获得最高质量等。我得到了大约 24MB/秒,但它似乎是单线程的。我的 Core2 @ 2.3Ghz 没问题。

关于linux - FFmpeg 截屏录制 : which codecs to use?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10166204/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com