Skip to content

Gui in 3D issues #77189

Open
Open
@BastiaanOlij

Description

Godot version

4.0.0.stable

System information

N/a

Issue description

I couldn't find the issue where this was previously discussed however after doing some testing and creating an MRP I figured a new issue that highlights just two of the issues specifically would help.

When we're using the "GUI in 3D" approach as demo'ed in https://github.com/godotengine/godot-demo-projects/tree/master/viewport/gui_in_3d we run into the problem that a number of controls now assume a subviewport is used in conjunction with a subviewport container and is always a normal 2D UI where coordinates within the subviewport map 1:1 to screen coordinates through simple translation.

This assumption is false.

The approach showcased in the "GUI in 3D" demo is prevalent among 3D games where UIs are shown on elements within the scene.

In the use case of XR this approach is exclusively used as this is the only method of displaying and interacting with a 2D UI. The input device is no longer the mouse connected to the PC (if there even is one) but often is implemented as a laser pointer attached to one of the users hands, where the laser pointer interacting with the 3D element results in mouse events being sent to the subviewport.

It is thus important that UI controls properly react to mouse events and the mouse coordinates presented within, instead of attempting to use system mouse coordinates transformed into local space as the latter may not exist.

Steps to reproduce

Run the attached MRP, this is a copy of the "GUI in 3D" example from our demo repository but with a larger display and two controls embedded that show the issue.

First we immediately see this warning in the debugger:
image
This warning indicates we're using the screen transform function from within a subviewport which isn't used in conjunction with a subviewport container. It is only presented the first time it's encountered but triggered from a bunch of controls that are attempting to obtain the mouse position.

In the UI the first failure, which is a minor one, is our tab bar. This contains logic to detect hovering over a tab to highlight it and show a preview. This does not work in the UI:
hovertab

Then switch to the second tab, this has a color picker button on it. Pressing this button will overlay a color picker. This would normally close if you click away from it but this doesn't work.
clickawayfromcolorpicker

There are other controls that exhibit similar issues. They can be easily replicated within the "Gui in 3D" demo project.

Minimal reproduction project

gui_in_3d.zip

Activity

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions