diff --git a/tutorials/3d/3d_text.rst b/tutorials/3d/3d_text.rst index 9014691b3ebe..a1849a565cac 100644 --- a/tutorials/3d/3d_text.rst +++ b/tutorials/3d/3d_text.rst @@ -44,6 +44,10 @@ Advantages more flexible on that aspect compared to TextMesh, especially for rendering fonts with self-intersecting outlines. +.. seealso:: + + See :ref:`doc_using_fonts` for guidelines on configuring font imports. + Limitations ^^^^^^^^^^^ diff --git a/tutorials/ui/gui_using_fonts.rst b/tutorials/ui/gui_using_fonts.rst index 1ec4b0e11dfb..bb3b02d7da13 100644 --- a/tutorials/ui/gui_using_fonts.rst +++ b/tutorials/ui/gui_using_fonts.rst @@ -8,51 +8,674 @@ Godot allows you to set specific fonts for different UI nodes. 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**. And lastly in +for control nodes under **Theme Overrides > Fonts**. Lastly, in the inspector settings for themes under **Default Font**. -Regardless of where you are creating the font the process is -the same. Click on the font setting you want to add a font to -and a dropdown will appear with two choices: **New Bitmap Font** -and **New Dynamic Font**. - -.. image:: img/new_font.png - -Bitmap fonts (``.fnt``) are a format created by `BMFont `__ -(many BMFont compatible programs exist, like `BMGlyph `__). -If you are using a ``.fnt`` file do not select **New Bitmap Font**. -Instead, drag the file from the file system panel to the -font slot. Selecting the font after adding it to the font slot -gives you three settings that can be changed: **height**, **ascent** -and **distance field**. Distance field fonts were never reimplemented -for Godot 3 and do not work in that version. - -Dynamic Font supports the following formats: -- TrueType (``.ttf``) -- OpenType (``.otf``) +.. note:: + + Since Godot 4.0, font sizes are no longer defined in the font itself but are + instead defined in the node that uses the font. This is done in the + **Theme Overrides > Font Sizes** section of the inspector. + + This allows changing the font size without having to duplicate the font + resource for every different font size. + +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). + +.. tip:: + + 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. + +Dynamic fonts +------------- + +Godot supports the following dynamic font formats: + +- TrueType Font or Collection (``.ttf``, ``.ttc``) +- OpenType Font or Collection (``.otf``, ``.otc``) - Web Open Font Format 1 (``.woff``) - Web Open Font Format 2 (``.woff2``, since Godot 4.0) -If you are using one of these select **New Dynamic Font**. -Click on it to open its settings in the inspector. From here -open the **Font** settings and add your font file to the Font -Data slot. The dynamic font resource is now using the font -you selected. - -There are several options you can adjust. **Extra Spacing** options -control the spacing of characters. **Settings** control the general -settings of the font. - -.. image:: img/dynamic_font_options.png - -In addition, the font data has antialiasing and hinting settings you -can see if you click on it. If you want to adjust either of these -you need to make the font data resource unique, then save it to a -``.tres`` file. Adjusting the font file will not work because ``.ttf``/ -``.otf``/``.woff``/``.woff2`` files can't contain metadata about antialiasing -or hinting. - -If you want to use the same font again but with different settings, -such as a larger size or an outline, create another dynamic font -resource using the same font file, and make the adjustments that you -want. +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. + +Bitmap fonts +------------ + +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 `__. + +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**: + +.. figure:: img/using_fonts_bitmap_font_from_image_import_options.webp + :align: center + :alt: Changing import type to Font Data (Monospace Image Font) + + Changing import type to **Font Data (Monospace Image Font)** + +The font's character set layout can be in any order, but orders that match +standard Unicode are recommended as they'll require far less configuration to +import. Each character's allocated space must also be square. For example, the +bitmap font below contains `ASCII `__ +characters and follows standard ASCII ordering: + +.. figure:: img/using_fonts_monospace_bitmap_font_example.webp + :align: center + :alt: Bitmap font example + + Credit: `LibreQuake `__ + (scaled and cropped to exclude extended range) + +The following import options can be used to import the above font image +successfully: + +.. figure:: img/using_fonts_bitmap_font_from_image_example_configuration.webp + :align: center + :alt: Import options to use for the above example font + + Import options to use for the above example font + +The **Character Ranges** option is an array that maps each position on the image +(in tile coordinates, not pixels). When using a range (specified with a hyphen +between two numbers), the font atlas is traversed from left to right and top to +bottom. + +Make sure the **Character Ranges** option doesn't exceed the number of +**Columns** × **Rows** defined. Otherwise, the font will fail to import. + +Loading a font file +------------------- + +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: + +.. figure:: img/using_fonts_load_font.webp + :align: center + + Loading a font file + +You can also drag-and-drop a font file from the FileSystem dock to the inspector +property that accepts a Font resource. + +Advanced font features +---------------------- + +.. _doc_using_fonts_antialiasing: + +Antialiasing +^^^^^^^^^^^^ + +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. + +.. figure:: img/using_fonts_antialiasing_comparison.webp + :align: center + :alt: Font antialiasing comparison + + From top to bottom: Disabled, Grayscale, LCD Subpixel (RGB) + +.. note:: + + Antialiasing cannot be changed on :ref:`MSDF-rendered fonts ` + – these are always rendered with grayscale antialiasing. + +.. _doc_using_fonts_hinting: + +Hinting +^^^^^^^ + +Hinting controls how aggressively glyph edges should be snapped to pixels when +rasterizing the font. **None** results in the smoothest appearance, which can +make the font look blurry at small sizes. **Light** (default) is sharper by +snapping glyph edges to pixels on the Y axis only, while **Full** is even sharper +by snapping glyph edges to pixels on both X and Y axes. Depending on personal +preference, you may prefer using one hinting mode over the other. + +.. figure:: img/using_fonts_hinting_comparison.webp + :align: center + :alt: Font hinting comparison + + From top to bottom: None, Light, Full hinting + +.. note:: + + 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. + +.. _doc_using_fonts_subpixel_positioning: + +Subpixel positioning +^^^^^^^^^^^^^^^^^^^^ + +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. + +.. _doc_using_fonts_mipmaps: + +Mipmaps +^^^^^^^ + +By default, fonts do not have mipmaps generated to reduce memory usage and speed +up rasterization. However, this can cause downscaled fonts to become grainy. This +can be especially noticeable with :ref:`doc_3d_text` that doesn't have **Fixed +Size** enabled. This can also occur when displaying text with a traditional rasterized +(non-:ref:`MSDF `) font in a Control node that has its scale +lower than ``(1, 1)``. + +After selecting a font in the FileSystem dock, you can enable the **Mipmaps** in +the Import dock to improve downscaled font rendering appearance. + +Mipmaps can be enabled on MSDF fonts as well. This can improve font rencering +quality a little at smaller-than-default sizes, but MSDF fonts are already +resistant to graininess out of the box. + +.. _doc_using_fonts_msdf: + +MSDF font rendering +^^^^^^^^^^^^^^^^^^^ + +Multi-channel signed distance field (MSDF) font rendering allows rendering fonts +at any size, without having to re-rasterize them when their size changes. + +MSDF font rendering has 2 upsides over traditional font rasterization, which +Godot uses by default: + +- The font will always look crisp, even at huge sizes. +- There is less stuttering when rendering characters *at large font sizes* for + the first time, as there is no rasterization performed. + +The downsides of MSDF font rendering are: + +- Higher baseline cost for font rendering. This is usually not noticeable on + desktop platforms, but it can have an impact on low-end mobile devices. +- Fonts at small sizes will not look as clear as rasterized fonts, due to the + lack of hinting. +- Rendering new glyphs for the first time *at small font sizes* may be more + expensive compared to traditional rasterized fonts. + :ref:`doc_using_fonts_font_prerendering` can be used to alleviate this. +- LCD subpixel optimization cannot be enabled for MSDF fonts. +- Fonts with self-intersecting outlines will not render correctly in MSDF mode. + If you notice rendering issues on fonts downloaded from websites such as + `Google Fonts `__, try downloading the font from the + font author's official website instead. + +Using emoji +^^^^^^^^^^^ + +Godot has full support for emoji, but the font used needs to include them. Otherwise, +emoji won't be displayed and placeholder characters will appear instead: + +TODO + +.. tip:: + + To use a regular font alongside emoji, it's recommended to specify a + :ref:`fallback font ` that points to the emoji + font in the regular font's advanced import options. + + Emoji fonts are quite large in size, so you may want to :ref:`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. + + It's possible to use a system font as a fallback font too. + +Using icon fonts +^^^^^^^^^^^^^^^^ + +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 :ref:`doc_3d_text` and TextMesh. + +.. note:: + + 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 :ref:`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 :kbd:`Ctrl + C` (:kbd:`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 a icon font alongside a traditional font in the same Control, you can +specify the icon font as a :ref:`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. + +.. note:: + + 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. + +.. _doc_using_fonts_font_fallbacks: + +Font fallbacks +^^^^^^^^^^^^^^ + +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. + +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: + +.. figure:: img/using_fonts_advanced_import_settings.webp + :align: center + + Import dock + +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**: + +.. figure:: img/using_fonts_font_fallbacks_add.webp + :align: center + + Adding font fallback + +Click the dropdown arrow on the new element, then choose a font file using the +**Quick Load** or **Load** options: + +.. figure:: img/using_fonts_font_fallbacks_load.webp + :align: center + + Loading font fallback + +.. note:: + + Font fallbacks can also be defined on a local basis similar to + :ref:`doc_using_fonts_opentype_font_features`, but this is not covered here + for brevity reasons. + +.. _doc_using_fonts_variable_fonts: + +Variable fonts +^^^^^^^^^^^^^^ + +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 :ref:`class_FontVariation` resource in the +location where you intend to use the font, then load a font file within the +FontVariation resource: + +.. figure:: img/using_fonts_font_variation_create.webp + :align: center + + Creating a FontVariation resource + +.. figure:: img/using_fonts_font_variation_load.webp + :align: center + + Loading a font file into 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: + +.. figure:: img/using_fonts_font_variation_variable_font.webp + :align: center + + List of variation axes + +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``: + +.. figure:: img/using_fonts_font_variation_variable_font_example.webp + :align: center + + Variable font example (Inter V) + +.. tip:: + + 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: + +.. figure:: img/using_fonts_font_variation_save_to_file.webp + :align: center + + Saving FontVariation to an external resource file + +.. _doc_using_fonts_opentype_font_features: + +OpenType font features +^^^^^^^^^^^^^^^^^^^^^^ + +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 featutres: + +**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: + +.. figure:: img/using_fonts_advanced_import_settings.webp + :align: center + + Import dock + +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**: + +.. figure:: img/using_fonts_advanced_import_settings_opentype_features.webp + :align: center + + OpenType feature overrides in Advanced Import Settings + +**In a specific font usage (FontVariation)** + +To use a font feature, create a FontVariation resource like you would do for a +:ref:`variable font `, then load a font file +within the FontVariation resource: + +.. figure:: img/using_fonts_font_variation_create.webp + :align: center + + Creating a FontVariation resource + +.. figure:: img/using_fonts_font_variation_load.webp + :align: center + + Loading a font file into a 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: + +.. figure:: img/using_fonts_font_variation_opentype_features.webp + :align: center + + Specifying OpenType features in a FontVariation resource + +For example, here's the `Inter `__ font without the +*Slashed Zero* feature (top), then with the *Slashed Zero* OpenType feature enabled +(bottom): + +.. figure:: img/using_fonts_font_variation_slashed_zero.webp + :align: center + + OpenType feature comparison (Inter) + +.. _doc_using_fonts_system_fonts: + +System fonts +^^^^^^^^^^^^ + +.. warning:: + + Loading system fonts is only supported on Windows, macOS and Linux. + +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. + +Create a SystemFont resource in the location where you desire to use the system font: + +.. figure:: img/using_fonts_system_font_create.webp + :align: center + + Creating a SystemFont resource + +.. figure:: img/using_fonts_system_font_specify.webp + :align: center + + Specifying a font name to use in a SystemFont resource + +You can either specify one or more font names explicitly (such as ``Arial``), or +specify the name of a font *alias* that maps to a "standard" default font for +the system: + ++----------------+-----------------+----------------+-------------------------+ +| Font alias | Windows | macOS/iOS | Linux | ++================+=================+================+=========================+ +| ``sans-serif`` | Arial | Helvetica | *Handled by fontconfig* | ++----------------+-----------------+----------------+-------------------------+ +| ``serif`` | Times New Roman | Times | *Handled by fontconfig* | ++----------------+-----------------+----------------+-------------------------+ +| ``monospace`` | Courier New | Courier | *Handled by fontconfig* | ++----------------+-----------------+----------------+-------------------------+ +| ``cursive`` | Comic Sans MS | Apple Chancery | *Handled by fontconfig* | ++----------------+-----------------+----------------+-------------------------+ +| ``fantasy`` | Gabriola | Papyrus | *Handled by fontconfig* | ++----------------+-----------------+----------------+-------------------------+ + +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. + +.. note:: + + 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. + +.. _doc_using_fonts_font_prerendering: + +Font prerendering +^^^^^^^^^^^^^^^^^ + +When using traditional rasterized fonts, Godot caches glyphs on a per-font and +per-size basis. This reduces stuttering, but it can still occur the first time a +glyph is displayed when running the project. This can be especially noticeable +at higher font sizes or on mobile devices. + +When using MSDF fonts, they only need to be rasterized once to a special signed +distance field texture. This means caching can be done purely on a per-font +basis, without taking the font size into consideration. However, the initial +rendering of MSDF fonts is slower compared to a traditional rasterized font at a +medium size. + +To avoid stuttering issues related to font rendering, it is possible to +*prerender* certain glyphs. This can be done for all glyphs you intend to use +(for optimal results), or only for common glyphs that are most likely to appear +during gameplay (to reduce file size). Glyphs that aren't pre-rendered will be +rasterizd on-the-fly as usual. + +.. note:: + + In both cases (traditional and MSDF), font rasterization is done on the CPU. + This means that the GPU performance doesn't affect how long it takes for fonts + to be rasterized. + +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: + +.. figure:: img/using_fonts_advanced_import_settings.webp + :align: center + + Import dock + +Move to the **Pre-render Configurations** tab of the Advanced Import Settings dialog, +then add a configuration by clicking the "plus" symbol: + +.. figure:: img/using_fonts_advanced_import_settings_prerender_new_configuration.webp + :align: center + :alt: Adding a new prerendering configuration in the Advanced Import Settings dialog + + Adding a new prerendering configuration in the Advanced Import Settings dialog + +After adding a configuration, make sure it is selected by clicking its name +once. You can also rename the configuration by double-clicking it. + +There are 2 ways to add glyphs to be prerendered to a given configuration. It is +possible to use both approaches in a cumulative manner: + +**Using preexisting text** + +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: + +.. figure:: img/using_fonts_advanced_import_settings_prerender_text.webp + :align: center + :alt: Enabling prerendering in the Advanced Import Settings dialog, Glyphs from the Text tab + + Enabling prerendering in the Advanced Import Settings dialog with the **Glyphs from the Text** tab + +.. tip:: + + If your project supports :ref:`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). + +**By enabling character sets** + +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 +*dobule-click* character sets to be enabled on the right: + +.. figure:: img/using_fonts_advanced_import_settings_prerender_character_map.webp + :align: center + :alt: Enabling prerendering in the Advanced Import Settings dialog, Glyphs from the Character Map tab + + Enabling prerendering in the Advanced Import Settings dialog with the **Glyphs from the Character Map** tab + +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. + +Default project font properties +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +In the **GUI > Theme** section of the advanced Project Settings, you can choose +how the default font should be rendered: + +- **Default Font Antialiasing:** Controls the + :ref:`antialiasing ` method used + for the default project font. +- **Default Font Hinting:** Controls the + :ref:`hinting ` method used for + the default project font. +- **Default Font Subpixel Positioning:** Controls the + :ref:`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 + :ref:`mipmap ` generation and + usage for the default project font. + +.. note:: + + 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. diff --git a/tutorials/ui/img/dynamic_font_options.png b/tutorials/ui/img/dynamic_font_options.png deleted file mode 100644 index 7d32c5c49584..000000000000 Binary files a/tutorials/ui/img/dynamic_font_options.png and /dev/null differ diff --git a/tutorials/ui/img/new_font.png b/tutorials/ui/img/new_font.png deleted file mode 100644 index 43ff0a1569f6..000000000000 Binary files a/tutorials/ui/img/new_font.png and /dev/null differ diff --git a/tutorials/ui/img/using_fonts_advanced_import_settings.webp b/tutorials/ui/img/using_fonts_advanced_import_settings.webp new file mode 100644 index 000000000000..245d4da3dc32 Binary files /dev/null and b/tutorials/ui/img/using_fonts_advanced_import_settings.webp differ diff --git a/tutorials/ui/img/using_fonts_advanced_import_settings_opentype_features.webp b/tutorials/ui/img/using_fonts_advanced_import_settings_opentype_features.webp new file mode 100644 index 000000000000..47ba7b9c5f43 Binary files /dev/null and b/tutorials/ui/img/using_fonts_advanced_import_settings_opentype_features.webp differ diff --git a/tutorials/ui/img/using_fonts_advanced_import_settings_prerender_character_map.webp b/tutorials/ui/img/using_fonts_advanced_import_settings_prerender_character_map.webp new file mode 100644 index 000000000000..5bc232a7a61c Binary files /dev/null and b/tutorials/ui/img/using_fonts_advanced_import_settings_prerender_character_map.webp differ diff --git a/tutorials/ui/img/using_fonts_advanced_import_settings_prerender_new_configuration.webp b/tutorials/ui/img/using_fonts_advanced_import_settings_prerender_new_configuration.webp new file mode 100644 index 000000000000..892ea35fa033 Binary files /dev/null and b/tutorials/ui/img/using_fonts_advanced_import_settings_prerender_new_configuration.webp differ diff --git a/tutorials/ui/img/using_fonts_advanced_import_settings_prerender_text.webp b/tutorials/ui/img/using_fonts_advanced_import_settings_prerender_text.webp new file mode 100644 index 000000000000..bba251005321 Binary files /dev/null and b/tutorials/ui/img/using_fonts_advanced_import_settings_prerender_text.webp differ diff --git a/tutorials/ui/img/using_fonts_antialiasing_comparison.webp b/tutorials/ui/img/using_fonts_antialiasing_comparison.webp new file mode 100644 index 000000000000..1c0415254d54 Binary files /dev/null and b/tutorials/ui/img/using_fonts_antialiasing_comparison.webp differ diff --git a/tutorials/ui/img/using_fonts_bitmap_font_from_image_example_configuration.webp b/tutorials/ui/img/using_fonts_bitmap_font_from_image_example_configuration.webp new file mode 100644 index 000000000000..af822c2bb894 Binary files /dev/null and b/tutorials/ui/img/using_fonts_bitmap_font_from_image_example_configuration.webp differ diff --git a/tutorials/ui/img/using_fonts_bitmap_font_from_image_import_options.webp b/tutorials/ui/img/using_fonts_bitmap_font_from_image_import_options.webp new file mode 100644 index 000000000000..8fb2deae81e7 Binary files /dev/null and b/tutorials/ui/img/using_fonts_bitmap_font_from_image_import_options.webp differ diff --git a/tutorials/ui/img/using_fonts_font_fallbacks_add.webp b/tutorials/ui/img/using_fonts_font_fallbacks_add.webp new file mode 100644 index 000000000000..01c6a4567ce1 Binary files /dev/null and b/tutorials/ui/img/using_fonts_font_fallbacks_add.webp differ diff --git a/tutorials/ui/img/using_fonts_font_fallbacks_load.webp b/tutorials/ui/img/using_fonts_font_fallbacks_load.webp new file mode 100644 index 000000000000..fcc422abd961 Binary files /dev/null and b/tutorials/ui/img/using_fonts_font_fallbacks_load.webp differ diff --git a/tutorials/ui/img/using_fonts_font_variation_create.webp b/tutorials/ui/img/using_fonts_font_variation_create.webp new file mode 100644 index 000000000000..fe28de878d5e Binary files /dev/null and b/tutorials/ui/img/using_fonts_font_variation_create.webp differ diff --git a/tutorials/ui/img/using_fonts_font_variation_load.webp b/tutorials/ui/img/using_fonts_font_variation_load.webp new file mode 100644 index 000000000000..202d8e86c873 Binary files /dev/null and b/tutorials/ui/img/using_fonts_font_variation_load.webp differ diff --git a/tutorials/ui/img/using_fonts_font_variation_opentype_features.webp b/tutorials/ui/img/using_fonts_font_variation_opentype_features.webp new file mode 100644 index 000000000000..f25854d7e570 Binary files /dev/null and b/tutorials/ui/img/using_fonts_font_variation_opentype_features.webp differ diff --git a/tutorials/ui/img/using_fonts_font_variation_save_to_file.webp b/tutorials/ui/img/using_fonts_font_variation_save_to_file.webp new file mode 100644 index 000000000000..49af1c405a41 Binary files /dev/null and b/tutorials/ui/img/using_fonts_font_variation_save_to_file.webp differ diff --git a/tutorials/ui/img/using_fonts_font_variation_slashed_zero.webp b/tutorials/ui/img/using_fonts_font_variation_slashed_zero.webp new file mode 100644 index 000000000000..d6c20cc24db1 Binary files /dev/null and b/tutorials/ui/img/using_fonts_font_variation_slashed_zero.webp differ diff --git a/tutorials/ui/img/using_fonts_font_variation_variable_font.webp b/tutorials/ui/img/using_fonts_font_variation_variable_font.webp new file mode 100644 index 000000000000..4d18a5372f90 Binary files /dev/null and b/tutorials/ui/img/using_fonts_font_variation_variable_font.webp differ diff --git a/tutorials/ui/img/using_fonts_font_variation_variable_font_example.webp b/tutorials/ui/img/using_fonts_font_variation_variable_font_example.webp new file mode 100644 index 000000000000..5ffc9420ac80 Binary files /dev/null and b/tutorials/ui/img/using_fonts_font_variation_variable_font_example.webp differ diff --git a/tutorials/ui/img/using_fonts_hinting_comparison.webp b/tutorials/ui/img/using_fonts_hinting_comparison.webp new file mode 100644 index 000000000000..d8da45e5180b Binary files /dev/null and b/tutorials/ui/img/using_fonts_hinting_comparison.webp differ diff --git a/tutorials/ui/img/using_fonts_load_font.webp b/tutorials/ui/img/using_fonts_load_font.webp new file mode 100644 index 000000000000..79b01d07098a Binary files /dev/null and b/tutorials/ui/img/using_fonts_load_font.webp differ diff --git a/tutorials/ui/img/using_fonts_monospace_bitmap_font_example.webp b/tutorials/ui/img/using_fonts_monospace_bitmap_font_example.webp new file mode 100644 index 000000000000..aa12864644a7 Binary files /dev/null and b/tutorials/ui/img/using_fonts_monospace_bitmap_font_example.webp differ diff --git a/tutorials/ui/img/using_fonts_msdf_import_options.webp b/tutorials/ui/img/using_fonts_msdf_import_options.webp new file mode 100644 index 000000000000..6ac7456cee5c Binary files /dev/null and b/tutorials/ui/img/using_fonts_msdf_import_options.webp differ diff --git a/tutorials/ui/img/using_fonts_outline_example.webp b/tutorials/ui/img/using_fonts_outline_example.webp new file mode 100644 index 000000000000..9fe69a168b02 Binary files /dev/null and b/tutorials/ui/img/using_fonts_outline_example.webp differ diff --git a/tutorials/ui/img/using_fonts_rasterized_vs_msdf_comparison.webp b/tutorials/ui/img/using_fonts_rasterized_vs_msdf_comparison.webp new file mode 100644 index 000000000000..fe44d2640a9b Binary files /dev/null and b/tutorials/ui/img/using_fonts_rasterized_vs_msdf_comparison.webp differ diff --git a/tutorials/ui/img/using_fonts_shadow.webp b/tutorials/ui/img/using_fonts_shadow.webp new file mode 100644 index 000000000000..a6a23a3ec33e Binary files /dev/null and b/tutorials/ui/img/using_fonts_shadow.webp differ diff --git a/tutorials/ui/img/using_fonts_shadow_example.webp b/tutorials/ui/img/using_fonts_shadow_example.webp new file mode 100644 index 000000000000..f844a44119ec Binary files /dev/null and b/tutorials/ui/img/using_fonts_shadow_example.webp differ diff --git a/tutorials/ui/img/using_fonts_system_font_create.webp b/tutorials/ui/img/using_fonts_system_font_create.webp new file mode 100644 index 000000000000..1c7842e1dce9 Binary files /dev/null and b/tutorials/ui/img/using_fonts_system_font_create.webp differ diff --git a/tutorials/ui/img/using_fonts_system_font_serif.webp b/tutorials/ui/img/using_fonts_system_font_serif.webp new file mode 100644 index 000000000000..4d07c3ea213a Binary files /dev/null and b/tutorials/ui/img/using_fonts_system_font_serif.webp differ diff --git a/tutorials/ui/img/using_fonts_system_font_specify.webp b/tutorials/ui/img/using_fonts_system_font_specify.webp new file mode 100644 index 000000000000..64ccdaa974f2 Binary files /dev/null and b/tutorials/ui/img/using_fonts_system_font_specify.webp differ