HTML では画像の幅と高さを指定することで画像を任意に拡大縮小できますが、この方法では画像のピクセル数は減りません。グラフィック ファイルのサイズは変更されておらず、画像のダウンロードが高速化されることもありません。もちろん、グラフィック ソフトウェアを使用して画像のサムネイルを手動で生成することもできますが、多数の画像を表示する場合、この作業負荷は膨大になります。ミニチュアの自動生成プログラムはこの目的のために設計されました。
PHP で提供される imagecopyresize 関数を使用して、実際の省略された画像を生成できます。この関数の標準の
構文は次のとおりです。
構文: int imagecopyresize(int dst_im, int src_im, int dstX, int dstY,
int srcX, int srcY, int dstW, int dstH, int srcW , int srcH);
戻り値: 整数
関数の種類: グラフィック処理
内容の説明: この関数は、新しい画像をコピーし、画像のサイズを変更できます。すべてのパラメータには目的が最初にあり、ソースは最後にあります。パラメータ dst im および src_im はイメージのハンドルです。パラメータ dstX、dstY、srcX、および srcY は、それぞれ宛先とソースの座標です。パラメータ dstW、dstH、srcW、および srcH は、それぞれソースとデスティネーションの幅と高さであり、調整される新しい画像のサイズがここで設定されます。
以下は、この関数の使用法を示す例です。対応するプログラムthumb.phpをプログラムリスト12-5に示します。
プログラム リスト 12—5 summ.php
コードをコピー コードは次のとおりです:
< ;?
// この関数はソース ファイルから画像を取り出し、指定されたサイズに設定して出力先ファイルに出力します
// ソース ファイル形式: gif、jpg、png
/ / 保存先ファイル形式: gif
// $srcFile: ソースファイル
// $dstFile: ターゲットファイル
// $dstW: ターゲット画像の幅
// $dstH: ターゲットファイルの高さ
function makethumb($srcFile,$dstFile ,$dstW,$dstH)
{
$data = GetImageSize($srcFile,&$info)
switch ($data[2])
{
ケース 1:
$imgsrc = @ImageCreateFromGIF($srcFile);
ケース 2:
$imgsrc = @ImageCreateFromJPEG($srcFile); 🎜>ケース 3:
$ imgsrc = @ImageCreateFromPNG($srcFile);
}
$srcW = ImageSX($imgsrc); ;
$ni = ImageCreate($dstW,$dstH);
ImageCopyResize($ni,$imgsrc,0,0,0,0,$dstW,$dstH,$srcW,$srcH); >Imagegif($ni,$dstFile) ;
// ブラウザに出力する必要がある場合は、前の文を ImageJpeg($ni) に変更します。
// 他の形式の画像が必要な場合は、最後の文を変更します
}
?>
この例では、まず getimagesize() 関数を通じてソース画像を取得し、次に imagecreatefromgif()、
imagecreatefromjpeg を使用します。 () または imagecreatefrompng() を使用してソース ビットマップ $imgsrc を作成し、
imagecreate() 関数を使用して長さと幅がソース ビットマップの半分であるターゲット ビットマップを作成します。次に、imagecopyresize()
関数を呼び出してソース ビットマップを縮小し、それをターゲット ビットマップにコピーし、最後に imagegif() 関数を使用してサムネイルを生成します。
ここで使用するグラフィック処理関数は、インストールされている GD ライブラリによって提供されており、ここでは個別に説明します。まず
function getImageInfo($img) //$img は画像ファイルの絶対パスです
{
$img_info = getimagesize($img);
switch ($ img_info[2])
{
ケース 1:
$imgtype = "GIF";
ケース 2:
$imgtype = "JPG"; 🎜>ブレイク ;
ケース 3:
$imgtype = "PNG";
}
$img_type = $imgtype."image"; filesize($ img)/1000)."k"; //ファイルサイズを取得
$new_img_info = array (
"width"=>$img_info[0],
"height "=>$img_info[1],
"type"=>$img_type,
"size"=>$img_size
);
print " width";
print $img_info[0 ];
print "高さ";
print "サイズ"; print $img_size;
print $new_img_info;
$img = "/www/htdocs/images/jf.gif"; >
プログラム 12-5 でサムネイルを作成するには、まず描画用の空白のキャンバスを作成する必要があります。
ImageCreate 関数はこれを行うことができます。画像の識別子を返すので、キャンバスの大きさ (x(幅) 対 y(高さ)) をピクセル
で関数に伝える必要があります。プログラム 12-5 で使用する画像作成関数 imagecreate()
の標準構文は次のとおりです。
構文: int imagecreate(int x_size, int y_size);
戻り値: integer
関数タイプ:グラフィック処理
内容説明: この関数は、完全に空のグラフを作成するために使用されます。パラメータ x_size と y_size はグラフィックのサイズで、単位
はピクセルです。