(PECL imagick 2 >= 2.3.0, PECL imagick 3)
Imagick::floodFillPaintImage — Cambia el valor del color de cualquier píxel que coincida con el objetivo
$fill
,$fuzz
,$target
,$x
,$y
,$invert
,$channel
= Imagick::CHANNEL_DEFAULTCambia el valor del color de cualquier píxel que coincida con el objetivo y esté en el área inmediata. Este método es un sustituto del método obsoleto Imagick::paintFloodFillImage(). Este método está disponible si Imagick ha sido compilado con la versión 6.3.8 o superior de ImageMagick.
fill
Objeto ImagickPixel o una cadena que contiene el color de relleno
fuzz
La cantidad de difusión. Por ejemplo, setee fuzz a 10 y el color rojo a intensidades de 100 y 102 respectivamente son ahora interpretados como el mismo color.
target
Objeto ImagickPixel o una cadena que contiene el color objetivo a dibujar
x
Posición X del inicio del relleno
y
Posición Y del inicio del relleno
invert
Si es true
se pinta cualquier píxel que no coincida con el color objetivo.
channel
Proporciona cualquier contante de canal que sea válida para su modo de canal. Para aplicarlo a más de un canal, combine constantes de canal using bitwise operadores bit a bit. El valor por defecto para Imagick::CHANNEL_DEFAULT
. Referirse a esta lista de constantes de canal
Devuelve true
en caso de éxito.
Ejemplo #1 Ejemplo de Imagick::floodfillPaintImage()
<?php
$im = new Imagick();
$im->newImage(100, 50, "red");
$im->newImage(100, 50, "green");
$im->newImage(100, 50, "blue");
$im->resetIterator();
$combinado = $im->appendImages(true);
$combinado->writeImage("floodfillpaint_intermedia.png");
$x = 1;
$y = 1;
$objetivo = $combinado->getImagePixelColor($x, $y);
$combinado->floodfillPaintImage("black", 1, $objetivo, $x, $y, false);
$combinado->writeImage("floodfillpaint_resultado.png");
?>
El resultado del ejemplo sería algo similar a: