-
- *exif_imagetype -- 画像のタイプを決定します
- *説明: この機能は、画像を変形せずに任意のサイズの画像にトリミングすることです
- * パラメーターの説明: ファイル名を入力してください処理対象の画像の保存ファイル名を生成し、新しい画像の幅を生成し、新しい画像の高さを生成します
- */
- // 任意のサイズの画像を取得し、不足している部分を引き伸ばし、変形なし、空白なし
- function my_image_resize($src_file , $dst_file , $new_width , $new_height) {
- $new_width= intval($new_width);
- $new_height=intval($new_width);
- if($new_width < 1 || $new_height <1) {
- echo "パラメータの幅または高さのエラー !";
- exit();
- }
- if(!file_exists($src_file)) {
- echo $src_file " が存在しません !" ;
- exit();
- }
- // 画像の種類
- $type=exif_imagetype($src_file);
- $support_type=array(IMAGETYPE_JPEG , IMAGETYPE_PNG , IMAGETYPE_GIF);
- if(!in_array($type, $support_type,true) ) {
- echo "このタイプの画像はサポートされていません ! jpg、gif、または png のみをサポートします";
- exit();
- }
- //画像をロード
- switch($type) {
- case IMAGETYPE_JPEG :
- $src_img=imagecreatefromjpeg ($src_file);
- ブレーク;
- ケース IMAGETYPE_PNG :
- $src_img=imagecreatefrompng($src_file);
- ブレーク;
- ケース IMAGETYPE_GIF :
- $src_img=imagecreatefromgif($src_file);
- ブレーク;
- デフォルト:
- echo "画像をロードエラー!";
- 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) {
- $ rate = $ratio_h ; // ケース 1、幅と高さの比率が小さいので、高さの比率の標準に従ってトリミングまたは拡大します
- }else {
- $ratio = $ratio_w ;
- }
- // 中間の一時画像を定義しますアスペクト比はターゲット要件を満たしています
- $inter_w=( int)($new_width / $ratio);
- $inter_h=(int) ($new_height / $ratio);
- $inter_img=imagecreatetruecolor($inter_w , $inter_h) ;
- //var_dump($inter_img);
- imagecopy( $inter_img, $src_img, 0,0,0,0,$inter_w,$inter_h);
- // 最大辺の長さをサイズとして一時画像を生成しますターゲット画像 $ratio
- // 新しい画像を定義します
- $new_img=imagecreatetruecolor($new_width,$new_height);
- //var_dump($new_img);exit();
- 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 );
- ブレーク;
- case IMAGETYPE_GIF :
- imagegif($new_img,$dst_file,100);
- ブレーク;
- デフォルト:
- ブレーク;
- }
- } // end if 1
- // 2 対象画像の片側が元の画像より大きく、片側が元の画像より小さい場合、まず通常の画像を拡大してからトリミングします
- // =if( ($ratio_w < 1 && $ rate_h > 1) || ($ratio_w >1 && $ratio_h <1) )
- $ratio=$ratio_h>$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);
- ブレーク;
- case IMAGETYPE_GIF :
- imagegif($new_img,$dst_file,100);
- ブレーク;
- デフォルト:
- ブレーク;
- }
- }// if3
- }// end function
- my_image_resize('test .gif','11111.gif','100px','100px');
- ?>
-
コードをコピーします
編集者の概要:
上記で実装された PHP 画像トリミング関数は、imagecreatefromjpeg、imagecreatefrompng、imagecreatefromgif、imagecreatetruecolor およびその他の関数の使用を含む、PHP gd ライブラリの関連関数を柔軟に適用します。
したがって、写真のトリミングや透かし、サムネイルなどの機能を実現するには、PHP gd ライブラリの各関数の使い方を柔軟に使いこなすことが重要です。
|