From e68acaa02aa5c3faaa2a11577546a328e3a26df4 Mon Sep 17 00:00:00 2001 From: CodingJellyfish Date: Fri, 26 Apr 2024 13:05:36 +0800 Subject: [PATCH] Add resizing code for dynamic ribbon widget --- .../widgets/dynamic_ribbon_widget.cpp | 132 +++++++++++------- .../widgets/dynamic_ribbon_widget.hpp | 3 + 2 files changed, 86 insertions(+), 49 deletions(-) diff --git a/src/guiengine/widgets/dynamic_ribbon_widget.cpp b/src/guiengine/widgets/dynamic_ribbon_widget.cpp index 8e7b5dc3d86..99bc7091dba 100644 --- a/src/guiengine/widgets/dynamic_ribbon_widget.cpp +++ b/src/guiengine/widgets/dynamic_ribbon_widget.cpp @@ -118,25 +118,10 @@ void DynamicRibbonWidget::add() m_properties[PROP_LABELS_LOCATION] == "none" || m_properties[PROP_LABELS_LOCATION] == ""); - if (m_has_label) - { - // m_label_height contains the height of ONE text line - m_label_height = GUIEngine::getFontHeight(); - } - else - { - m_label_height = 0; - } - // ----- add dynamic label at bottom if (m_has_label) { - // leave room for many lines, just in case - rect label_size = rect(m_x, - m_y + m_h - m_label_height, - m_x + m_w, - m_y + m_h + m_label_height*5); - m_label = GUIEngine::getGUIEnv()->addStaticText(L" ", label_size, false, true /* word wrap */, NULL, -1); + m_label = GUIEngine::getGUIEnv()->addStaticText(L" ", rect(0, 0, 1, 1), false, true /* word wrap */, NULL, -1); m_label->setTextAlignment( EGUIA_CENTER, EGUIA_UPPERLEFT ); m_label->setWordWrap(true); } @@ -152,22 +137,11 @@ void DynamicRibbonWidget::add() m_left_widget = new IconButtonWidget(IconButtonWidget::SCALE_MODE_KEEP_TEXTURE_ASPECT_RATIO, false); m_right_widget = new IconButtonWidget(IconButtonWidget::SCALE_MODE_KEEP_TEXTURE_ASPECT_RATIO, false); - const int average_y = m_y + (m_h - m_label_height)/2; - - m_arrows_w = GUIEngine::getFontHeight() * 2; - m_arrows_w = std::max(m_arrows_w, 40); - - const int button_h = m_arrows_w; - // right arrow - rect right_arrow_location = rect(m_x + m_w - m_arrows_w, - average_y - button_h/2, - m_x + m_w, - average_y + button_h/2); - m_right_widget->m_x = right_arrow_location.UpperLeftCorner.X; - m_right_widget->m_y = right_arrow_location.UpperLeftCorner.Y; - m_right_widget->m_w = right_arrow_location.getWidth(); - m_right_widget->m_h = right_arrow_location.getHeight(); + m_right_widget->m_x = 0; + m_right_widget->m_y = 0; + m_right_widget->m_w = 1; + m_right_widget->m_h = 1; m_right_widget->m_event_handler = this; m_right_widget->m_focusable = false; m_right_widget->m_properties[PROP_ID] = "right"; @@ -178,15 +152,10 @@ void DynamicRibbonWidget::add() m_children.push_back( m_right_widget ); // left arrow - rect left_arrow_location = rect(m_x, - average_y - button_h/2, - m_x + m_arrows_w, - average_y + button_h/2); - stringw lmessage = "<<"; - m_left_widget->m_x = left_arrow_location.UpperLeftCorner.X; - m_left_widget->m_y = left_arrow_location.UpperLeftCorner.Y; - m_left_widget->m_w = left_arrow_location.getWidth(); - m_left_widget->m_h = left_arrow_location.getHeight(); + m_left_widget->m_x = 0; + m_left_widget->m_y = 0; + m_left_widget->m_w = 1; + m_left_widget->m_h = 1; m_left_widget->m_event_handler = this; m_left_widget->m_focusable = false; m_left_widget->m_properties[PROP_ID] = "left"; @@ -213,7 +182,81 @@ void DynamicRibbonWidget::add() m_child_height = 256; } + assert( m_left_widget->ok() ); + assert( m_right_widget->ok() ); + m_left_widget->m_element->setVisible(true); + updateForResizing(); + buildInternalStructure(); +} + +// ----------------------------------------------------------------------------- +void DynamicRibbonWidget::resize() +{ + std::string selected[MAX_PLAYER_COUNT]; + for (unsigned i = 0; i < MAX_PLAYER_COUNT; i++) + selected[i] = getSelectionIDString(i); + Widget::resize(); + updateForResizing(); + buildInternalStructure(); + updateItemDisplay(); + for (unsigned i = 0; i < MAX_PLAYER_COUNT; i++) + { + if (!selected[i].empty()) + setSelection(selected[i], i, true); + } +} + +// ----------------------------------------------------------------------------- +void DynamicRibbonWidget::updateForResizing() +{ + if (m_has_label) + { + // m_label_height contains the height of ONE text line + m_label_height = GUIEngine::getFontHeight(); + + // leave room for many lines, just in case + rect label_size = rect(m_x, + m_y + m_h - m_label_height, + m_x + m_w, + m_y + m_h + m_label_height*5); + m_label->setRelativePosition(label_size); + } + else + { + m_label_height = 0; + } + const int average_y = m_y + (m_h - m_label_height)/2; + + m_arrows_w = GUIEngine::getFontHeight() * 2; + m_arrows_w = std::max(m_arrows_w, 40); + + const int button_h = m_arrows_w; + + rect right_arrow_location = rect(m_x + m_w - m_arrows_w, + average_y - button_h/2, + m_x + m_w, + average_y + button_h/2); + m_right_widget->m_x = right_arrow_location.UpperLeftCorner.X; + m_right_widget->m_y = right_arrow_location.UpperLeftCorner.Y; + m_right_widget->m_w = right_arrow_location.getWidth(); + m_right_widget->m_h = right_arrow_location.getHeight(); + m_right_widget->resize(); + + rect left_arrow_location = rect(m_x, + average_y - button_h/2, + m_x + m_arrows_w, + average_y + button_h/2); + m_left_widget->m_x = left_arrow_location.UpperLeftCorner.X; + m_left_widget->m_y = left_arrow_location.UpperLeftCorner.Y; + m_left_widget->m_w = left_arrow_location.getWidth(); + m_left_widget->m_h = left_arrow_location.getHeight(); + m_left_widget->resize(); +} + +// ----------------------------------------------------------------------------- +void DynamicRibbonWidget::buildInternalStructure() +{ if (m_multi_row) { // determine row amount @@ -303,10 +346,6 @@ void DynamicRibbonWidget::add() m_row_amount = 1; } - assert( m_left_widget->ok() ); - assert( m_right_widget->ok() ); - m_left_widget->m_element->setVisible(true); - // get and build a list of IDs (by now we may not yet know everything about items, // but we need to get IDs *now* in order for tabbing to work. m_ids.resize(m_row_amount); @@ -316,11 +355,6 @@ void DynamicRibbonWidget::add() //Log::info("DynamicRibbonWidget", "getNewID returns %d", m_ids[i]); } - buildInternalStructure(); -} -// ----------------------------------------------------------------------------- -void DynamicRibbonWidget::buildInternalStructure() -{ //printf("****DynamicRibbonWidget::buildInternalStructure()****\n"); // ---- Clean-up what was previously there diff --git a/src/guiengine/widgets/dynamic_ribbon_widget.hpp b/src/guiengine/widgets/dynamic_ribbon_widget.hpp index cf8f22d4cf4..031cd41da8d 100644 --- a/src/guiengine/widgets/dynamic_ribbon_widget.hpp +++ b/src/guiengine/widgets/dynamic_ribbon_widget.hpp @@ -185,6 +185,7 @@ namespace GUIEngine void setLabelSize(const irr::core::stringw& text); irr::core::stringw getUserName(const irr::core::stringw& user_name) const; + void updateForResizing(); /** * Font used to write the labels, can be scaled down depending on the * length of the text @@ -314,6 +315,8 @@ namespace GUIEngine virtual void update(float delta); + virtual void resize(); + /** Set approximately how many items are expected to be in this ribbon; will help the layout * algorithm next time add() is called */ void setItemCountHint(int hint) { m_item_count_hint = hint; }