サードパーティのライブラリ ファイルをインストールし、一定の幾何学的知識がある限り、PHP を使用して画像を作成および処理できます。 PHP を使用して動的な画像を作成するのは非常に簡単です。以下、著者がそれを実現する方法を詳しく紹介します。
基本的なイメージ作成機能を使用する前に、GD ライブラリ ファイルをインストールする必要があります。 JPEG 関連の画像作成機能を使用する場合は、jpeg-6b もインストールする必要があります。画像で Type 1 フォントを使用する場合は、t1lib をインストールする必要があります。
イメージ作成環境を構築する前に、いくつかの準備を行う必要があります。まず t1lib をインストールし、次に jpeg-6b をインストールし、次に GD ライブラリ ファイルをインストールします。インストール中は、GD をコンパイルしてライブラリに保存するときに jpeg-6b が使用されるため、ここで指定した順序でインストールする必要があります。jpeg-6b がインストールされていない場合、コンパイル中にエラーが発生します。
これら 3 つのコンポーネントをインストールした後も、PHP を再構成する必要があります。これが、PHP のインストールに DSO を使用する理由の 1 つです。 make clean を実行し、現在の構成に次の内容を追加します:
--with-gd=[/path/to/gd]
--with-jpeg-dir=[/path/ to/jpeg -6b]
--with-t1lib=[/path/to/t1lib]
追加完了後、makeコマンドを実行し、次にmake installコマンドを実行し、Apacheを再起動してphpinfo()を実行します。新しい設定が有効になっているかどうかを確認します。これで、イメージの作成作業を開始できます。
インストールされている GD ライブラリ ファイルのバージョンに応じて、グラフィック ファイルを GIF 形式または PNG 形式で作成できるかどうかが決まります。 gd-1.6 以前のバージョンをインストールした場合、GIF 形式のファイルは使用できますが、PNG ファイルは作成できません。 gd-1.6 以降のバージョンをインストールした場合、PNG ファイルは作成できますが、GIF 形式のファイルは作成できません。
簡単な画像を作成するには多くの機能を使用する必要があります。これについては順を追って説明します。
次の例では、PNG 形式で画像ファイルを作成します。次のコードは、作成された画像の MIME タイプを含むヘッダーです。
: image/png");
ImageCreate() を使用して、空白の画像を表す変数を作成します。この関数には、ピクセル単位の画像サイズのパラメーターが必要です。その形式は ImageCreate(x_size, y_size) です。サイズ 250×250 の画像を作成したい場合は、次のステートメントを使用できます:
$newImg = ImageCreate(250,250);
画像はまだ空白なので、色で塗りつぶします。まず、ImageColorAllocate() 関数を使用して、RGB 値を使用してこの色に名前を割り当てる必要があります。この関数の形式は ImageColorAllocate([image], [red], [green], [blue]) です。空色を定義したい場合は、次のステートメントを使用できます:
$skyblue = ImageColorAllocate($newImg,136,193,255);
次に、ImageFill() 関数を使用して、これをこの色で塗りつぶします 画像の場合、ImageFillRectangle()、ImageFillPolygon() など、いくつかのバージョンの ImageFill() 関数があります。簡単にするために、次の形式で ImageFill() 関数を使用します:
ImageFill([image], [start x point], [start y point], [color])
ImageFill($newImg ,0,0,$skyblue);
最後に、画像の作成後に画像ハンドルと占有メモリを解放します:
ImagePNG($newImg);
ImageDestroy($newImg) ) ; ?>
このようにして、画像を作成するコード全体は次のようになります:
header ("Content-type: image/png");
$ newImg = ImageCreate(250,250 );
$skyblue = ImageColorAllocate($newImg,136,193,255);
ImageFill($newImg,0,0,$skyblue);
ImagePNG($newImg);
ImageDestroy ($newImg);
?>
このスクリプト ファイルを skyblue.php として保存し、ブラウザでアクセスすると、空色の 250×250 の PNG 形式の画像が表示されます。
画像作成機能を使用して、大きな画像を小さな画像に作成するなど、画像を処理することもできます。
画像があり、それを 35×35 のサイズに切り抜きたいとします。サイズイメージ。必要なのは、35×35 の空の画像を作成し、元の画像を含む画像ストリームを作成して、元の画像のサイズ変更したバージョンを新しい空の画像に配置することだけです。
このタスクを完了するための重要な関数は ImageCopyResize() です。これには次の形式が必要です:
ImageCopyResize([新しい画像ハンドル],[元の画像ハンドル],[新しい画像 X], [新しいイメージ Y]、[元のイメージ X]、[元のイメージ Y]、[新しいイメージ X]、[新しいイメージ Y]、[元のイメージ X]、[元のイメージ Y])。
/* ファイルに含まれるコンテンツ タイプをブラウザに知らせるためにヘッダーを送信します*/
header("Content-type: image/png");
/* 新しいファイルを作成して保存します画像の高さと幅の変数*/
$newWidth = 35;
$newHeight = 35;
/* 指定された高さと幅で新しい空白の画像を作成します*/
$newImg = ImageCreate( $ newWidth,$newHeight);
/* 元の大きい画像からデータを取得します*/
$origImg = ImageCreateFromPNG("test.png");
/*サイズ変更された画像をコピーし、ImageSX() を使用して、 ImageSY() は、X と Y の元の画像のサイズを取得します */
ImageCopyResize($newImg,$origImg,0,0,0,0,$newWidth,$newHeight,ImageSX($ origImg),ImageSY( $origImg));
/*目的の画像を作成してメモリを解放 */
ImagePNG($newImg);
ImageDestroy($newImg); ?>
これを小さく保存するとresize.php としてスクリプトを作成し、ブラウザでアクセスすると、35×35 の PNG 形式の画像が表示されます。