Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

4.3 cherry picks #10363

Merged
merged 7 commits into from
Dec 3, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion about/list_of_features.rst
Original file line number Diff line number Diff line change
Expand Up @@ -486,7 +486,7 @@ Scripting
- Use any build system and language features you wish.

- Actively developed GDExtension bindings for `D <https://github.com/godot-dlang/godot-dlang>`__,
`Haxe <https://hxgodot.github.io/>`__, `Swift <https://github.com/migueldeicaza/SwiftGodot>`__, and `Rust <https://github.com/godot-rust/gdextension>`__
`Swift <https://github.com/migueldeicaza/SwiftGodot>`__, and `Rust <https://github.com/godot-rust/gdextension>`__
bindings provided by the community. (Some of these bindings may be experimental and not production-ready).

Audio
Expand Down
5 changes: 5 additions & 0 deletions conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -170,6 +170,11 @@
"logo_only": True,
# Collapse navigation (False makes it tree-like)
"collapse_navigation": False,
# Remove version and language picker beneath the title
"version_selector": False,
"language_selector": False,
# Set Flyout menu to attached
"flyout_display": "attached",
}

html_title = supported_languages[language] % ( "(" + version + ")" )
Expand Down
4 changes: 2 additions & 2 deletions tutorials/2d/2d_antialiasing.rst
Original file line number Diff line number Diff line change
Expand Up @@ -77,8 +77,8 @@ affect** the following kinds of aliasing in any way:
- Aliasing in font rendering.

MSAA can be enabled in the Project Settings by changing the value of the
**Rendering > Anti Aliasing > Quality > MSAA 2D** setting. It's important to change
the value of the **MSAA 2D** setting and not **MSAA 3D**, as these are entirely
:ref:`Rendering > Anti Aliasing > Quality > MSAA 2D<class_ProjectSettings_property_rendering/anti_aliasing/quality/msaa_2d>`
setting. It's important to change the value of the **MSAA 2D** setting and not **MSAA 3D**, as these are entirely
separate settings.

Comparison between no antialiasing (left) and various MSAA levels (right). The
Expand Down
7 changes: 5 additions & 2 deletions tutorials/2d/2d_parallax.rst
Original file line number Diff line number Diff line change
Expand Up @@ -78,8 +78,11 @@ do?
Make the viewport smaller
^^^^^^^^^^^^^^^^^^^^^^^^^

The simplest answer is to make the viewport the same size or smaller than your textures. Click on
``Project -> Project Settings -> Window`` and change the viewport height and width to match your background.
The simplest answer is to make the viewport the same size or smaller than your textures.
In **Project Settings > Display > Window**, change the
:ref:`Viewport Width<class_ProjectSettings_property_display/window/size/viewport_width>`
and :ref:`Viewport Height<class_ProjectSettings_property_display/window/size/viewport_height>`
settings to match your background.

.. image:: img/2d_parallax_size_viewport.webp

Expand Down
6 changes: 3 additions & 3 deletions tutorials/2d/custom_drawing_in_2d.rst
Original file line number Diff line number Diff line change
Expand Up @@ -254,9 +254,9 @@ You will have to code a function to perform this and draw it yourself.

The following instructions use a fixed set of coordinates that could be too small
for high resolution screens (larger than 1080p). If that is your case, and the
drawing is too small consider increasing your window scale in
``Menu > Project > Project settings > display/window/stretch/scale`` to adjust
the project to a higher resolution (a 2 or 4 scale tends to work well).
drawing is too small consider increasing your window scale in the project setting
:ref:`Display > Window > Stretch > Scale<class_ProjectSettings_property_display/window/stretch/scale>`
to adjust the project to a higher resolution (a 2 or 4 scale tends to work well).

