imagecopyresized
(PHP 4, PHP 5, PHP 7, PHP 8)
imagecopyresized — Kopieren und Ändern der Größe eines Bild-Teiles
Beschreibung
GdImage
$dst_image
,GdImage
$src_image
,int
$dst_x
,int
$dst_y
,int
$src_x
,int
$src_y
,int
$dst_width
,int
$dst_height
,int
$src_width
,int
$src_height
): 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_width
and Höhe src_height
von
Position (src_x
,src_y
)
und platziert diesen in einem rechteckigen Bereich in dst_image
mit der Breite dst_width
and Höhe dst_height
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
-
Ressource des Zielbildes.
-
src_image
-
Ressource 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_width
-
Breite des Zielrechtecks.
-
dst_height
-
Höhe des Zielrechtecks.
-
src_width
-
Breite der Quelle.
-
src_height
-
Höhe der Quelle.
Rückgabewerte
Gibt bei Erfolg true
zurück. Bei einem Fehler wird false
zurückgegeben.
Changelog
Version | Beschreibung |
---|---|
8.0.0 |
dst_image und src_image erwarten jetzt
GdImage-Instanzen;
zuvor wurde eine resource erwartet.
|
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() - Copy and resize part of an image with resampling
- imagescale() - Scale an image using the given new width and height
- imagecrop() - Crop an image to the given rectangle