(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)
imagecopyresampled — Copie, redimensionne, rééchantillonne une image
$dst_image
,$src_image
,$dst_x
,$dst_y
,$src_x
,$src_y
,$dst_width
,$dst_height
,$src_width
,$src_height
imagecopyresampled() copie une zone
rectangulaire de l'image src_im
vers
l'image dst_im
. Durant la copie,
la zone est rééchantillonnée de manière à conserver la clarté
de l'image durant une réduction.
En d'autres termes, imagecopyresampled() prendra une
forme rectangulaire src_image
d'une largeur de
src_width
et d'une hauteur src_height
à la position (src_x
,src_y
)
et le placera dans une zone rectangulaire dst_image
d'une largeur de dst_width
et d'une hauteur de
dst_height
à la position
(dst_x
,dst_y
).
Si les hauteurs et largeurs des source et destination
diffèrent, l'image copiée sera étirée de manière appropriée.
Les coordonnées sont celles du coin supérieur gauche.
imagecopyresampled() peut servir à copier
des zones d'une image vers elle-même, (si dst_image
est la même que src_image
) mais si les régions se
chevauchent, les résultats sont imprévisibles.
dst_image
Ressource cible de l'image.
src_image
Ressource source de l'image.
dst_x
X : coordonnées du point de destination.
dst_y
Y : coordonnées du point de destination.
src_x
X : coordonnées du point source.
src_y
Y : coordonnées du point source.
dst_width
Largeur de la destination.
dst_height
Hauteur de la destination.
src_width
Largeur de la source.
src_height
Hauteur de la source.
Cette fonction retourne true
en cas de succès ou false
si une erreur survient.
Version | Description |
---|---|
8.0.0 |
dst_image et src_image
attendent désormais des instances de GdImage ;
auparavant, des resources étaient attendues.
|
Exemple #1 Exemple simple
Cet exemple redimensionne une image à la moitié de sa taille originale.
<?php
// Le fichier
$filename = 'test.jpg';
$percent = 0.5;
// Content type
header('Content-Type: image/jpeg');
// Calcul des nouvelles dimensions
list($width, $height) = getimagesize($filename);
$new_width = $width * $percent;
$new_height = $height * $percent;
// Redimensionnement
$image_p = imagecreatetruecolor($new_width, $new_height);
$image = imagecreatefromjpeg($filename);
imagecopyresampled($image_p, $image, 0, 0, 0, 0, $new_width, $new_height, $width, $height);
// Affichage
imagejpeg($image_p, null, 100);
?>
Résultat de l'exemple ci-dessus est similaire à :
Exemple #2 Redimensionnement proportionnel d'une image
Cet exemple affichera une image avec une largeur ou une hauteur maximale de 200 pixels.
<?php
// Le fichier
$filename = 'test.jpg';
// Définition de la largeur et de la hauteur maximale
$width = 200;
$height = 200;
// Content type
header('Content-Type: image/jpeg');
// Cacul des nouvelles dimensions
list($width_orig, $height_orig) = getimagesize($filename);
$ratio_orig = $width_orig/$height_orig;
if ($width/$height > $ratio_orig) {
$width = $height*$ratio_orig;
} else {
$height = $width/$ratio_orig;
}
// Redimensionnement
$image_p = imagecreatetruecolor($width, $height);
$image = imagecreatefromjpeg($filename);
imagecopyresampled($image_p, $image, 0, 0, 0, 0, $width, $height, $width_orig, $height_orig);
// Affichage
imagejpeg($image_p, null, 100);
?>
Résultat de l'exemple ci-dessus est similaire à :
Note:
Il y a un problème dû aux limitations de la taille de la palette (255 + 1 couleurs différentes). Filtrer ou rééchantillonner une image demande plus de 255 couleurs, une approximation est alors utilisée pour calculer le nouveau nombre de couleurs. Avec une palette, si une nouvelle couleur ne peut être allouée, la couleur la plus proche (en théorie) est utilisée. Ce n'est pas toujours la couleur la plus proche visuellement. Cela peut générer des problèmes étranges, comme des images blanches. Pour éviter ce problème, passez en image TrueColor, comme celle générée par la fonction imagecreatetruecolor().