Drawing a custom polygon shape
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Expand Down
Binary file added tutorials/2d/img/2d_editor_guidelines.webp
Binary file not shown.
Binary file added tutorials/2d/img/2d_editor_viewport.webp
Binary file not shown.
Binary file not shown.
Binary file added tutorials/2d/img/2d_platformer_demo.webp
Binary file not shown.
Binary file added tutorials/2d/img/2d_ruler_with_snap.webp
Binary file not shown.
Binary file added tutorials/2d/img/2d_snapping_options.webp
Binary file not shown.
Binary file added tutorials/2d/img/2d_snapping_options_menu.webp
Binary file not shown.
Binary file added tutorials/2d/img/2d_toolbar.webp
Binary file not shown.
Binary file added tutorials/2d/img/3d_in_2d_demo_editor.webp
Binary file not shown.
1 change: 1 addition & 0 deletions tutorials/2d/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
:maxdepth: 1
:name: toc-learn-features-2d

introduction_to_2d
canvas_layers
2d_transforms

Expand Down
316 changes: 316 additions & 0 deletions tutorials/2d/introduction_to_2d.rst

Large diffs are not rendered by default.

6 changes: 3 additions & 3 deletions tutorials/2d/using_tilesets.rst
Original file line number Diff line number Diff line change
Expand Up @@ -168,7 +168,7 @@ sounds), particle effects, and more.
Scene tiles come with a greater performance overhead compared to atlases, as
every scene is instanced individually for every placed tile.

It's recommended to use only scene tiles when necessary. To draw sprites in a
It's recommended to only use scene tiles when necessary. To draw sprites in a
tile without any kind of advanced manipulation,
:ref:`use atlases instead <doc_creating_tilesets_using_tilesheet>`.

Expand Down Expand Up @@ -257,7 +257,7 @@ TileSet resource, choose **Merge (Keep Original Atlases)** instead.
Adding collision, navigation and occlusion to the TileSet
---------------------------------------------------------

We've now successfully created a basic TileSet. We could start using in the
We've now successfully created a basic TileSet. We could start using it in the
TileMapLayer node now, but it currently lacks any form of collision detection.
This means the player and other objects could walk straight through the floor or
walls.
Expand Down Expand Up @@ -436,7 +436,7 @@ corners or edges of platforms, floors, etc. While these can be placed manually,
this quickly becomes tedious. Handling this situation with procedurally
generated levels can also be difficult and require a lot of code.

Godot offers *terrains* to perform this kind of tile connections automatically.
Godot offers *terrains* to perform this kind of tile connection automatically.
This allows you to have the "correct" tile variants automatically used.

Terrains are grouped into terrain sets. Each terrain set is assigned a mode from
Expand Down
23 changes: 13 additions & 10 deletions tutorials/3d/3d_antialiasing.rst
Original file line number Diff line number Diff line change
Expand Up @@ -65,8 +65,8 @@ moderate performance cost, but it's effective at reducing aliasing on
transparent materials without introducing any blurriness.

MSAA can be enabled in the Project Settings by changing the value of the
**Rendering > Anti Aliasing > Quality > MSAA 3D** setting. It's important to change
the value of the **MSAA 3D** setting and not **MSAA 2D**, as these are entirely
:ref:`Rendering > Anti Aliasing > Quality > MSAA 3D<class_ProjectSettings_property_rendering/anti_aliasing/quality/msaa_3d>`
setting. It's important to change the value of the **MSAA 3D** setting and not **MSAA 2D**, as these are entirely
separate settings.

Comparison between no antialiasing (left) and various MSAA levels (right).
Expand Down Expand Up @@ -103,8 +103,9 @@ downside of TAA is that it can exhibit *ghosting* artifacts behind moving
objects. Rendering at a higher framerate will allow TAA to converge faster,
therefore making those ghosting artifacts less visible.

Temporal antialiasing can be enabled in the Project Settings by changing the
value of the **Rendering > Anti Aliasing > Quality > Use TAA** setting.
Temporal antialiasing can be enabled in the Project Settings by changing the value of the
:ref:`Rendering > Anti Aliasing > Quality > TAA<class_ProjectSettings_property_rendering/anti_aliasing/quality/use_taa>`
setting.

