Imagick::fxImage

(PECL imagick 2.0.0)

Imagick::fxImage式を画像の各ピクセルに適用する

説明

Imagick Imagick::fxImage ( string $expression [, int $channel = Imagick::CHANNEL_ALL ] )

式を画像の各ピクセルに適用します。 詳細は » The Fx Special Effects Image Operator を参照ください。

パラメータ

expression

式。

channel

チャネルモードに対応したチャネル定数を指定します。 複数のチャネルに適用するには、 ビット演算子でチャネル型定数を組み合わせます。 チャネル定数 の一覧を参照ください。

返り値

成功した場合に TRUE を返します。

エラー / 例外

エラー時に ImagickException をスローします。

例1 Imagick::fxImage()

<?php
function fxImage() {
    
$imagick = new \Imagick();
    
$imagick->newPseudoImage(200200"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
3
thomasgf22 at NOSPAM dot gmail dot com
3 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