我正在尝试使用moviepy生成带有文本的视频。首先,我想显示一条消息,然后再显示另一条。在我的情况下,我想显示“狗”一秒钟,而不是“猫猫”。为此,我使用以下代码:
从moviepy.editor导入*
def my_func(messeges):
clips = {}
count = 0
for messege in messeges:
count += 1
clips[count] = TextClip(messege, fontsize=270, color='green')
clips[count] = clips[count].set_pos('center').set_duration(1)
clips[count].write_videofile(str(count) + '.avi', fps=24, codec='mpeg4')
videos = [clips[i+1] for i in range(count)]
video = concatenate(videos)
video.write_videofile('test.avi', fps=24, codec='mpeg4')
video = VideoFileClip('test.avi')
video.write_gif('test.gif', fps=24)
if __name__ == '__main__':
ms = []
ms += ['Dog']
ms += ['Cat Cat']
my_func(ms)
这就是我得到的结果:
有人知道我为什么和猫有问题吗?
要写入文件,所有帧必须具有相同的大小。在这里,狗的帧比猫的帧小,这会破坏视频。第一种解决方案是在串联视频剪辑中使用“合成”方法,这将为所有剪辑提供相同的大小:
第二种解决方案是为所有文本剪辑提供相同的大小(宽度、高度):
相关问题 更多 >
编程相关推荐