ホームページ  >  記事  >  バックエンド開発  >  php_PHP チュートリアルでサムネイル コードを生成する

php_PHP チュートリアルでサムネイル コードを生成する

WBOY
WBOYオリジナル
2016-07-21 15:17:53899ブラウズ

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



コードをコピー

コードは次のとおりです: <
// この関数はソースファイルから画像を取り出し、指定されたサイズに設定します。を指定し、出力先ファイルに出力します
// ソースファイル形式: 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);
ケース 3:
$imgsrc; ImageCreateFromPNG($srcFile);
}
$srcW = ImageSY($imgsrc);
$ni = ImageCreate($dstW,$dstH); $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
関数の種類:グラフィック処理
内容の説明:この関数は、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);
switch ($img_info[2])
{
case 1:
$imgtype = "GIF";
ケース 2:
$imgtype = "PNG";
$img_type = $ imgtype." Image";
$img_size = ceil(filesize($img)/1000)."k"; // ファイルサイズを取得

$new_img_info = array (
"width"=>$img_info[0] ,
"高さ"=>$img_info[1],
"タイプ"=>$img_type,
"サイズ"=>$img_size
);
print "高さ";
print $img_type;
print $new_img_info;

$img www/htdocs/images/jf.gif";
getImageInfo($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);
戻り値: integer
関数の種類: グラフィック処理

内容の説明: この関数は新しいものをコピーできます画像を編集し、画像のサイズを変更します。パラメータの場合、目的が最初に来て、ソースが最後に来ます。パラメータ 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画像には著作権の問題があるため、
商用利用には十分な配慮が必要です。



http://www.bkjia.com/PHPjc/325640.html

www.bkjia.com

tru​​e

http://www.bkjia.com/PHPjc/325640.html

技術記事

HTML では画像の幅と高さを指定することで画像を任意に拡大縮小できますが、この方法では画像のピクセル数は減りません。グラフィック ファイルのサイズは変わっていませんし、もちろん変わっていません...




声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。