summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrequizm <mehmet41650@gmail.com>2021-08-20 12:49:19 +0300
committerrequizm <mehmet41650@gmail.com>2021-08-20 23:06:00 +0300
commit6f3d8fa228c6b4719206efe0db137356fabfa7f7 (patch)
tree39f9eb22ae3f6969652b51e21f3cb21fee19d90e
parent6cea7ebae4721e05ea7013c6159a751f7498ea85 (diff)
Fix tooltip message working incorrectly in PopupMenu
fix
-rw-r--r--scene/gui/popup_menu.cpp1
-rw-r--r--scene/main/viewport.cpp7
2 files changed, 8 insertions, 0 deletions
diff --git a/scene/gui/popup_menu.cpp b/scene/gui/popup_menu.cpp
index 4bd88fde5f..c3f9933f02 100644
--- a/scene/gui/popup_menu.cpp
+++ b/scene/gui/popup_menu.cpp
@@ -228,6 +228,7 @@ void PopupMenu::_activate_submenu(int p_over) {
// Set autohide areas
PopupMenu *submenu_pum = Object::cast_to<PopupMenu>(submenu_popup);
if (submenu_pum) {
+ submenu_pum->take_mouse_focus();
// Make the position of the parent popup relative to submenu popup
this_rect.position = this_rect.position - submenu_pum->get_position();
diff --git a/scene/main/viewport.cpp b/scene/main/viewport.cpp
index 78fa0985a9..83406842c6 100644
--- a/scene/main/viewport.cpp
+++ b/scene/main/viewport.cpp
@@ -45,6 +45,7 @@
#include "scene/gui/control.h"
#include "scene/gui/label.h"
#include "scene/gui/popup.h"
+#include "scene/gui/popup_menu.h"
#include "scene/main/canvas_layer.h"
#include "scene/main/window.h"
#include "scene/resources/mesh.h"
@@ -1104,6 +1105,12 @@ String Viewport::_gui_get_tooltip(Control *p_control, const Vector2 &p_pos, Cont
while (p_control) {
tooltip = p_control->get_tooltip(pos);
+ //Temporary solution for PopupMenus
+ PopupMenu *menu = Object::cast_to<PopupMenu>(this);
+ if (menu) {
+ tooltip = menu->get_tooltip(pos);
+ }
+
if (r_tooltip_owner) {
*r_tooltip_owner = p_control;
}