Comparison between no antialiasing (left) and TAA (right):

Expand Down Expand Up @@ -164,9 +165,9 @@ as an in-game option may still be worthwhile for players with low-end GPUs.
FXAA introduces a moderate amount of blur when enabled (more than TAA when
still, but less than TAA when the camera is moving).

FXAA can be enabled in the Project Settings by changing the
value of the **Rendering > Anti Aliasing > Quality > Screen Space AA** setting to
**FXAA**.
FXAA can be enabled in the Project Settings by changing the value of the
:ref:`Rendering > Anti Aliasing > Quality > Screen Space AA<class_ProjectSettings_property_rendering/anti_aliasing/quality/screen_space_aa>`
setting to ``FXAA``.

Comparison between no antialiasing (left) and FXAA (right):

Expand All @@ -187,9 +188,11 @@ The downside of SSAA is its *extremely* high cost. This cost generally makes
SSAA difficult to use for game purposes, but you may still find supersampling
useful for :ref:`offline rendering <doc_creating_movies>`.

Supersample antialiasing is performed by increasing the **Rendering > Scaling 3D
> Scale** advanced project setting above ``1.0`` while ensuring
**Rendering > Scaling 3D > Mode** is set to **Bilinear** (the default).
Supersample antialiasing is performed by increasing the
:ref:`Rendering > Scaling 3D > Scale<class_ProjectSettings_property_rendering/scaling_3d/scale>`
advanced project setting above ``1.0`` while ensuring
:ref:`Rendering > Scaling 3D > Mode<class_ProjectSettings_property_rendering/scaling_3d/mode>`
is set to ``Bilinear`` (the default).
Since the scale factor is defined per-axis, a scale factor of ``1.5`` will result
in 2.25× SSAA while a scale factor of ``2.0`` will result in 4× SSAA. Since Godot
uses the hardware's own bilinear filtering to perform the downsampling, the result
Expand Down
5 changes: 3 additions & 2 deletions tutorials/3d/3d_rendering_limitations.rst
Original file line number Diff line number Diff line change
Expand Up @@ -46,8 +46,9 @@ rendering, where banding may be visible when using smooth gradient textures.

There are two main ways to alleviate banding:

