diff options
author | Markus Sauermann <6299227+Sauermann@users.noreply.github.com> | 2022-10-04 21:53:18 +0200 |
---|---|---|
committer | Markus Sauermann <6299227+Sauermann@users.noreply.github.com> | 2023-01-31 22:53:43 +0100 |
commit | decbda68d7067d597698908f53fceebc3247dfcd (patch) | |
tree | c0baf53f9b90803aed252822b454369c98f25b3b /scene/main/viewport.cpp | |
parent | 0056acf46fc88757cae9d9f6fe9805f0eec1cd09 (diff) | |
download | redot-engine-decbda68d7067d597698908f53fceebc3247dfcd.tar.gz |
Prohibit inconsistent size state for SubViewport
Prohibit size changes of SubViewports with parent SubViewportContainers that have stretch mode enabled.
Diffstat (limited to 'scene/main/viewport.cpp')
-rw-r--r-- | scene/main/viewport.cpp | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/scene/main/viewport.cpp b/scene/main/viewport.cpp index 234cebd821..430725f2bf 100644 --- a/scene/main/viewport.cpp +++ b/scene/main/viewport.cpp @@ -4080,9 +4080,26 @@ Viewport::~Viewport() { ///////////////////////////////// void SubViewport::set_size(const Size2i &p_size) { - _set_size(p_size, _get_size_2d_override(), Rect2i(), _stretch_transform(), true); + _internal_set_size(p_size); +} +void SubViewport::set_size_force(const Size2i &p_size) { + // Use only for setting the size from the parent SubViewportContainer with enabled stretch mode. + // Don't expose function to scripting. + _internal_set_size(p_size, true); +} + +void SubViewport::_internal_set_size(const Size2i &p_size, bool p_force) { SubViewportContainer *c = Object::cast_to<SubViewportContainer>(get_parent()); + if (!p_force && c && c->is_stretch_enabled()) { +#ifdef DEBUG_ENABLED + WARN_PRINT("Can't change the size of a `SubViewport` with a `SubViewportContainer` parent that has `stretch` enabled. Set `SubViewportContainer.stretch` to `false` to allow changing the size manually."); +#endif // DEBUG_ENABLED + return; + } + + _set_size(p_size, _get_size_2d_override(), Rect2i(), _stretch_transform(), true); + if (c) { c->update_minimum_size(); } |