Cette fois, je vais vous apporter une explication détaillée des étapes pour recadrer des images à une taille fixe en PHP. Quelles sont les précautions pour recadrer des images à une taille fixe en PHP Voici un cas pratique. , jetons un coup d'oeil.
Pour créer une image d'appel de page d'accueil, vous devez parfois obtenir une image de taille fixe, car la position de l'image de la page d'accueil est généralement spécifiée par le concepteur. Si vous effectuez un appel d'image de dernière version, vous. Je ne sais pas ce que le client va télécharger Quelle proportion de l'image, donc parfois il n'y a aucun moyen de déterminer la proportion de l'image. Les rédacteurs de pages frontales utilisent généralement la méthode de fixation de la hauteur et. largeur de l'élément img pour contrôler le débordement de l'image, mais si la proportion de l'image n'est pas requise, la proportion entraînera une déformation de l'image après son appel, ce qui affectera grandement la beauté de la page. Une solution consiste à la mettre à l'échelle en fonction. à la proportion de l'image originale. L'image mise à l'échelle aura inévitablement des espaces vides, et les espaces vides seront remplis de couleur, de sorte que bien que l'image ne soit pas déformée, cela posera de nombreux problèmes, par exemple, si l'utilisateur. envoie une image avec une image élevée mais une largeur moyenne, et si elle est compressée en une image 1:1, alors l'image ne sera fondamentalement pas visible après la compression.
La solution est de recadrer n'importe quelle image à une taille fixe, l'image ne sera pas déformée et l'espace vide sera étiré et rempli. L'image sera toujours remplie sans espace vide. bcastr doit savoir que bcastr garantit l'appel d'image sans déformation, pour un cadre d'image de sortie de taille fixe, l'image source a les situations suivantes :
1 : La hauteur et la largeur de l'image à sortir sont inférieures à la hauteur et largeur de l'image source, écrite sous forme de jugement $new_width<$src_width && $ new_height<$src_width
2 : La hauteur et la largeur de l'image à afficher sont plus grandes que la hauteur et la largeur de l'image originale, écrit sous forme de jugement $new_width>$src_width && $new_height>$src_width
3 : Exclure les deux types 1 et 2, c'est-à-dire le cas du zoom avant lors du zoom arrière et le jugement d'égalité
Pour 1 et 2, le code de traitement de la fonction est exactement le même, il peut donc être résumé en une seule instruction de traitement
<?php /* *说明:函数功能是把一个图像裁剪为任意大小的图像,图像不变形 * 参数说明:输入 需要处理图片的 文件名,生成新图片的保存文件名,生成新图片的宽,生成新图片的高 * written by smallchicken * time 2008-12-18 */ // 获得任意大小图像,不足地方拉伸,不产生变形,不留下空白 function my_image_resize($src_file, $dst_file , $new_width , $new_height) { if($new_width <1 || $new_height <1) { echo "params width or height error !"; exit(); } if(! file_exists ($src_file)) { echo $src_file . " is not exists !"; exit(); } // 图像类型 $type=exif_imagetype($src_file); $support_type=array(IMAGETYPE_JPEG , IMAGETYPE_PNG , IMAGETYPE_GIF); if(!in_array($type, $support_type,true)) { echo "this type of image does not support! only support jpg , gif or png"; exit(); } //Load image switch($type) { case IMAGETYPE_JPEG : $src_img=imagecreatefromjpeg($src_file); break; case IMAGETYPE_PNG : $src_img=imagecreatefrompng($src_file); break; case IMAGETYPE_GIF : $src_img=imagecreatefromgif($src_file); break; default: echo "Load image error!"; exit(); } $w=imagesx($src_img); $h=imagesy($src_img); $ratio_w=1.0 * $new_width / $w; $ratio_h=1.0 * $new_height / $h; $ratio=1.0; // 生成的图像的高宽比原来的都小,或都大 ,原则是 取大比例放大,取大比例缩小(缩小的比例就比较小了) if( ($ratio_w < 1 && $ratio_h < 1) || ($ratio_w > 1 && $ratio_h > 1)) { if($ratio_w < $ratio_h) { $ratio = $ratio_h ; // 情况一,宽度的比例比高度方向的小,按照高度的比例标准来裁剪或放大 }else { $ratio = $ratio_w ; } // 定义一个中间的临时图像,该图像的宽高比 正好满足目标要求 $inter_w=(int)($new_width / $ratio); $inter_h=(int) ($new_height / $ratio); $inter_img=imagecreatetruecolor($inter_w , $inter_h); imagecopy($inter_img, $src_img, 0,0,0,0,$inter_w,$inter_h); // 生成一个以最大边长度为大小的是目标图像$ratio比例的临时图像 // 定义一个新的图像 $new_img=imagecreatetruecolor($new_width,$new_height); imagecopyresampled($new_img,$inter_img,0,0,0,0,$new_width,$new_height,$inter_w,$inter_h); switch($type) { case IMAGETYPE_JPEG : imagejpeg($new_img, $dst_file,100); // 存储图像 break; case IMAGETYPE_PNG : imagepng($new_img,$dst_file,100); break; case IMAGETYPE_GIF : imagegif($new_img,$dst_file,100); break; default: break; } } // end if 1 // 2 目标图像 的一个边大于原图,一个边小于原图 ,先放大平普图像,然后裁剪 // =if( ($ratio_w < 1 && $ratio_h > 1) || ($ratio_w >1 && $ratio_h <1) ) else{ $ratio=$ratio_h>$ratio_w? $ratio_h : $ratio_w; //取比例大的那个值 // 定义一个中间的大图像,该图像的高或宽和目标图像相等,然后对原图放大 $inter_w=(int)($w * $ratio); $inter_h=(int) ($h * $ratio); $inter_img=imagecreatetruecolor($inter_w , $inter_h); //将原图缩放比例后裁剪 imagecopyresampled($inter_img,$src_img,0,0,0,0,$inter_w,$inter_h,$w,$h); // 定义一个新的图像 $new_img=imagecreatetruecolor($new_width,$new_height); imagecopy($new_img, $inter_img, 0,0,0,0,$new_width,$new_height); switch($type) { case IMAGETYPE_JPEG : imagejpeg($new_img, $dst_file,100); // 存储图像 break; case IMAGETYPE_PNG : imagepng($new_img,$dst_file,100); break; case IMAGETYPE_GIF : imagegif($new_img,$dst_file,100); break; default: break; } }// if3 }// end function ?>
Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour en savoir plus. informations passionnantes, veuillez prêter attention aux autres articles connexes sur le site Web php chinois !
Lecture recommandée :
Explication détaillée des étapes de l'exemple de classe de compression php ZIP
Recadrage PHP sans affecter la forme de l'image
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!