Moviepy缩放效果需要调整

时间:2016-06-02 00:36:56

标签: python animation video moviepy

我想将剪辑缩放到某个尺寸,然后停止进一步缩放。换句话说,剪辑在达到特定尺寸后停止进一步增大其尺寸,并且如果剪辑从其原始尺寸的较小尺寸开始缩放,则剪辑更好,并且更大版本。我正在使用moviepy模块。使用以下代码,我可以逐步缩放剪辑,但很难弄清楚如何将剪辑从小到大,从而创建动画效果。非常感谢您提供的任何反馈。

import os
from moviepy.editor import *

screensize = (640,360)

clip = (ImageClip(img)
        .resize(height=screensize[1]*4)
        .resize(lambda t : 1+0.02*t)
        .set_position(('center', 'center'))
        .set_duration(10)
        )

我很难弄清楚如何编写函数以便用moviepy的txtclip创建一个类型写入效果,这意味着剪辑中的字母会一个接一个地显示,创建一个平滑的类型编写器动画文本。 Moviepy得到了一些有用的类,比如findObjects - 它可以检测剪辑中的单个字母:

txtClip = TextClip('Cool effect',color='white', font="Amiri-Bold",
                   kerning = 5, fontsize=100)
cvc = CompositeVideoClip( [txtClip.set_pos('center')],
                        size=screensize, transparent=True)

letters = findObjects(cvc) # a list of ImageClips 

here is the link: http://zulko.github.io/moviepy/examples/moving_letters.html
找到字母(字母剪辑)之后,我想以这样的方式加入它们,它们一个接一个地出现,看起来像是写字。

文档中已经有一些移动字母的例子,但这些字母可能很有用。谢谢

1 个答案:

答案 0 :(得分:3)

这是实现您想要的方式。关键是在命名函数中定义调整大小逻辑,而不是使用lambda

import os
from moviepy.editor import *


def resize_func(t):
    if t < 4:
        return 1 + 0.2*t  # Zoom-in.
    elif 4 <= t <= 6:
        return 1 + 0.2*4  # Stay.
    else: # 6 < t
        return 1 + 0.2*(duration-t)  # Zoom-out.

duration = 10
screensize = (640,360)

clip_img = (
    ImageClip('test.png')
    .resize(screensize)
    .resize(resize_func)
    .set_position(('center', 'center'))
    .set_duration(duration)
    .set_fps(25)
    )

clip = CompositeVideoClip([clip_img], size=screensize)
clip.write_videofile('test.mp4')

修改

以下代码回答了问题的第二部分(我不知道提出两个单独的问题是否更好。)

from __future__ import division
from moviepy.editor import *
from moviepy.video.tools.segmenting import findObjects


def clip_typewriter(text, duration_clip, duration_effect):
    # `duration_effect` is effectively the time where the last letter appears.
    clip_text = TextClip(
                    text,
                    color='white',
                    font='Consolas',
                    fontsize=80,
                    kerning=3,
                    )
    letters = findObjects(clip_text, preview=False)
    # Select the start time in seconds for each letter found:
    n = len(letters)
    times_start = [duration_effect*i/(n-1) for i in range(n)]
    clips_letters = []
    for i, letter in enumerate(letters):
        clips_letters.append(letter
            .set_position(letter.screenpos)
            .set_start(times_start[i])
            .set_end(duration_clip)
            # Here you can add key sounds using `set_audio`.
            )
    return CompositeVideoClip(clips_letters, size=clip_text.size)


if __name__ == '__main__':
    screensize = (320, 180)
    fps = 12
    clip_1 = clip_typewriter('hello', 2, 1).set_start(1).set_position('center')
    clip_2 = clip_typewriter('world', 2, 1).set_start(4).set_position('center')
    clip_final = CompositeVideoClip([clip_1, clip_2], size=screensize)
    clip_final.write_gif('test_typewriter.gif', fps=fps)

结果:

enter image description here