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-5thumb.php
コードをコピー コードは次のとおりです:
// この関数はソースファイルから画像を取り出し、指定されたサイズに設定して出力先に出力します。 file
// ソース ファイル形式: gif 、jpg、png
// 宛先ファイル形式: gif
// $srcFile: ソース ファイル
// $dstFile: ターゲット ファイル
// $dstW: ターゲット画像の幅
// $ dstH: ターゲットファイルの高さ
function makethumb( $srcFile,$dstFile,$dstW,$dstH)
{
$data = GetImageSize($srcFile,&$info)
switch ($data[2])
{
case; 1:
$imgsrc = @ImageCreateFromGIF($srcFile);
ケース 2:
$imgsrc = @ImageCreateFromJPEG($srcFile); $imgsrc);
$srcH = ImageSY($imgsrc);
$ni = ImageCreate($dstW,$dstH); $srcW,$srcH);
Imagegif($ni,$dstFile);
// ブラウザに出力する必要がある場合は、前の文を ImageJpeg($ni) に変更します
// 他の画像が必要な場合この例では、まず getimagesize() 関数を通じてソース画像を取得し、次に imagecreatefromgif()、
imagecreatefromjpeg() または imagecreatefrompng() を使用してソースを作成します。 bitmap $imgsrc を作成し、
imagecreate() 関数を使用して、長さと幅がソース ビットマップの半分であるターゲット ビットマップを作成します。次に、imagecopyresize() 関数を呼び出してソース ビットマップを縮小し、それをターゲット ビットマップにコピーし、最後に imagegif() 関数を使用してサムネイルを生成します。
ここで使用されるグラフィック処理関数は、インストールされている GD ライブラリによって提供されており、個別に説明します。まず、getimagesize() 関数について説明します。その標準構文は次のとおりです。
構文:array getimagesize(string filename,array [imageinfo]);
戻り値:array
関数の種類:グラフィック処理
内容の説明:この関数は、GIF、 JPEG および PNG は、GD ライブラリをインストールせずにこの機能を使用できます。返される配列には 4 つの要素があります。返される配列の最初の要素 (インデックス値 0) はピクチャの高さ (ピクセル単位)、2 番目の要素 (インデックス値 1) はピクチャの幅 (インデックス値 2) です。 ) は画像のファイル形式で、その値 1 は GIF 形式、2 は JPEG/JPG 形式、3 は PNG 形式です。
4 番目の要素 (インデックス値 3) は、画像の高さと幅の文字列、height = xxx 幅=yyy。
getimagesize() 関数を応用すると、画像に関するさまざまな情報を簡単に取得できます。 getimagesize() 関数の使用スキルをさらに理解するために、画像の幅、高さ、形式、およびファイル サイズの情報を取得する例を示します。
プログラム imginfo をプログラムリスト 12-6 に示します。
プログラムリスト 12-6 imginfo.php
コードをコピー コードは以下の通り:
function getImageInfo($img) //$imgは画像ファイルの絶対パス
{
$img_info = getimagesize ($img);
スイッチ ($img_info[2])
ケース 1:
$imgtype = "GIF";
ケース 2:
$imgtype = "JPG";
$imgtype = "PNG ";
break;
$img_type = $imgtype."image";
$img_size = ceil(filesize($img)/1000)."k";
$new_img_info = array (
"幅"=>$img_info[0],
"高さ"=>$img_info[1],
"タイプ"=>$img_type,
"サイズ"=>$img_size
);
print $img_info[0]
print "高さ"; print " フォーマット ";
print $img_size;
$img = "/www/htdocs/images/jf"; img);
?>
プログラム 12-5 でサムネイルを作成するには、まず描画用の空白のキャンバスを作成する必要があります。
ImageCreate関数はこれを行うことができます。画像の識別子を返すので、キャンバスの大きさをピクセル単位でどのくらいにするか
(x (幅) 対 y (高さ)) を関数に伝える必要があります。プログラム12-5で使用する画像作成関数imagecreate()の標準構文は以下のとおりです:
構文: int imagecreate(int x_size,int y_size);
戻り値: 整数
関数の種類: グラフィックス処理
内容の説明: これ関数は完全に空のグラフを作成するために使用されます。パラメータ x_size と y_size はグラフィックのサイズで、単位はピクセルです。
既存の画像から画像ファイルのコードを抽出したい場合は、imagecreatefromgif()、
imagecreatefromjpeg()、または imagecreatefrompng() を使用できます。たとえば、関数 imagecreatefromgif() は、GIF
形式から対応する画像ソースを抽出します。画像ファイルのコードの標準構文は次のとおりです:
構文: int imagecreatefromgif(string filename);
戻り値: 整数
関数の種類: グラフィック処理
内容の説明: この関数は通常、GIF 形式のグラフィックを取得するために使用されます。背景または基本的なキャンバスとして使用される使用例
。パラメータのファイル名には、ローカル ファイルまたはネットワーク URL アドレスを指定できます。戻り値は GIF ファイル
コードであり、他の関数で使用できます。
ソース ビットマップが縮小されてターゲット ビットマップにコピーされる場合、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);
戻り値: 整数
関数の種類: グラフィック処理
内容の説明: この関数は新しいものをコピーできます画像を編集し、画像のサイズを変更します。パラメータの場合、目的が最初に来て、ソースが最後に来ます。パラメータ ddst_im および src_im はイメージのハンドルです。パラメータ dstX、dstY、srcX、および srcY は、それぞれ宛先とソースの座標です。パラメータ dstW、dstH、srcW、および srcH は、それぞれソースとデスティネーションの幅と高さです。新しいイメージのサイズを調整する場合は、ここで設定します。
画像の出力に使用されるimagegif()関数の標準構文は次のとおりです:
構文: int imagegif(int im,string [filename]);
戻り値: 整数
関数の種類: グラフィック処理
内容の説明: この関数GIF 形式のグラフィックを作成するために使用されます。パラメータ im は、ImageCreate() を使用して作成された画像コードです。パラメータ ファイル名が存在しない場合は、画像を送信する前に Content-type を使用することを忘れないでください。画像/gifの文字列をブラウザに送信することで画像をスムーズに送信します。背景が透明な GIF 画像 (GIF89a 形式) を使用する場合は、まず
ImageColorTransparent() を使用して透明な背景を設定する必要があります。著作権の問題により、この機能で生成されたGIF画像を商用利用する場合には、より考慮する必要があります。