imagecopyresized
Kopieren und Ändern der Größe eines Bild-Teiles
Beschreibung
bool imagecopyresized
( resource $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
)
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.
Parameter-Liste
-
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.
Rückgabewerte
Gibt bei Erfolg TRUE zurück. Im Fehlerfall wird FALSE zurückgegeben.
Beispiele
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.
Anmerkungen
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.
Siehe auch
imagecopyresampled