imagefilter
(PHP 5, PHP 7)
imagefilter — Applies a filter to an image
Beschreibung
$image
, int $filtertype
[, int $arg1
[, int $arg2
[, int $arg3
[, int $arg4
]]]] ) : bool
imagefilter() applies the given filter
filtertype
on the image
.
Parameter-Liste
-
image
-
Eine von den verschiedenen Erzeugungsfunktionen wie imagecreatetruecolor() gelieferte Grafikressource.
-
filtertype
-
filtertype
can be one of the following:-
IMG_FILTER_NEGATE
: Reverses all colors of the image. -
IMG_FILTER_GRAYSCALE
: Converts the image into grayscale by changing the red, green and blue components to their weighted sum using the same coefficients as the REC.601 luma (Y') calculation. The alpha components are retained. For palette images the result may differ due to palette limitations. -
IMG_FILTER_BRIGHTNESS
: Changes the brightness of the image. Usearg1
to set the level of brightness. The range for the brightness is -255 to 255. -
IMG_FILTER_CONTRAST
: Changes the contrast of the image. Usearg1
to set the level of contrast. -
IMG_FILTER_COLORIZE
: LikeIMG_FILTER_GRAYSCALE
, except you can specify the color. Usearg1
,arg2
andarg3
in the form ofred
,green
,blue
andarg4
for thealpha
channel. The range for each color is 0 to 255. -
IMG_FILTER_EDGEDETECT
: Uses edge detection to highlight the edges in the image. -
IMG_FILTER_EMBOSS
: Embosses the image. -
IMG_FILTER_GAUSSIAN_BLUR
: Blurs the image using the Gaussian method. -
IMG_FILTER_SELECTIVE_BLUR
: Blurs the image. -
IMG_FILTER_MEAN_REMOVAL
: Uses mean removal to achieve a "sketchy" effect. -
IMG_FILTER_SMOOTH
: Makes the image smoother. Usearg1
to set the level of smoothness. -
IMG_FILTER_PIXELATE
: Applies pixelation effect to the image, usearg1
to set the block size andarg2
to set the pixelation effect mode. -
IMG_FILTER_SCATTER
: Applies scatter effect to the image, usearg1
andarg2
to define the effect strength and additionallyarg3
to only apply the on select pixel colors.
-
-
arg1
-
-
IMG_FILTER_BRIGHTNESS
: Brightness level. -
IMG_FILTER_CONTRAST
: Contrast level. -
IMG_FILTER_COLORIZE
: Wert der Rotkomponente. -
IMG_FILTER_SMOOTH
: Smoothness level. -
IMG_FILTER_PIXELATE
: Block size in pixels. -
IMG_FILTER_SCATTER
: Effect substraction level. This must not be higher or equal to the addition level set witharg2
.
-
-
arg2
-
-
IMG_FILTER_COLORIZE
: Wert der Grünkomponente. -
IMG_FILTER_PIXELATE
: Whether to use advanced pixelation effect or not (defaults toFALSE
). -
IMG_FILTER_SCATTER
: Effect addition level.
-
-
arg3
-
-
IMG_FILTER_COLORIZE
: Wert der Blaukomponente. -
IMG_FILTER_SCATTER
: Optional array indexed color values to apply effect at.
-
-
arg4
-
-
IMG_FILTER_COLORIZE
: Alpha channel, A value between 0 and 127. 0 indicates completely opaque while 127 indicates completely transparent.
-
Changelog
Version | Beschreibung |
---|---|
7.4.0 |
Scatter support (IMG_FILTER_SCATTER ) was added.
|
5.3.0 |
Pixelation support (IMG_FILTER_PIXELATE ) was added.
|
5.2.5 |
Alpha support for IMG_FILTER_COLORIZE was added.
|
Beispiele
Beispiel #1 imagefilter() grayscale example
<?php
$im = imagecreatefrompng('dave.png');
if($im && imagefilter($im, IMG_FILTER_GRAYSCALE))
{
echo 'Image converted to grayscale.';
imagepng($im, 'dave.png');
}
else
{
echo 'Conversion to grayscale failed.';
}
imagedestroy($im);
?>
Beispiel #2 imagefilter() brightness example
<?php
$im = imagecreatefrompng('sean.png');
if($im && imagefilter($im, IMG_FILTER_BRIGHTNESS, 20))
{
echo 'Image brightness changed.';
imagepng($im, 'sean.png');
imagedestroy($im);
}
else
{
echo 'Image brightness change failed.';
}
?>
Beispiel #3 imagefilter() colorize example
<?php
$im = imagecreatefrompng('philip.png');
/* R, G, B, so 0, 255, 0 is green */
if($im && imagefilter($im, IMG_FILTER_COLORIZE, 0, 255, 0))
{
echo 'Image successfully shaded green.';
imagepng($im, 'philip.png');
imagedestroy($im);
}
else
{
echo 'Green shading failed.';
}
?>
Beispiel #4 imagefilter() negate example
<?php
// Define our negate function so its portable for
// php versions without imagefilter()
function negate($im)
{
if(function_exists('imagefilter'))
{
return imagefilter($im, IMG_FILTER_NEGATE);
}
for($x = 0; $x < imagesx($im); ++$x)
{
for($y = 0; $y < imagesy($im); ++$y)
{
$index = imagecolorat($im, $x, $y);
$rgb = imagecolorsforindex($index);
$color = imagecolorallocate($im, 255 - $rgb['red'], 255 - $rgb['green'], 255 - $rgb['blue']);
imagesetpixel($im, $x, $y, $color);
}
}
return(true);
}
$im = imagecreatefromjpeg('kalle.jpg');
if($im && negate($im))
{
echo 'Image successfully converted to negative colors.';
imagejpeg($im, 'kalle.jpg', 100);
imagedestroy($im);
}
else
{
echo 'Converting to negative colors failed.';
}
?>
Beispiel #5 imagefilter() pixelate example
<?php
// Load the PHP logo, we need to create two instances
// to show the differences
$logo1 = imagecreatefrompng('./php.png');
$logo2 = imagecreatefrompng('./php.png');
// Create the image instance we want to show the
// differences on
$output = imagecreatetruecolor(imagesx($logo1) * 2, imagesy($logo1));
// Apply pixelation to each instance, with a block
// size of 3
imagefilter($logo1, IMG_FILTER_PIXELATE, 3);
imagefilter($logo2, IMG_FILTER_PIXELATE, 3, true);
// Merge the differences onto the output image
imagecopy($output, $logo1, 0, 0, 0, 0, imagesx($logo1) - 1, imagesy($logo1) - 1);
imagecopy($output, $logo2, imagesx($logo2), 0, 0, 0, imagesx($logo2) - 1, imagesy($logo2) - 1);
imagedestroy($logo1);
imagedestroy($logo2);
// Output the differences
header('Content-Type: image/png');
imagepng($output);
imagedestroy($output);
?>
Das oben gezeigte Beispiel erzeugt eine ähnliche Ausgabe wie:
Beispiel #6 imagefilter() scatter example
<?php
// Load the image
$logo = imagecreatefrompng('./php.png');
// Apply a very soft scatter effect to the image
imagefilter($logo, IMG_FILTER_SCATTER, 3, 5);
// Output the image with the scatter effect
header('Content-Type: image/png');
imagepng($logo);
imagedestroy($logo);
?>
Das oben gezeigte Beispiel erzeugt eine ähnliche Ausgabe wie:
Deutsche Übersetzung
Sie haben gebeten, diese Seite auf Deutsch zu besuchen. Momentan ist nur die Oberfläche übersetzt, aber noch nicht der gesamte Inhalt.Wenn Sie mir bei Übersetzungen helfen wollen, ist Ihr Beitrag willkommen. Alles, was Sie tun müssen, ist, sich auf der Website zu registrieren und mir eine Nachricht zu schicken, in der Sie gebeten werden, Sie der Gruppe der Übersetzer hinzuzufügen, die Ihnen die Möglichkeit gibt, die gewünschten Seiten zu übersetzen. Ein Link am Ende jeder übersetzten Seite zeigt an, dass Sie der Übersetzer sind und einen Link zu Ihrem Profil haben.
Vielen Dank im Voraus.
Dokument erstellt 30/01/2003, zuletzt geändert 26/10/2018
Quelle des gedruckten Dokuments:https://www.gaudry.be/de/php-rf-imagefilter.html
Die Infobro ist eine persönliche Seite, deren Inhalt in meiner alleinigen Verantwortung liegt. Der Text ist unter der CreativeCommons-Lizenz (BY-NC-SA) verfügbar. Weitere Informationen auf die Nutzungsbedingungen und dem Autor.
Referenzen
Diese Verweise und Links verweisen auf Dokumente, die während des Schreibens dieser Seite konsultiert wurden, oder die zusätzliche Informationen liefern können, aber die Autoren dieser Quellen können nicht für den Inhalt dieser Seite verantwortlich gemacht werden.
Der Autor Diese Website ist allein dafür verantwortlich, wie die verschiedenen Konzepte und Freiheiten, die mit den Nachschlagewerken gemacht werden, hier dargestellt werden. Denken Sie daran, dass Sie mehrere Quellinformationen austauschen müssen, um das Risiko von Fehlern zu reduzieren.