(PHP 4, PHP 5, PHP 7)
imagecopyresized — Kopieren und Ändern der Größe eines Bild-Teiles
$dst_image
, resource $src_image
, int $dst_x
, int $dst_y
, int $src_x
, int $src_y
, int $dst_w
, int $dst_h
, int $src_w
, int $src_h
) : bool
imagecopyresized() kopiert einen rechteckigen
Ausschnitt eines Bildes in ein anderes Bild.
dst_image
gibt das Zielbild,
src_image
gibt die Bildquelle an.
Mit anderen Worten, imagecopyresized() nimmt
einen rechteckigen Ausschnitt von src_image
der Breite
src_w
and Höhe src_h
von
Position (src_x
,src_y
)
und platziert diesen in einem rechteckigen Bereich in dst_image
mit der Breite dst_w
and Höhe dst_h
an der Position (dst_x
,dst_y
).
Unterscheiden sich die Angaben der Quelle und des Ziels bezogen auf
die Koordinaten, Höhe oder Breite, wird das Teilbild entsprechend
gedehnt oder geschrumpft. Die Koordinaten beziehen sich auf die
linke obere Ecke. Sie können hiermit auch Teilbilder innerhalb
ein- und desselben Bildes kopieren, sofern
dst_image
und src_image
gleich sind. Falls sich dabei aber die kopierten Teile überlappen,
führt das zu unvorhersehbaren Ergebnissen.
dst_image
Resource des Zielbildes.
src_image
Resource des Quellbildes.
dst_x
x-Koordinate des Zielrechtecks.
dst_y
y-Koordinate des Zielrechtecks.
src_x
x-Koordinate des Quellrechtecks.
src_y
y-Koordinate des Quellrechtecks.
dst_w
Breite des Zielrechtecks.
dst_h
Höhe des Zielrechtecks.
src_w
Breite der Quelle.
src_h
Höhe der Quelle.
Gibt bei Erfolg TRUE
zurück. Im Fehlerfall wird FALSE
zurückgegeben.
Beispiel #1 Ein Bild skalieren
Dieses Beispiel zeigt ein Bild in halber Größe an.
<?php
// Datei und Faktor der Größenänderung
$filename = 'test.jpg';
$percent = 0.5;
// Typ der Ausgabe
header('Content-Type: image/jpeg');
// Neue Größe berechnen
list($width, $height) = getimagesize($filename);
$newwidth = $width * $percent;
$newheight = $height * $percent;
// Bild laden
$thumb = imagecreatetruecolor($newwidth, $newheight);
$source = imagecreatefromjpeg($filename);
// Skalieren
imagecopyresized($thumb, $source, 0, 0, 0, 0, $newwidth, $newheight, $width, $height);
// Ausgabe
imagejpeg($thumb);
?>
Das oben gezeigte Beispiel erzeugt eine ähnliche Ausgabe wie:
Das Bild wird in halber Größe ausgegeben, allerdings könnten mit Hilfe der Funktion imagecopyresampled() Ergebnisse besserer Qualität erzielt werden.
Hinweis:
Es gibt ein Problem bei Verwendung von limitierten Farbpaletten (255+1 Farben). Resampling und Filterung von Bildern benötigt in der Regel mehr als 255 Farben und eine Art der Annäherung wird zur Berechnung des neu resampleten Pixels und dessen Farbwertes verwendet. Bei einem palettenbasierten Bild wird zuerst versucht eine neue Farbe zu allokieren, wenn dies fehlschlägt wird der theoretisch nächst gelegene Farbwert aus der Palette verwendet. Dies ist aber nicht immer der Wert der farblich am nächsten ist. Dies kann zu eigenartigen Ergebnissen wie leeren (oder scheinbar leeren) Bildern führen. Um dieses Problem zu vermeiden, sollte ein Truecolor-Bild als Zielbild verwendet werden, welches z.B. mit der Funktion imagecreatetruecolor() erstellt werden kann.