- If using the Forward+ or Forward Mobile rendering methods, enable **Use
Debanding** in the advanced Project Settings. This applies a fullscreen debanding
- If using the Forward+ or Forward Mobile rendering methods, enable
:ref:`Use Debanding<class_ProjectSettings_property_rendering/anti_aliasing/quality/use_debanding>`
in **Project Settings > Rendering > Anti Aliasing**. This applies a fullscreen debanding
shader as a post-processing effect and is very cheap.
- Alternatively, bake some noise into your textures. This is mainly effective in
2D, e.g. for vignetting effects. In 3D, you can also use a `custom debanding
Expand Down
11 changes: 6 additions & 5 deletions tutorials/3d/environment_and_post_processing.rst
Original file line number Diff line number Diff line change
Expand Up @@ -653,7 +653,8 @@ There are 2 ways to use glow in 2D:
rendering output.

- To enable HDR in 2D, open the Project Settings, enable
**Rendering > Viewport > HDR 2D** then restart the editor.
:ref:`Rendering > Viewport > HDR 2D<class_ProjectSettings_property_rendering/viewport/hdr_2d>`
then restart the editor.

- If you want to maximize performance, you can leave HDR disabled for 2D
rendering. However, you will have less control on which objects glow.
Expand All @@ -676,10 +677,10 @@ There are 2 ways to use glow in 2D:
.. warning::

The 2D renderer renders in linear color space if the
**Rendering > Viewport > HDR 2D** project setting is enabled, so
``source_color`` must also be used for uniform samplers that are
used as color input in ``canvas_item`` shaders. If this is not done,
the texture will appear washed out.
:ref:`Rendering > Viewport > HDR 2D<class_ProjectSettings_property_rendering/viewport/hdr_2d>`
project setting is enabled, so the ``source_color`` hint must also be used
for uniform samplers that are used as color input in ``canvas_item`` shaders.
If this is not done, the texture will appear washed out.

If 2D HDR is disabled, ``source_color`` will keep working correctly in
``canvas_item`` shaders, so it's recommend to use it when relevant either
Expand Down
6 changes: 3 additions & 3 deletions tutorials/3d/global_illumination/reflection_probes.rst
Original file line number Diff line number Diff line change
Expand Up @@ -187,9 +187,9 @@ reflection probe rendering. As many reflection probes as desired can be added (a
performance allows). However, there's still a default limit of 512 *clustered
elements* that can be present in the current camera view. A clustered element is
an omni light, a spot light, a :ref:`decal <doc_using_decals>` or a
:ref:`reflection probe <doc_reflection_probes>`. This limit can be increased by
adjusting the **Rendering > Limits > Cluster Builder > Max Clustered Elements**
advanced project setting.
:ref:`reflection probe <doc_reflection_probes>`. This limit can be increased by adjusting
:ref:`Max Clustered Elements<class_ProjectSettings_property_rendering/limits/cluster_builder/max_clustered_elements>`
in **Project Settings > Rendering > Limits > Cluster Builder**.

When using the Forward Mobile backend, only 8 reflection probes can be applied on each
individual Mesh *resource*. If there are more reflection probes affecting a single mesh,
Expand Down
16 changes: 9 additions & 7 deletions tutorials/3d/lights_and_shadows.rst
Original file line number Diff line number Diff line change
Expand Up @@ -61,9 +61,9 @@ real-time lighting. As many lights as desired can be added (as long as
performance allows). However, there's still a default limit of 512 *clustered
elements* that can be present in the current camera view. A clustered element is
an omni light, a spot light, a :ref:`decal <doc_using_decals>` or a
:ref:`reflection probe <doc_reflection_probes>`. This limit can be increased by
adjusting the **Rendering > Limits > Cluster Builder > Max Clustered Elements**
advanced project setting.
:ref:`reflection probe <doc_reflection_probes>`. This limit can be increased by adjusting
:ref:`Max Clustered Elements<class_ProjectSettings_property_rendering/limits/cluster_builder/max_clustered_elements>`
in **Project Settings > Rendering > Limits > Cluster Builder**.

When using the Forward Mobile renderer, there is a limitation of 8 OmniLights +
8 SpotLights per mesh resource. There is also a limit of 256 OmniLights + 256
Expand All @@ -72,10 +72,12 @@ currently cannot be changed.

When using the Compatibility renderer, up to 8 OmniLights + 8 SpotLights can be
rendered per mesh resource. This limit can be increased in the advanced Project
Settings by adjusting **Rendering > Limits > OpenGL > Max Renderable Lights**
and/or **Rendering > Limits > OpenGL > Max Lights Per Object** at the cost of
performance and longer shader compilation times. The limit can also be decreased
to reduce shader compilation times and improve performance slightly.
Settings by adjusting
:ref:`Max Renderable Elements<class_ProjectSettings_property_rendering/limits/opengl/max_renderable_elements>`
and/or :ref:`Max Lights per Object<class_ProjectSettings_property_rendering/limits/opengl/max_lights_per_object>`
in **Rendering > Limits > OpenGL**, at the cost of performance and longer shader
compilation times. The limit can also be decreased to reduce shader compilation
times and improve performance slightly.

With all rendering methods, up to 8 DirectionalLights can be visible at a time.
However, each additional DirectionalLight with shadows enabled will reduce the
Expand Down
11 changes: 6 additions & 5 deletions tutorials/3d/using_decals.rst
Original file line number Diff line number Diff line change
Expand Up @@ -234,8 +234,9 @@ away from the camera (and may have little to no impact on the final scene
rendering). Using node groups, you can also prevent non-essential decorative
decals from spawning based on user configuration.

The way decals are rendered also has an impact on performance. The **Rendering >
Textures > Decals > Filter** advanced project setting lets you control how decal
The way decals are rendered also has an impact on performance. The
:ref:`Rendering > Textures > Decals > Filter<class_ProjectSettings_property_rendering/textures/decals/filter>`
advanced project setting lets you control how decal
textures should be filtered. **Nearest/Linear** does not use mipmaps. However,
decals will look grainy at a distance. **Nearest/Linear Mipmaps** will look
smoother at a distance, but decals will look blurry when viewed from oblique
Expand All @@ -262,9 +263,9 @@ decal rendering. As many decals as desired can be added (as long as
performance allows). However, there's still a default limit of 512 *clustered
elements* that can be present in the current camera view. A clustered element is
an omni light, a spot light, a :ref:`decal <doc_using_decals>` or a
:ref:`reflection probe <doc_reflection_probes>`. This limit can be increased by
adjusting the **Rendering > Limits > Cluster Builder > Max Clustered Elements**
advanced project setting.
:ref:`reflection probe <doc_reflection_probes>`. This limit can be increased by adjusting
:ref:`Max Clustered Elements<class_ProjectSettings_property_rendering/limits/cluster_builder/max_clustered_elements>`
in **Project Settings > Rendering > Limits > Cluster Builder**.

When using the Forward Mobile backend, only 8 decals can be applied on each
individual Mesh *resource*. If there are more decals affecting a single mesh,
Expand Down
2 changes: 1 addition & 1 deletion tutorials/audio/recording_with_microphone.rst
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ A simple demo is included in the official demo projects and will be used as
support for this tutorial:
`<https://github.com/godotengine/godot-demo-projects/tree/master/audio/mic_record>`_.

