Skip to content

Commit

Permalink
Introduce Viewport functions for keeping the mouse over state consi…
Browse files Browse the repository at this point in the history
…stent
  • Loading branch information
Sauermann committed Nov 30, 2024
1 parent 893bbdf commit 6537252
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 0 deletions.
14 changes: 14 additions & 0 deletions doc/classes/Viewport.xml
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,20 @@
If [member handle_input_locally] is set to [code]false[/code], this method will try finding the first parent viewport that is set to handle input locally, and return its value for [method is_input_handled] instead.
</description>
</method>
<method name="notify_mouse_entered">
<return type="void" />
<description>
Inform the Viewport, that the mouse has entered its area. Use this function before sending an [InputEventMouseButton] or [InputEventMouseMotion] to the [Viewport] with [method Viewport.push_input]. See also [method notify_mouse_exited].
[b]Note:[/b] In most cases, it is not necessary to call this function, because [SubViewport] nodes, that are children of [SubViewportContainer] are notified automatically. This is only necessary when interacting with viewports in non-default ways, like for example as textures in [TextureRect] or in 3D-objects with an [Area3D], that forwards input events.
</description>
</method>
<method name="notify_mouse_exited">
<return type="void" />
<description>
Inform the Viewport, that the mouse has left its area. Use this function when the node which displays the viewport notices, that the mouse has left the area of the displayed viewport. See also [method notify_mouse_entered].
[b]Note:[/b] In most cases, it is not necessary to call this function, because [SubViewport] nodes, that are children of [SubViewportContainer] are notified automatically. This is only necessary when interacting with viewports in non-default ways, like for example as textures in [TextureRect] or in 3D-objects with an [Area3D], that forwards input events.
</description>
</method>
<method name="push_input">
<return type="void" />
<param index="0" name="event" type="InputEvent" />
Expand Down
18 changes: 18 additions & 0 deletions scene/main/viewport.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3257,6 +3257,22 @@ void Viewport::_push_unhandled_input_internal(const Ref<InputEvent> &p_event) {
}
}

void Viewport::notify_mouse_entered() {
if (gui.mouse_in_viewport) {
WARN_PRINT_ED("The Viewport was previously notified, that the mouse is in its area. There is no need to notify it at this time.");
return;
}
notification(NOTIFICATION_VP_MOUSE_ENTER);
}

void Viewport::notify_mouse_exited() {
if (!gui.mouse_in_viewport) {
WARN_PRINT_ED("The Viewport was previously notified, that the mouse has left its area. There is no need to notify it at this time.");
return;
}
_mouse_leave_viewport();
}

void Viewport::set_physics_object_picking(bool p_enable) {
ERR_MAIN_THREAD_GUARD;
physics_object_picking = p_enable;
Expand Down Expand Up @@ -4679,6 +4695,8 @@ void Viewport::_bind_methods() {
#ifndef DISABLE_DEPRECATED
ClassDB::bind_method(D_METHOD("push_unhandled_input", "event", "in_local_coords"), &Viewport::push_unhandled_input, DEFVAL(false));
#endif // DISABLE_DEPRECATED
ClassDB::bind_method(D_METHOD("notify_mouse_entered"), &Viewport::notify_mouse_entered);
ClassDB::bind_method(D_METHOD("notify_mouse_exited"), &Viewport::notify_mouse_exited);

ClassDB::bind_method(D_METHOD("get_mouse_position"), &Viewport::get_mouse_position);
ClassDB::bind_method(D_METHOD("warp_mouse", "position"), &Viewport::warp_mouse);
Expand Down
2 changes: 2 additions & 0 deletions scene/main/viewport.h
Original file line number Diff line number Diff line change
Expand Up @@ -578,6 +578,8 @@ class Viewport : public Node {
#ifndef DISABLE_DEPRECATED
void push_unhandled_input(const Ref<InputEvent> &p_event, bool p_local_coords = false);
#endif // DISABLE_DEPRECATED
void notify_mouse_entered();
void notify_mouse_exited();

void set_disable_input(bool p_disable);
bool is_input_disabled() const;
Expand Down

0 comments on commit 6537252

Please sign in to comment.