Imagick::setImageTicksPerSecond

(PECL imagick 2, PECL imagick 3)

Imagick::setImageTicksPerSecondDefine os tiques por segundo da imagem

Descrição

public Imagick::setImageTicksPerSecond(int $ticks_per_second): bool

Ajusta o tempo durante o qual um quadro de uma imagem animada é exibido.

Note:

Para GIFs animados, esta função não altera o número de 'tiques de imagem' por segundo, que é sempre definido como 100. Em vez disso, ajusta a quantidade de tempo que o quadro é exibido para simular a mudança em 'tiques por segundo'.

Por exemplo, para um GIF animado onde cada quadro é exibido por 20 tiques (1/5 de segundo), quando este método é chamado em cada quadro da imagem com um argumento de 50, os quadros são ajustados para serem exibidos por 40 tiques (2/5 de segundo) e a animação será reproduzida na metade da velocidade original.

Parâmetros

ticks_per_second

A duração durante a qual uma imagem deve ser exibida, expressa em tiques por segundo.

Valor Retornado

Retorna true em caso de sucesso.

Exemplos

Example #1 Modificando GIF animado com Imagick::setImageTicksPerSecond()

<?php

// Modifica um GIF animado para que a primeira metade do gif seja reproduzida na metade da
// velocidade atual e a segunda metade seja reproduzida no dobro da velocidade
// atual

$imagick = new Imagick(realpath("Teste.gif"));
$imagick = $imagick->coalesceImages();

$totalFrames = $imagick->getNumberImages();

$frameCount = 0;

foreach ($imagick as $frame) {
    $imagick->setImageTicksPerSecond(50);

    if ($frameCount < ($totalFrames / 2)) {
        // Modifica o quado para ser mostrado por um tempo duas vezes maior que o atual
        $imagick->setImageTicksPerSecond(50);
    } else {
        // Modifica o quado para ser mostrado pela metado do tempo atual
        $imagick->setImageTicksPerSecond(200);
    }

    $frameCount++;
}

$imagick = $imagick->deconstructImages();

$imagick->writeImages("/caminho/para/gravar/resultado.gif", true);

?>