diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2023-01-07 13:20:56 +0100 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2023-01-07 13:20:56 +0100 |
commit | 3579d7a9f74e3f1eda88826897feb4b866d75ec9 (patch) | |
tree | 40afa501f94493b7df9dc41c6d7b3ed738f0b15d /scene/gui | |
parent | 447aa5b0259ab18139d86297dfccb8dd68ef2e30 (diff) | |
parent | 2bdd7e9ea0383c06fe6a83445469e41222477abc (diff) |
Merge pull request #36301 from KoBeWi/daddy_node
Add reparent methods to Node
Diffstat (limited to 'scene/gui')
-rw-r--r-- | scene/gui/control.cpp | 8 | ||||
-rw-r--r-- | scene/gui/control.h | 1 |
2 files changed, 9 insertions, 0 deletions
diff --git a/scene/gui/control.cpp b/scene/gui/control.cpp index 64d1d38abb..7daeb6eab6 100644 --- a/scene/gui/control.cpp +++ b/scene/gui/control.cpp @@ -186,6 +186,14 @@ Size2 Control::_edit_get_minimum_size() const { } #endif +void Control::reparent(Node *p_parent, bool p_keep_global_transform) { + Transform2D temp = get_global_transform(); + Node::reparent(p_parent); + if (p_keep_global_transform) { + set_global_position(temp.get_origin()); + } +} + // Editor integration. void Control::get_argument_options(const StringName &p_function, int p_idx, List<String> *r_options) const { diff --git a/scene/gui/control.h b/scene/gui/control.h index 288de7c9e7..a11f7da00f 100644 --- a/scene/gui/control.h +++ b/scene/gui/control.h @@ -387,6 +387,7 @@ public: virtual Size2 _edit_get_minimum_size() const override; #endif + virtual void reparent(Node *p_parent, bool p_keep_global_transform = true) override; // Editor integration. |