Web aym.pekori.to

imagettftext

(PHP 3, PHP 4, PHP 5)

imagettftext -- TrueType フォントを使用したテキストの出力

説明

array imagettftext ( resource image, float size, float angle, int x, int y, int color, string fontfile, string text )

image

イメージリソース。imagecreatetruecolor() を参照ください。

size

フォントサイズ。GD のバージョンに依存し、ピクセルサイズ (GD1) もしくはポイントサイズ (GD2) で指定する必要があります。

angle

度で表される角度。0 度は左から右にテキストを読む方向になります。 0 より大きな値は、時計廻りの回転を表現します。例えば、 90 という値は下から上にテキストを読む方向になります。

x

xy で与えられた座標は、最初の文字のベースポイント (ほぼ文字の左下角) を定義します。 この仕様は、xy で最初の文字の右上角を定義する imagestring() と異なっています。 例えば、左上は 0, 0 となります。

y

y 座標。これは文字の最下位置ではなく、 フォントペースラインの位置を指定します。

color

カラーインデックス。負の数を使用した場合、アンチエイリアス機能が オフになります。 imagecolorallocate() を参照ください。

fontfile

使用する TrueType フォントのパス。

PHP が使用している GD ライブラリのバージョンに依存しており、 fontfile/ で始まらない場合、ファイル名に .ttf が追加され、 ライブラリはライブラリが定義したフォントパスから ファイル名を検索しようとします。

2.0.18 以前のバージョンの GD ライブラリを使用している場合、 異なるフォントファイルに対する 'パスの区切り文字' として セミコロンよりも space 文字が使用されます。 この特徴が意図せずに使用されることで Warning: Could not find/open font という結果になります。 これらの影響があるバージョンに対する唯一の解決方法は、 スペースを含まないパスにフォントを移動させることです。

フォントがスクリプトと同一ディレクトリに存在している場合のほとんどで、 以下のトリックが問題の軽減に繋がります。
<?php
// GD の環境変数を設定する
putenv('GDFONTPATH=' . realpath('.'));

// 使用するフォント名 (拡張子 .ttf がないことに注意)
$font = 'SomeFont';
?>

text

テキスト文字列

フォント内で 127 文字目以降の文字にアクセスするために 10 進数文字参照を含めることができます。 UTF-8 エンコーディングされた文字列を直接渡すことができます。

フォントでサポートされていない文字が文字列で使用されている場合、 その文字は白抜きの矩形に置き換えられます。

imagettftext() は、テキストの境界を 構成する 4 点を表す 8 個の要素を有する配列を返します。 返される点は左上、右上、右下、左下の順番となります。 点の座標は、角度によらず text に関する相対座標として表されます。 つまり、"左上"は、text を水平に見た場合の左上の隅を表します。

例 1. imagettftext() の例

この例題スクリプトは、400x30 ピクセルの白地に Arial フォントを用いて、黒字 (グレーの影付き) で "Testing..." と書かれた PNG を作成します。

<?php
// コンテントタイプを設定する
header("Content-type: image/png");

// 画像を生成する
$im = imagecreatetruecolor(400, 30);

// いくつかの色を生成する
$white = imagecolorallocate($im, 255, 255, 255);
$grey = imagecolorallocate($im, 128, 128, 128);
$black = imagecolorallocate($im, 0, 0, 0);
imagefilledrectangle($im, 0, 0, 399, 29, $white);

// 描画する文字列
$text = 'Testing...';
// フォント自身のパスでパスを置き換える
$font = 'arial.ttf';

// テキストに影を付ける
imagettftext($im, 20, 0, 11, 21, $grey, $font, $text);

// テキストを追加する
imagettftext($im, 20, 0, 10, 20, $black, $font, $text);

// imagepng() を使用して imagejpeg() よりもクリアなテキストにする
imagepng($im);
imagedestroy($im);
?>

この関数は GD ライブラリと FreeType ライブラリの両方が必要です。

imagettfbbox() も参照ください。