From b41613cdafe5388c34b90dcaaf66c2bb34a1fffc Mon Sep 17 00:00:00 2001 From: Zhilkin Serg Date: Wed, 4 Dec 2024 16:47:19 +0300 Subject: [PATCH] Fixes to score menu --- data/raw/keybindings.json | 14 +++++++++ src/enum_traits.h | 22 +++++++++++++ src/scores_ui.cpp | 65 +++++++++++++++++++-------------------- 3 files changed, 67 insertions(+), 34 deletions(-) diff --git a/data/raw/keybindings.json b/data/raw/keybindings.json index 5ef4601f89e2f..98328721ff176 100644 --- a/data/raw/keybindings.json +++ b/data/raw/keybindings.json @@ -4861,6 +4861,20 @@ { "input_method": "keyboard_code", "mod": [ "ctrl" ], "key": "y" } ] }, + { + "type": "keybinding", + "id": "TOGGLE_MONSTER_GROUP", + "category": "SCORE_UI", + "name": "Toggle monster group", + "bindings": [ { "input_method": "keyboard_any", "key": "m" } ] + }, + { + "type": "keybinding", + "id": "TOGGLE_NPC_GROUP", + "category": "SCORE_UI", + "name": "Toggle NPC group", + "bindings": [ { "input_method": "keyboard_any", "key": "n" } ] + }, { "type": "keybinding", "id": "HELP_KEYBINDINGS", diff --git a/src/enum_traits.h b/src/enum_traits.h index fac2d4abf6a7b..816d52c5bc218 100644 --- a/src/enum_traits.h +++ b/src/enum_traits.h @@ -118,4 +118,26 @@ inline bool operator!( E e ) return !static_cast( e ); } +template +static E &operator++( E &e ) +{ + using I = std::underlying_type_t; + e = static_cast( static_cast( e ) + 1 ); + if( e == enum_traits::last ) { + e = enum_traits::first; + } + return e; +} + +template +static E &operator--( E &e ) +{ + using I = std::underlying_type_t; + if( e == enum_traits::first ) { + e = enum_traits::last; + } + e = static_cast( static_cast( e ) - 1 ); + return e; +} + #endif // CATA_SRC_ENUM_TRAITS_H diff --git a/src/scores_ui.cpp b/src/scores_ui.cpp index 46b5610514d41..32494f0252e2d 100644 --- a/src/scores_ui.cpp +++ b/src/scores_ui.cpp @@ -34,23 +34,11 @@ enum class scores_ui_tab_enum : int { num_tabs }; -static scores_ui_tab_enum &operator++( scores_ui_tab_enum &c ) -{ - c = static_cast( static_cast( c ) + 1 ); - if( c == scores_ui_tab_enum::num_tabs ) { - c = static_cast( 0 ); - } - return c; -} - -static scores_ui_tab_enum &operator--( scores_ui_tab_enum &c ) -{ - if( c == static_cast( 0 ) ) { - c = scores_ui_tab_enum::num_tabs; - } - c = static_cast( static_cast( c ) - 1 ); - return c; -} +template<> +struct enum_traits { + static constexpr scores_ui_tab_enum first = scores_ui_tab_enum::achievements; + static constexpr scores_ui_tab_enum last = scores_ui_tab_enum::num_tabs; +}; class scores_ui; @@ -69,15 +57,18 @@ class scores_ui_impl : public cataimgui::window ImGuiWindowFlags_NoResize | ImGuiWindowFlags_NoMove | ImGuiWindowFlags_NoNav ) {} private: - void draw_achievements_text( bool use_conducts = false ); - void draw_scores_text(); - void draw_kills_text(); + void draw_achievements_text( bool use_conducts = false ) const; + void draw_scores_text() const; + void draw_kills_text() const; scores_ui_tab_enum selected_tab = scores_ui_tab_enum::achievements; scores_ui_tab_enum switch_tab = scores_ui_tab_enum::num_tabs; - size_t window_width = ImGui::GetMainViewport()->Size.x / 3.0 * 2.0; - size_t window_height = ImGui::GetMainViewport()->Size.y / 3.0 * 2.0; + size_t window_width = ImGui::GetMainViewport()->Size.x * 8 / 9; + size_t window_height = ImGui::GetMainViewport()->Size.y * 8 / 9; + + bool monster_group_collapsed = false; + bool npc_group_collapsed = false; protected: void draw_controls() override; @@ -85,11 +76,13 @@ class scores_ui_impl : public cataimgui::window void scores_ui::draw_scores_ui() { - input_context ctxt; + input_context ctxt( "SCORE_UI" ); scores_ui_impl p_impl; ctxt.register_navigate_ui_list(); ctxt.register_leftright(); + ctxt.register_action( "TOGGLE_MONSTER_GROUP" ); + ctxt.register_action( "TOGGLE_NPC_GROUP" ); ctxt.register_action( "NEXT_TAB" ); ctxt.register_action( "PREV_TAB" ); ctxt.register_action( "SELECT" ); @@ -110,7 +103,7 @@ void scores_ui::draw_scores_ui() } } -void scores_ui_impl::draw_achievements_text( bool use_conducts ) +void scores_ui_impl::draw_achievements_text( bool use_conducts ) const { const achievements_tracker &achievements = g->achievements(); if( !achievements.is_enabled() ) { @@ -162,7 +155,7 @@ void scores_ui_impl::draw_achievements_text( bool use_conducts ) ); } -void scores_ui_impl::draw_scores_text() +void scores_ui_impl::draw_scores_text() const { stats_tracker &stats = g->stats(); std::vector valid_scores = stats.valid_scores(); @@ -179,7 +172,7 @@ void scores_ui_impl::draw_scores_text() ); } -void scores_ui_impl::draw_kills_text() +void scores_ui_impl::draw_kills_text() const { const kill_tracker &kills_data = g->get_kill_tracker(); @@ -197,7 +190,7 @@ void scores_ui_impl::draw_kills_text() } if( ImGui::CollapsingHeader( string_format( _( "Monster kills (%d):" ), monster_kills ).c_str(), - ImGuiTreeNodeFlags_DefaultOpen ) ) { + monster_group_collapsed ? ImGuiTreeNodeFlags_None : ImGuiTreeNodeFlags_DefaultOpen ) ) { if( monster_kills == 0 ) { ImGui::TextWrapped( "%s", _( "You haven't killed any monsters yet!" ) ); } else { @@ -219,7 +212,7 @@ void scores_ui_impl::draw_kills_text() } } if( ImGui::CollapsingHeader( string_format( _( "NPC kills (%d):" ), npc_kills ).c_str(), - ImGuiTreeNodeFlags_DefaultOpen ) ) { + npc_group_collapsed ? ImGuiTreeNodeFlags_None : ImGuiTreeNodeFlags_DefaultOpen ) ) { if( npc_kills == 0 ) { ImGui::TextWrapped( "%s", _( "You haven't killed any NPCs yet!" ) ); } else { @@ -242,22 +235,26 @@ void scores_ui_impl::draw_controls() if( last_action == "QUIT" ) { return; + } else if( last_action == "TOGGLE_MONSTER_GROUP" ) { + monster_group_collapsed = !monster_group_collapsed; + } else if( last_action == "TOGGLE_NPC_GROUP" ) { + npc_group_collapsed = !npc_group_collapsed; } else if( last_action == "UP" ) { - ImGui::SetKeyboardFocusHere( -1 ); + ImGui::SetScrollY( ImGui::GetScrollY() - ImGui::GetTextLineHeightWithSpacing() ); } else if( last_action == "DOWN" ) { - ImGui::SetKeyboardFocusHere( 1 ); + ImGui::SetScrollY( ImGui::GetScrollY() + ImGui::GetTextLineHeightWithSpacing() ); } else if( last_action == "NEXT_TAB" || last_action == "RIGHT" ) { + ImGui::SetScrollY( 0 ); switch_tab = selected_tab; ++switch_tab; } else if( last_action == "PREV_TAB" || last_action == "LEFT" ) { + ImGui::SetScrollY( 0 ); switch_tab = selected_tab; --switch_tab; } else if( last_action == "PAGE_UP" ) { - ImGui::SetWindowFocus(); // Dumb hack! Clear our focused item so listbox selection isn't nav highlighted. - ImGui::SetScrollY( ImGui::GetScrollY() - ( window_height / 5.0f ) ); + ImGui::SetScrollY( ImGui::GetScrollY() - window_height ); } else if( last_action == "PAGE_DOWN" ) { - ImGui::SetWindowFocus(); // Dumb hack! Clear our focused item so listbox selection isn't nav highlighted. - ImGui::SetScrollY( ImGui::GetScrollY() + ( window_height / 5.0f ) ); + ImGui::SetScrollY( ImGui::GetScrollY() + window_height ); } ImGuiTabItemFlags_ flags = ImGuiTabItemFlags_None;