gpt4 book ai didi

python - 使用 openCV 从 numpy 数组生成视频

转载 作者:行者123 更新时间:2023-12-04 12:10:07 29 4
gpt4 key购买 nike

我正在尝试使用 openCV VideoWriter 类从 numpy 数组生成视频。我正在使用以下代码:

import numpy as np
import cv2
size = 720*16//9, 720
duration = 2
fps = 25
out = cv2.VideoWriter('output.avi', cv2.VideoWriter_fourcc(*'X264'), fps, size)
for _ in range(fps * duration):
data = np.random.randint(0, 256, size, dtype='uint8')
out.write(data)
out.release()
编解码器似乎已安装,因为 ffmpeg 可以转换为 x264 编解码器并安装了 libx264。代码在没有警告的情况下运行,但是生成的视频似乎不包含任何数据,因为我在尝试使用 mpv 阅读它们时总是收到以下消息:

[ffmpeg/demuxer] avi: Could not find codec parameters for stream 0 (Video: h264 (X264 / 0x34363258), none, 1280x720): unspecified pixel format


这个问题的原因可能是什么?

最佳答案

第一个问题是您尝试使用黑白帧创建视频,而 VideoWriter 默认采用彩色。 VideoWriter 有第 5 个 bool 参数,您可以在其中传递 False 来指定视频是黑白的。
第二个问题是 cv2 期望的维度与 numpy 是相反的。因此,大小应该是 (size[1], size[0])。
另一个可能的问题是正在使用的编解码器。我一直无法让“X264”在我的机器上工作,而是一直使用“mp4v”作为编解码器,使用“.mp4”作为容器类型,以获得 H.264 编码输出。
在所有这些问题都解决之后,这就是结果。请试试这个,看看它是否适合你:

import numpy as np
import cv2
size = 720*16//9, 720
duration = 2
fps = 25
out = cv2.VideoWriter('output.mp4', cv2.VideoWriter_fourcc(*'mp4v'), fps, (size[1], size[0]), False)
for _ in range(fps * duration):
data = np.random.randint(0, 256, size, dtype='uint8')
out.write(data)
out.release()

关于python - 使用 openCV 从 numpy 数组生成视频,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62880911/

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