7

我想将剪辑缩放到某个尺寸,然后停止进一步缩放。换句话说,剪辑在达到一定尺寸后会停止进一步增加其尺寸,如果剪辑开始从比其原始尺寸小得多的尺寸开始缩放到更大的版本,效果会更好。我正在使用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

在找到字母(字母剪辑)后,我想将它们连接起来,使它们一个接一个地出现,看起来像打字。

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

4

1 回答 1

10

这是一种实现你想要的方式。关键是在命名函数中定义调整大小的逻辑,而不是使用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)

结果:

在此处输入图像描述

于 2016-06-02T21:05:59.417 回答