(PECL imagick 3 >= 3.3.0)
Imagick::setProgressMonitor — Define una función de retrollamada a ser llamada durante el procesamiento
Define una función de retrollamada que será llamada durante el procesamiento de la imagen Imagick.
callbackLa función de progreso a llamar. Debe retornar true si el procesamiento de la imagen debe continuar, o false si debe ser cancelado. El argumento offset indica la progresión y el argumento span indica la cantidad total de trabajo a realizar.
Los valores pasados a la función de retrollamada no son consistentes. En particular, el argumento span puede aumentar durante el procesamiento de la imagen. Debido a esto, el cálculo del porcentaje completo de una operación de imagen no es trivial.
   Devuelve true en caso de éxito.
  
Ejemplo #1 Imagick::setProgressMonitor()
<?php
        $abortReason = null;
        try {
            $imagick = new \Imagick(realpath($this->control->getImagePath()));
            $startTime = time();
            $callback = function ($offset, $span)  use ($startTime, &$abortReason) {
                if (((100 * $offset) / $span)  > 20) {
                    $abortReason = "Processing reached 20%";
                    return false;
                }
                $nowTime = time();
                if ($nowTime - $startTime > 5) {
                    $abortReason = "Image processing took more than 5 seconds";
                    return false;
                }
                if (($offset % 5) == 0) {
                    echo "Progress: $offset / $span <br/>";
                }
                return true;
            };
            $imagick->setProgressMonitor($callback);
            $imagick->waveImage(2, 15);
            echo "Data len is: ".strlen($imagick->getImageBlob());
        }
        catch(\ImagickException $e) {
            if ($abortReason != null) {
                echo "Image processing was aborted: ".$abortReason."<br/>";
            }
            else {
                echo "ImagickException caught: ".$e->getMessage()." Exception type is ".get_class($e);
            }
        }
?>