Imagick::fxImage

(PECL imagick 2, PECL imagick 3)

Imagick::fxImageBir ifadeyi görüntüdeki her piksele uygular

Açıklama

public Imagick::fxImage(string $ifade, int $kanal = Imagick::CHANNEL_DEFAULT): Imagick

Belirtilen ifadeyi görüntüdeki her piksele uygular. Daha fazla bilgi için » Özel etkiler için Fx görüntü işleci sayfasına bakınız.

Bağımsız Değişkenler

ifadeyi

Her piksele uygulanacak ifade.

kanal

Normalde kanal türü sabitlerinden biri, ancak bitsel işleçler kullanılarak birden fazla kanal belirtilebilir.

Dönen Değerler

Başarı durumunda true döner.

Hatalar/İstisnalar

Hata durumunda bir ImagickException istisnası oluşur.

Örnekler

Örnek 1 - Imagick::fxImage() kullanımı

<?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