You will need to enable audio input in the project settings ``Project Settings -> Audio -> Driver -> Enable Input``, or you'll just get empty audio files.
You will need to enable audio input in the :ref:`Audio > Driver > Enable Input<class_ProjectSettings_property_audio/driver/enable_input>` project setting, or you'll just get empty audio files.

The structure of the demo
-------------------------
Expand Down
4 changes: 3 additions & 1 deletion tutorials/performance/thread_safe_apis.rst
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,9 @@ Rendering
---------

Instancing nodes that render anything in 2D or 3D (such as Sprite) is *not* thread-safe by default.
To make rendering thread-safe, set the **Rendering > Driver > Thread Model** project setting to **Multi-Threaded**.
To make rendering thread-safe, set the
:ref:`Rendering > Driver > Thread Model<class_ProjectSettings_property_rendering/driver/threads/thread_model>`
project setting to **Multi-Threaded**.

Note that the Multi-Threaded thread model has several known bugs, so it may not be usable
in all scenarios.
Expand Down
4 changes: 2 additions & 2 deletions tutorials/physics/physics_introduction.rst
Original file line number Diff line number Diff line change
Expand Up @@ -132,7 +132,7 @@ These properties can be configured via code, or by editing them in the Inspector

Keeping track of what you're using each layer for can be difficult, so you
may find it useful to assign names to the layers you're using. Names can
be assigned in Project Settings -> Layer Names.
be assigned in **Project Settings > Layer Names**.

.. image:: img/physics_layer_names.png

Expand Down Expand Up @@ -235,7 +235,7 @@ You can modify a rigid body's behavior via properties such as "Mass",
"Friction", or "Bounce", which can be set in the Inspector.

The body's behavior is also affected by the world's properties, as set in
`Project Settings -> Physics`, or by entering an :ref:`Area2D <class_Area2D>`
**Project Settings > Physics**, or by entering an :ref:`Area2D <class_Area2D>`
that is overriding the global physics properties.

When a rigid body is at rest and hasn't moved for a while, it goes to sleep.
Expand Down
Loading