使用字体
Godot 中能够为不同的 UI 节点设置指定的字体。
There are three different places where you can setup font usage. The first is the theme editor. Choose the node you want to set the font for and select the font tab. The second is in the inspector for control nodes under Theme Overrides > Fonts. Lastly, in the inspector settings for themes under Default Font.
如果其他地方都没有指定字体覆盖项,那么就会使用 Open Sans SemiBold 作为默认的项目字体。
备注
从 Godot 4.0 开始,字体的大小不再随字体本身指定,而是在使用字体的节点中定义。可以在检查器的 Theme Overrides > Font Sizes 中找到。
这样修改字体大小的时候就不必为每种字体大小复制字体一份资源了。
There are 2 kinds of font files: dynamic (TTF/OTF/WOFF/WOFF2 formats) and bitmap (BMFont .fnt
format or monospaced image). Dynamic fonts are the most commonly used option, as they can be resized and still look crisp at higher sizes. Thanks to their vector-based nature, they can also contain a lot more glyphs while keeping a reasonable file size compared to bitmap fonts. Dynamic fonts also support some advanced features that bitmap fonts cannot support, such as ligatures (several characters transforming into a single different design).
小技巧
You can find freely licensed font files on websites such as Google Fonts and Font Library.
Fonts are covered by copyright. Double-check the license of a font before using it, as not all fonts allow commercial use without purchasing a license.
参见
You can see how fonts work in action using the BiDI and Font Features demo project.
动态字体
Godot 支持以下动态字体格式:
TrueType 字体或合集(
.ttf
、.ttc
)OpenType 字体或合集(
.otf
、.otc
)Web 开放字体格式 1(
.woff
)Web 开放字体格式 2(
.woff2
,从 Godot 3.5 开始支持)
While .woff
and especially .woff2
tend to result in smaller file sizes, there is no universally “better” font format. In most situations, it’s recommended to use the font format that was shipped on the font developer’s website.
位图字体
Godot supports the BMFont (.fnt
) bitmap font format. This is a format created by the BMFont program. Many BMFont-compatible programs also exist, like BMGlyph or web-based fontcutter.
Alternatively, you can import any image to be used as a bitmap font. This is only supported for monospaced fonts (fonts where each character has the same width). To do so, select the image in the FileSystem dock, go to the Import dock, change its import type to Font Data (Monospace Image Font) then click Reimport:
字体可以使用任意顺序的字符集布局,但建议使用与标准 Unicode 一致的顺序,这样导入所需的配置就会少很多。例如,下面的位图字体包含了 ASCII 字符,与标准 ASCII 顺序一致:
The following import options can be used to import the above font image successfully:
The Character Ranges option is an array that maps each position on the image (in tile coordinates, not pixels). The font atlas is traversed from left to right and top to bottom. Characters can be specified with decimal numbers (127
), hexadecimal numbers (0x007f
) or between single quotes ('~'
). Ranges can be specified with a hyphen between characters.
For instance, 0-127
(or 0x0000-0x007f
) denotes the full ASCII range. As another example, ' '-'~'
is equivalent to 32-127
and denotes the range of printable (visible) ASCII characters.
Make sure the Character Ranges option doesn’t exceed the number of Columns × Rows defined. Otherwise, the font will fail to import.
If your font image contains margins not used for font glyphs (such as attribution information), try adjusting Image Margin. This is a margin applied only once around the whole image.
If your font image contains guides (in the form of lines between glyphs) or if spacing between characters appears incorrect, try adjusting Character Margin. This margin is applied for every imported glyph.
加载字体文件
To load a font file (dynamic or bitmap), use the resource dropdown’s Quick Load or Load option next to a font property, then navigate to the font file in question:
You can also drag-and-drop a font file from the FileSystem dock to the inspector property that accepts a Font resource.
警告
In Godot 4.0 and later, texture filter and repeat properties are defined in the location where the texture is used, rather than on the texture itself. This also applies to fonts (both dynamic fonts and bitmap fonts).
Fonts that have a pixel art appearance should have bilinear filtering disabled by changing the Rendering > Textures > Canvas Textures > Default Texture Filter project setting to Nearest.
The font size must also be an integer multiple of the design size (which varies on a per-font basis), and the Control node using the font must be scaled by an integer multiple as well. Otherwise, the font may look blurry. Font sizes in Godot are specified in pixels (px), not points (pt). Keep this in mind when comparing font sizes across different software.
The texture filter mode can also be set on individual nodes that inherit from CanvasItem by setting CanvasItem.texture_filter.
字体轮廓与阴影
Font outlines and shadows can be used to improve readability when the background color isn’t known in advance. For instance, this is the case for HUD elements that are drawn over a 2D/3D scene.
Font outlines are available in most nodes that derive from Control, in addition to Label3D.
To enable outline for a font on a given node, configure the theme overrides Font Outline Color and Outline Size in the inspector. The result should look like this:
备注
If using a font with MSDF rendering, its MSDF Pixel Range import option be set to at least twice the value of the outline size for outline rendering to look correct. Otherwise, the outline may appear to be cut off earlier than intended.
Support for font shadows is more limited: they are only available in Label and RichTextLabel. Additionally, font shadows always have a hard edge (but you can reduce their opacity to make them look more subtle). To enable font shadows on a given node, configure the Font Shadow Color, Shadow Offset X, and Shadow Offset Y theme overrides in a Label or RichTextLabel node accordingly:
The result should look like this:
小技巧
You can create local overrides to font display in Label nodes by creating a LabelSettings resource that you reuse across Label nodes. This resource takes priority over theme properties.
高级字体特性
抗锯齿
You can adjust how the font should be smoothed out when rendering by adjusting antialiasing and hinting. These are different properties, with different use cases.
Antialiasing controls how glyph edges should be smoothed out when rasterizing the font. The default antialiasing method (Grayscale) works well on every display technology. However, at small sizes, grayscale antialiasing may result in fonts looking blurry.
The antialiasing sharpness can be improved by using LCD subpixel optimization, which exploits the subpixel patterns of most LCD displays by offsetting the font antialiasing on a per-channel basis (red/green/blue). The downside is that this can introduce “fringing” on edges, especially on display technologies that don’t use standard RGB subpixels (such as OLED displays).
In most games, it’s recommended to stick to the default Grayscale antialiasing. For non-game applications, LCD subpixel optimization is worth exploring.
备注
MSDF 渲染的字体无法修改抗锯齿——这种字体始终使用灰度抗锯齿进行渲染。
微调
微调控制的是对字体进行栅格化的时候,字形边缘吸附到像素的程度。None看上去最平滑,字体较小时会看上去比较模糊。Light(默认值)只会在 Y 轴上对字形的边缘进行吸附,看上去会比较锐利,而 Full 则更加锐利,X 轴和 Y 轴都会进行边缘的吸附。对微调模式的选择取决于你个人的口味。
备注
If changing the hinting mode has no visible effect after clicking Reimport, it’s usually because the font doesn’t include hinting instructions. This can be resolved by looking for a version of the font file that includes hinting instructions, or enabling Force Autohinter in the Import dock. This will use FreeType‘s autohinter to automatically add hinting instructions to the imported font.
次像素定位
Subpixel positioning can be adjusted. This is a FreeType feature that allows glyphs to be rendered more closely to their intended form. The default setting of Auto automatically enables subpixel positioning at small sizes, but disables it at large font sizes to improve rasterization performance.
You can force the subpixel positioning mode to Disabled, One half of a pixel or One quarter of a pixel. One quarter of a pixel provides the best quality, at the cost of longer rasterization times.
Changing antialiasing, hinting and subpixel positioning has the most visible effect at smaller font sizes.
警告
Fonts that have a pixel art appearance should have their subpixel positioning mode set to Disabled. Otherwise, the font may appear to have uneven pixel sizes.
This step is not required for bitmap fonts, as subpixel positioning is only relevant for dynamic fonts (which are usually made of vector elements).
Mipmap
默认情况下字体不会生成 Mipmap,这样就能够降低内存占用、加速栅格化。但这样一来,缩小后的字体就会变成一坨。3D 文本 不启用 Fixed Size 的时候尤为明显。如果在 Control 节点中使用传统的栅格化字体(非 MSDF 字体)显示文本,并且该节点的缩放比 (1, 1)
要小,也会出现这种情况。
在“文件系统”面板中选中字体后,你可以在“导入”面板中启用 Mipmap,从而改善字体缩小渲染后的外观。
MSDF 字体也可以启用 Mipmap。在字体大小小于默认值时,这可以稍稍改善字体的渲染质量,但 MSDF 字体在放大后原本就是没有颗粒度问题的。
MSDF 字体渲染
多通道带符号距离场(Multi-channel signed distance field,MSDF)字体渲染能够将字体渲染为任意大小,无需在大小发生变化时重新栅格化。
与 Godot 默认使用的传统字体栅格化相比,MSDF 字体渲染有两个优点:
即便文字非常巨大,字体看上去也总是清晰的。
首次渲染大字号字体的字符时卡顿更短,因为无须执行栅格化。
MSDF 字体渲染的缺点有:
字体渲染的基础开销较高。桌面平台上通常无法察觉,但是会影响低端移动设备。
由于缺少微调,较小的字体没有栅格化字体清晰。
与传统的栅格化字体相比,首次为新字形渲染小字号字体的开销可能更大。可以使用 字体预渲染 缓解。
无法为 MSDF 字体启用 LCD 次像素优化。
MSDF 模式下无法正确渲染轮廓自相交的字体。如果使用从 Google Fonts 等处下载到的字体时出现渲染问题,请尝试改为从作者的官方网站下载。
To enable MSDF rendering for a given font, select it in the FileSystem dock, go to the Import dock, enable Multichannel Signed Distance Field, then click Reimport:
使用 Emoji
Godot 对 Emoji 字体的支持有限:
支持 CBDT/CBLC(内嵌 PNG)和 SVG Emoji 字体。
不支持 COLR/CPAL Emoji 字体(自定义矢量格式)。
不支持 EMJC 位图压缩(iOS 系统 Emoji 字体需要用到)。这意味着如果要在 iOS 上支持 Emoji,你就必须改用自定义的使用 SVG 或 PNG 位图压缩的字体。
For Godot to be able to display emoji, the font used (or one of its fallbacks) needs to include them. Otherwise, emoji won’t be displayed and placeholder “tofu” characters will appear instead:
After adding a font to display emoji such as Noto Color Emoji, you get the expected result:
To use a regular font alongside emoji, it’s recommended to specify a fallback font that points to the emoji font in the regular font’s advanced import options. If you wish to use the default project font while displaying emoji, leave the Base Font property in FontVariation empty while adding a font fallback pointing to the emoji font:
小技巧
Emoji fonts are quite large in size, so you may want to load a system font to provide emoji glyphs rather than bundling it with your project. This allows providing full emoji support in your project without increasing the size of its exported PCK. The downside is that emoji will look different depending on the platform, and loading system fonts is not supported on all platforms.
也可以将系统字体用作回退字体。
使用图标字体
Tools like Fontello can be used to generate font files containing vectors imported from SVG files. This can be used to render custom vector elements as part of your text, or to create extruded 3D icons with 3D 文本 and TextMesh.
备注
Fontello currently does not support creating multicolored fonts (which Godot can render). As of November 2022, support for multicolored fonts in icon font generation tools remains scarce.
Depending on your use cases, this may lead to better results compared to using the img
tag in RichTextLabel. Unlike bitmap images (including SVGs which are rasterized on import by Godot), true vector data can be resized to any size without losing quality.
After downloading the generated font file, load it in your Godot project then specify it as a custom font for a Label, RichTextLabel or Label3D node. Switch over to the Fontello web interface, then copy the character by selecting it then pressing Ctrl + C (Cmd + C on macOS). Paste the character in the Text property of your Label node. The character will appear as a placeholder glyph in the inspector, but it should appear correctly in the 2D/3D viewport.
To use an icon font alongside a traditional font in the same Control, you can specify the icon font as a fallback. This works because icon fonts use the Unicode private use area, which is reserved for use by custom fonts and doesn’t contain standard glyphs by design.
备注
Several modern icon fonts such as Font Awesome 6 have a desktop variant that uses ligatures to specify icons. This allows you to specify icons by entering their name directly in the Text property of any node that can display fonts. Once the icon’s name is fully entered as text (such as house
), it will be replaced by the icon.
While easier to use, this approach cannot be used with font fallbacks as the main font’s characters will take priority over the fallback font’s ligatures.
字体回退
Godot supports defining one or more fallbacks when the main font lacks a glyph to be displayed. There are 2 main use cases for defining font fallbacks:
Use a font that only supports Latin character sets, but use another font to be able to display text another character set such as Cyrillic.
Use a font to render text, and another font to render emoji or icons.
Open the Advanced Import Settings dialog by double-clicking the font file in the FileSystem dock. You can also select the font in the FileSystem dock, go to the Import dock then choose Advanced… at the bottom:
In the dialog that appears, look for Fallbacks section on the sidebar on the right, click the Array[Font] (size 0) text to expand the property, then click Add Element:
Click the dropdown arrow on the new element, then choose a font file using the Quick Load or Load options:
It is possible to add fallback fonts while using the default project font. To do so, leave the Base Font property empty while adding one or more font fallbacks.
备注
Font fallbacks can also be defined on a local basis similar to OpenType 字体特性, but this is not covered here for brevity reasons.
可变字体
Godot has full support for variable fonts, which allow you to use a single font file to represent various font weights and styles (regular, bold, italic, …). This must be supported by the font file you’re using.
To use a variable font, create a FontVariation resource in the location where you intend to use the font, then load a font file within the FontVariation resource:
Scroll down to the FontVariation’s Variation section, then click the Variation Coordinates text to expand the list of axes that can be adjusted:
The set of axes you can adjust depends on the font loaded. Some variable fonts only support one axis of adjustment (typically weight or slant), while others may support multiple axes of adjustment.
For example, here’s the Inter V font with a weight of 900
and a slant of -10
:
小技巧
While variable font axis names and scales aren’t standardized, some common conventions are usually followed by font designers. For instance, the weight axis typically uses 400
as the “regular” font weight and 700
as the “bold” font weight.
You can save the FontVariation to a .tres
resource file to reuse it in other places:
假粗体和假斜体
When writing text in bold or italic, using font variants specifically designed for this looks better. Spacing between glyphs will be more consistent when using a bold font, and certain glyphs’ shapes may change entirely in italic variants (compare “a” and “a”).
However, real bold and italic fonts require shipping more font files, which increases distribution size. A single variable font file can also be used, but this file will be larger than a single non-variable font. While file size is usually not an issue for desktop projects, it can be a concern for mobile/web projects that strive to keep distribution size as low as possible.
To allow bold and italic fonts to be displayed without having to ship additional fonts (or use a variable font that is larger in size), Godot supports faux bold and italic.
Faux bold and italic is automatically used in RichTextLabel‘s bold and italic tags if no custom fonts are provided for bold and/or italic.
To use faux bold, create a FontVariation resource in a property where a Font resource is expected. Set Variation > Embolden to a positive value to make a font bolder, or to a negative value to make it less bold. Recommended values are between 0.5
and 1.2
depending on the font.
Faux italic is created by skewing the text, which is done by modifying the per-character transform. This is also provided in FontVariation using the Variation > Transform property. Setting the yx
component of the character transform to a positive value will italicize the text. Recommended values are between 0.2
and 0.4
depending on the font.
调整字体间距
For stylistic purposes or for better readability, you may want to adjust how a font is presented in Godot.
Create a FontVariation resource in a property where a Font resource is expected. There are 4 properties available in the Variation > Extra Spacing section, which accept positive and negative values:
Glyph: Additional spacing between every glyph.
Space: Additional spacing between words.
Top: Additional spacing above glyphs. This is used for multiline text, but also to calculate the minimum size of controls such as Label and Button.
Top: Additional spacing below glyphs. This is used for multiline text, but also to calculate the minimum size of controls such as Label and Button.
The Variation > Transform property can also be adjusted to stretch characters horizontally or vertically. This is specifically done by adjusting the xx
(horizontal scale) and yy
(vertical scale) components. Remember to adjust glyph spacing to account for any changes, as glyph transform doesn’t affect how much space each glyph takes in the text. Non-uniform scaling of this kind should be used sparingly, as fonts are generally not designed to be displayed with stretching.
OpenType 字体特性
Godot supports enabling OpenType font features, which are a standardized way to define alternate characters that can be toggled without having to swap font files entirely. Despite being named OpenType font features, these are also supported in TrueType (.ttf
) and WOFF/WOFF2 font files.
Support for OpenType features highly depends on the font used. Some fonts don’t support any OpenType features, while other fonts can support dozens of toggleable features.
There are 2 ways to use OpenType font features:
Globally on a font file
Open the Advanced Import Settings dialog by double-clicking the font file in the FileSystem dock. You can also select the font in the FileSystem dock, go to the Import dock then choose Advanced… at the bottom:
In the dialog that appears, look for the Metadata Overrides > OpenType Features section on the sidebar on the right, click the Features (0 of N set) text to expand the property, then click Add Feature:
In a specific font usage (FontVariation)
To use a font feature, create a FontVariation resource like you would do for a variable font, then load a font file within the FontVariation resource:
Scroll down to the FontVariation’s OpenType Features section, click the Features (0 of N set) text to expand the property, then click Add Feature and select the desired feature in the dropdown:
For example, here’s the Inter font without the Slashed Zero feature (top), then with the Slashed Zero OpenType feature enabled (bottom):
You can disable ligatures and/or kerning for a specific font by adding OpenType features, then unchecking them in the inspector:
系统字体
警告
只有 Windows、macOS、Linux、Android、iOS 支持加载系统字体。
However, loading system fonts on Android is unreliable as there is no official API for doing so. Godot has to rely on parsing system configuration files, which can be modified by third-party Android vendors. This may result in non-functional system font loading.
System fonts are a different type of resource compared to imported fonts. They are never actually imported into the project, but are loaded at run-time. This has 2 benefits:
The fonts are not included within the exported PCK file, leading to a smaller file size for the exported project.
Since fonts are not included with the exported project, this avoids licensing issues that would occur if proprietary system fonts were distributed alongside the project.
引擎会自动使用系统字体作为回退字体,因此不加载自定义字体也能够显示中日韩字符以及 emoji。不过仍然会有一些限制,见使用 emoji 中的相关内容。
需要使用系统字体的地方,请创建 SystemFont 资源:
你可以显式指定若干字体名称(例如 Arial
),也可以指定字体的别名,后者会映射到系统中的“标准”默认字体:
字体别名 | Windows | macOS/iOS | Linux | Android |
---|---|---|---|---|
| Arial | Helvetica | 由 fontconfig 处理 | Roboto / Noto Sans |
| Times New Roman | Times | 由 fontconfig 处理 | Noto Serif |
| Courier New | Courier | 由 fontconfig 处理 | Droid Sans Mono |
| Comic Sans MS | Apple Chancery | 由 fontconfig 处理 | Dancing Script |
| Gabriola | Papyrus | 由 fontconfig 处理 | Droid Sans Mono |
On Android, Roboto is used for Latin/Cyrillic text and Noto Sans is used for other languages’ glyphs such as CJK. On third-party Android distributions, the exact font selection may differ.
If specifying more than one font, the first font that is found on the system will be used (from top to bottom). Font names and aliases are case-insensitive on all platforms.
Like for font variations, you can save the SystemFont arrangement to a resource file to reuse it in other places.
Remember that different system fonts have different metrics, which means that text that can fit within a rectangle on one platform may not be doing so on another platform. Always reserve some additional space during development so that labels can extend further if needed.
备注
Unlike Windows and macOS/iOS, the set of default fonts shipped on Linux depends on the distribution. This means that on different Linux distributions, different fonts may be displayed for a given system font name or alias.
It is also possible to load fonts at runtime even if they aren’t installed on the system. See Runtime loading and saving for details.
字体预渲染
使用传统的栅格字体时,Godot 会针对不同字体的不同尺寸进行字形的缓存。这样做能够减轻卡顿,但卡顿仍然会在项目的运行过程中首次显示某个字形时发生。如果使用的是较大的字体大小,或者是在移动设备上运行,就会尤为明显。
使用 MSDF 字体时,只需要执行一次特殊的带符号距离场纹理栅格化。这样就可以单纯针对字体进行缓存,无需考虑字体大小。不过 MSDF 字体的首次渲染相对于中等大小的传统栅格字体要慢。
为了避免与字体渲染相关的卡顿问题,可以对特定的字形进行预渲染。可以针对所有需要使用的字形进行预渲染(得到最优的效果),也可以只针对游戏中可能出现的常见字形进行预渲染(降低文件尺寸)。没有预渲染的字形会照常进行即时栅格化。
备注
无论是传统字体还是 MSDF 字体,栅格化都是在 CPU 上进行的。也就是说 GPU 的性能并不会影响字体栅格化的耗时。
Open the Advanced Import Settings dialog by double-clicking the font file in the FileSystem dock. You can also select the font in the FileSystem dock, go to the Import dock then choose Advanced… at the bottom:
前往“高级导入设置”对话框的预渲染配置选项卡,单击“加号”添加配置:
添加配置后,请单击对应的名称,确保选中该配置。双击名称可以重命名该配置。
在配置中添加字形的方法有两种。两种方法可以同时使用,效果会累积:
使用翻译中的文本
对于大多数项目而言,使用这个方法最方便,因为可以从语言翻译中自动提取文本。缺点是只有项目支持国际化时才能使用。否则请使用下面“使用自定义文本”的方法。
After adding translations to the Project Settings, use the Glyphs from the Translations tab to check translations by double-clicking them, then click Shape All Strings in the Translations and Add Glyphs at the bottom:
备注
The list of prerendered glyphs is not automatically updated when translations are updated, so you need to repeat this process if your translations have changed significantly.
使用自定义文本
While it requires manually specifying text that will appear in the game, this is the most efficient approach for games which don’t feature user text input. This approach is worth exploring for mobile games to reduce the file size of the distributed app.
To use existing text as a baseline for prerendering, go to the Glyphs from the Text sub-tab of the Advanced Import Settings dialog, enter text in the window on the right, then click Shape Text and Add Glyphs at the bottom of the dialog:
小技巧
If your project supports internationalization, you can paste the contents of your CSV or PO files in the above box to quickly prerender all possible characters that may be rendered during gameplay (excluding user-provided or non-translatable strings).
通过启用字符集
The second method requires less configuration and fewer updates if your game’s text changes, and is more suited to text-heavy games or multiplayer games with chat. On the other hand, it may cause glyphs that never show up in the game to be prerendered, which is less efficient in terms of file size.
To use existing text as a baseline for prerendering, go to the Glyphs from the Character Map sub-tab of the Advanced Import Settings dialog, then double-click character sets to be enabled on the right:
To ensure full prerendering, the character sets you need to enable depend on which languages are supported in your game. For English, only Basic Latin needs to be enabled. Enabling Latin-1 Supplement as well allows fully covering many more languages, such as French, German and Spanish. For Russian, Cyrillic needs to be enabled, and so on.
默认项目字体属性
在高级“项目设置”的 GUI > 主题部分中,可以对默认字体的渲染方式进行选择:
Default Font Antialiasing: Controls the antialiasing method used for the default project font.
Default Font Hinting: Controls the hinting method used for the default project font.
Default Font Subpixel Positioning: Controls the subpixel positioning method for the default project font.
Default Font Multichannel Signed Distance Field: If
true
, makes the default project font use MSDF font rendering instead of traditional rasterization.Default Font Generate Mipmaps: If
true
, enables mipmap generation and usage for the default project font.
备注
These project settings only affect the default project font (the one that is hardcoded in the engine binary).
Custom fonts’ properties are governed by their respective import options instead. You can use the Import Defaults section of the Project Settings dialog to override default import options for custom fonts.