PHPCon Poland 2024


(PHP 4, PHP 5, PHP 7, PHP 8)

imagefontwidthYazı tipi piksel genişliğini döndürür


imagefontwidth(GdFont|int $yazıtipi): int

Belirtilen yazı tipindeki bir karakterin piksel cinsinden genişliğini döndürür.

Bağımsız Değişkenler


Değer olarak, Latin2 kodlamalı yerleşik yazı tipleri için 1, 2, 3, 4, 5 (daha büyük numara daha yüksek yazı tipine karşılıktır) veya imageloadfont() işlevinden dönen GdFont örneği belirtilebilir.

Dönen Değerler

Piksel cinsinden genişlik döndürür.

Sürüm Bilgisi

Sürüm: Açıklama
8.1.0 yazıtipi bağımsız değişkeni artık ya GdFont nesnesi ya da tamsayı değer kabul ediyor, evvelce sadece tamsayı değer kabul edilirdi.


Örnek 1 - Yerleşik yazı tipleri üzerinde imagefontwidth()

echo 'Yazı tipi genişliği: ' . imagefontwidth(4) . ' piksel';

Yukarıdaki örnek şuna benzer bir çıktı üretir:

Yazı tipi genişliği: 8 piksel

Örnek 2 - imagefontwidth() ile imageloadfont() işlevinin birlikte kullanımı

// Bir .gdf yazı tipi yükleyelim
$font = imageloadfont('anonymous.gdf');

'Yazı tipi genişliği: ' . imagefontwidth($font) . ' piksel';

Yukarıdaki örnek şuna benzer bir çıktı üretir:

Yazı tipi genişliği: 23 piksel

Ayrıca Bakınız

add a note

User Contributed Notes 3 notes

10 years ago
I've notice that with accented characters (so french !!)
like that:
strlen("câble" * imagefontwidth(FONTSIZE));
this command give a string length bigger than it is in reality
so you have to pass the chain in utf8 decode before

strlen(utf8_decode("câble") * imagefontwidth(FONTSIZE));

that's all (sorry for my english !)
dev at numist dot net
19 years ago
This library function is very useful for variable-sized images that only contain text, like this function that I use to output error messages that accumulate and cause a fatal error in my thumbnailer:

function errimg($error) {
// $error is an array of error messages, each taking up one line
// initialization
$font_size = 2;
$text_width = imagefontwidth($font_size);
$text_height = imagefontheight($font_size);
$width = 0;
// the height of the image will be the number of items in $error
$height = count($error);

// this gets the length of the longest string, in characters to determine
// the width of the output image
for($x = 0; $x < count($error); $x++) {
strlen($error[$x]) > $width) {
$width = strlen($error[$x]);

// next we turn the height and width into pixel values
$width = $width * $text_width;
$height = $height * $text_height;

// create image with dimensions to fit text, plus two extra rows and
// two extra columns for border
$im = imagecreatetruecolor($width + ( 2 * $text_width ),
$height + ( 2 * $text_height ) );
$im) {
// image creation success
$text_color = imagecolorallocate($im, 233, 14, 91);
// this loop outputs the error message to the image
for($x = 0; $x < count($error); $x++) {
// imagestring(image, font, x, y, msg, color);
imagestring($im, $font_size, $text_width,
$text_height + $x * $text_height, $error[$x],
// now, render your image using your favorite image* function
// (imagejpeg, for instance)
out($im, array(), $error);
} else {
// image creation failed, so just dump the array along with extra error
$error[] = "Is GD Installed?";

The function expects an array of error messages to be passed in, and then outputs an image containing the contents of the array. This is especially useful if your code is contained in an html page that will display rexes if the images do not render correctly.

This function displays the array in image form with index 0 at the top, and the highest index at the bottom.

You have to write out() yourself though, see imagejpeg, imagepng, etc for good ideas on how to write a decent output function.
puremango dot co dot uk at gmail dot com
18 years ago
a function that is faster than ImageFontWidth for certain uses:

function ImageFontWidthByFilename($filename)
$handle = @fopen($font_locations[$i],"r");
$c_wid = @fread($handle,11);

echo "./font.gdf is ".ImageFontWidthByFilename("./font.gdf")." pixels wide";


reading the widths of 5 different fonts, 500 times, ImageFontWidth took an average of ~0.004 seconds per 5 reads, my function takes ~0.0003 per 5.

The reason is that ImageFontWidth requires a call to ImageLoadFont, but if for some reason you won't need to load the font, just find out the width, this is the function for you :-)

more such wonders at
To Top