From 0ef9102ac61144a183378d0d4638021e2202e0e6 Mon Sep 17 00:00:00 2001 From: cutealien Date: Tue, 27 Sep 2022 16:02:39 +0000 Subject: [PATCH] Fix IGUIElements not getting a tab order because of invisible or disabled parents. First problem was that IGUIElement::getNextElement wasn't passing includeInvisible and includeDisabled flags recursively, so anything deeper than one level could fail if an element was disabled/invisible in between while it was created. Second problem was that setTabOrder(-1) did ignore disabled elements. So when any parent was disabled when elements were created they never got a tab order. git-svn-id: svn://svn.code.sf.net/p/irrlicht/code/trunk@6428 dfc29bdd-3216-0410-991c-e03cc46cb475 --- changes.txt | 3 +++ include/IGUIElement.h | 4 ++-- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/changes.txt b/changes.txt index 438cb17..5a35fae 100644 --- a/changes.txt +++ b/changes.txt @@ -1,6 +1,9 @@ -------------------------- Changes in 1.9 (not yet released) +- Bugfix: IGUIElement::getNextElement now passing includeInvisible and includeDisabled flags recursively instead of disabling those for children. + This fixes problems that elements sometimes didn't get a tab order because some parent was invisible and so tab'ing for them failed completely. + Also setTabOrder(-1) now also checks for disabled elements for the same reason (disabled parent causing children to not get a tab-order). - Fix MouseButtonStates for mouse events in CIrrDeviceSDL when middle or right button are released. - CGUIContextMenu no longer marks EMIE_MOUSE_MOVED as handled - core::array::linear_search and linear_reverse_search can now work with any types as long as corresponding operator== is implemented. diff --git a/include/IGUIElement.h b/include/IGUIElement.h index 9ad6126..25b88a3 100644 --- a/include/IGUIElement.h +++ b/include/IGUIElement.h @@ -434,7 +434,7 @@ public: if (el) { // find the highest element number - el->getNextElement(-1, true, IsTabGroup, first, closest, true); + el->getNextElement(-1, true, IsTabGroup, first, closest, true, true); if (first) { TabOrder = first->getTabOrder() + 1; @@ -720,7 +720,7 @@ public: } } // search within children - if ((*it)->getNextElement(startOrder, reverse, group, first, closest)) + if ((*it)->getNextElement(startOrder, reverse, group, first, closest, includeInvisible, includeDisabled)) { return true; }