使用imagettftext()函数可在PHP-GD中绘制TrueType字体文字,需准备.ttf字体文件并确保路径正确;通过imagecreatetruecolor()创建画布,imagecolorallocate()定义颜色,调用imagettftext($im, 20, 0, 50, 50, $textColor, 'fonts/simhei.ttf', '你好,世界!')渲染文字,最后输出PNG图像;注意字体需支持中文以防乱码,确认GD库启用Freetype支持且字体文件可读。

PHP-GD 使用 TrueType 字体需要借助 imagettftext() 函数,该函数允许你在图像上绘制带抗锯齿效果的文字,并支持自定义字体文件(.ttf)。系统默认字体有限,加载自定义字体能提升视觉效果。
准备字体文件
确保你有一个可用的 TrueType 字体文件(.ttf 格式),例如 simhei.ttf(黑体)或 arial.ttf。将字体文件放在项目目录中,比如:
- /path/to/your/project/fonts/simhei.ttf
注意:GD 库不支持 .otf、.woff 等其他字体格式,仅支持 .ttf 和部分 .dfont(macOS)。
使用 imagettftext() 绘制文字
这个函数是加载和渲染 TrueType 字体的核心。其语法如下:
立即学习“PHP免费学习笔记(深入)”;
array imagettftext ( resource $image , float $size , float $angle , int $x , int $y , int $color , string $fontfile , string $text )
参数说明:
- $image:由 imagecreate() 或 imagecreatetruecolor() 创建的图像资源
- $size:字体大小(单位:像素)
- $angle:文字旋转角度(0 为正常,90 表示逆时针旋转)
- $x, $y:文字起始坐标(y 是基线位置)
- $color:用 imagecolorallocate() 定义的颜色
- $fontfile:TrueType 字体文件的完整路径
- $text:要写入的文字内容
完整示例代码
以下是一个生成带中文标题的图片的实例:
常见问题与注意事项
使用过程中可能遇到的问题及解决方法:
- 中文乱码或方框:确保字体支持中文字符集(如 simsun、simhei、droid 等),避免使用仅支持英文的字体(如 arial)
- 提示“Could not read font”:检查字体文件路径是否正确,权限是否可读(chmod 644 fonts/*.ttf)
- PHP 报错:Call to undefined function imagettftext():表示 GD 没有编译 Freetype 支持,请确认 PHP 配置中启用了 --with-freetype
- 服务器环境无 GUI 字体目录:不要依赖系统字体路径(如 /usr/share/fonts),建议将 .ttf 文件放在项目内并使用相对或绝对路径引用
基本上就这些。只要字体文件存在且支持所需字符,配合 imagettftext() 就能顺利在图片上添加美观文字。











