Imagick::fxImage

(PECL imagick 2, PECL imagick 3)

Imagick::fxImageÉvalue une expression pour chaque pixel d'une image

Description

public Imagick::fxImage(string $expression, int $channel = Imagick::CHANNEL_DEFAULT): Imagick

Évalue une expression pour chaque pixel d'une image. Consultez » The Fx Special Effects Image Operator pour plus de détails (en anglais).

Liste de paramètres

expression

L'expression.

channel

Fournit une constante de canal valide pour votre mode de canal. Pour utiliser plus d'un canal, combinez les constantes de type de canal en utilisant les opérateurs de bits. Reportez-vous à la liste des constantes de canal.

Valeurs de retour

Retourne true en cas de succès.

Erreurs / Exceptions

Lance une exception ImagickException si une erreur survient.

Exemples

Exemple #1 Exemple avec Imagick::fxImage()

<?php
function fxImage() {
$imagick = new \Imagick();
$imagick->newPseudoImage(200, 200, "xc:white");

$fx = 'xx=i-w/2; yy=j-h/2; rr=hypot(xx,yy); (.5-rr/140)*1.2+.5';
$fxImage = $imagick->fxImage($fx);

header("Content-Type: image/png");
$fxImage->setimageformat('png');
echo
$fxImage->getImageBlob();
}

?>

add a note add a note

User Contributed Notes 1 note

up
2
thomasgf22 at NOSPAM dot gmail dot com
10 years ago
Beware that fxImage return value's type is a new object(Imagick), opposing the current documentation (boolean). Therefore it does not affect the caller object. Example:
<?php
            $canvas
= new Imagick();
           
$canvas->newImage(256, 256, "white", "jpg");

           
$gradient = new Imagick();
           
$gradient->newPseudoImage(256, 256, "gradient:white-black");
           
$canvas->compositeImage( $gradient, imagick::COMPOSITE_OVER, 0, 0 );
           
$canvas->rotateImage(new ImagickPixel(), 90);
           
/*instead of just $canvas->fxImage("floor(s*10+0.5)/10"); we must store fxImage()'s result*/
           
$canvas= $canvas->fxImage("floor(s*10+0.5)/10");

           
header( "Content-Type: image/jpg" );
            echo
$canvas;
?>
To Top