ホームページ >php教程 >php手册 >phpでサムネイルコードを生成

phpでサムネイルコードを生成

WBOY
WBOYオリジナル
2016-06-13 11:59:38833ブラウズ

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 ライブラリによって提供されており、ここでは個別に説明します。まず

getimagesize() 関数を紹介します。その標準構文は次のとおりです。
構文: array getimagesize(string filename,array [imageinfo]);
戻り値: array
関数の種類: グラフィック処理
内容の説明: この関数は 3 種類の GIF を取得するために使用できます。 JPEG および PNG この機能を使用すると、GD ライブラリをインストールせずに、WWW 上の画像の高さと幅を設定できます。返される配列には 4 つの要素があります。返される配列の最初の要素 (インデックス値 0) はピクチャの高さ (ピクセル単位)、2 番目の要素 (インデックス値 1) はピクチャの幅 (インデックス値 2) です。 ) は画像のファイル形式で、値 1 は GIF 形式、2 は JPEG/JPG 形式、3 は PNG 形式です。
4 番目の要素 (インデックス値 3) は、画像の高さと幅の文字列です。高さ=xxx 幅=yyy。
getimagesize()関数を応用すると、画像に関するさまざまな情報を簡単に取得できます。 getimagesize() 関数の使用スキルをさらに理解するために、画像の幅、高さ、形式、およびファイル サイズの情報を取得する例を示します。
プログラム imginfo をプログラムリスト 12-6 に示します。

プログラムリスト 12-6 imginfo.php



コードをコピー

コードは次のとおりです。


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 はグラフィックのサイズで、単位
はピクセルです。


既存の画像から画像ファイルのコードを抽出したい場合は、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); 戻り値: integer
関数の型:グラフィックス処理

内容説明: この機能は、新しい画像をコピーし、画像のサイズを変更することができます。パラメータの場合、目的が最初に来て、ソースが最後に来ます。パラメータ ddst_im および src_im はイメージのハンドルです。パラメータ dstX、dstY、srcX、および srcY は、それぞれ宛先
と送信元の座標です。パラメータ dstW、dstH、srcW、および srcH は、それぞれソースとデスティネーションの幅と高さです。新しい画像
のサイズを調整する場合は、ここで設定します。
最終的な画像出力で使用される imagegif() 関数の標準構文は次のとおりです。
構文: int imagegif(int im,string [filename])
戻り値: integer
関数種類 : グラフィック処理
内容説明 : この関数は、GIF 形式のグラフィックを作成するために使用されます。パラメータ im は、ImageCreate() を使用して作成された
の画像コードです。パラメータ ファイル名がない場合は、画像がブラウザに直接送信されます。
の前に画像を送信することを忘れないでください。 Content-type:image/gif ヘッダー文字列をブラウザ
に送信して、画像をスムーズに送信します。背景が透明な GIF 画像 (GIF89a 形式) を使用する場合は、最初に
ImageColorTransparent() を使用して透明な背景を設定する必要があります。この機能で生成されるGIF画像には著作権の問題があるため、
を商用利用する場合はさらに配慮する必要があります。
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。