diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/defaultsettings.cpp | 7 | ||||
-rw-r--r-- | src/gui/cheatMenu.cpp | 163 | ||||
-rw-r--r-- | src/gui/cheatMenu.h | 37 |
3 files changed, 145 insertions, 62 deletions
diff --git a/src/defaultsettings.cpp b/src/defaultsettings.cpp index 9e32a11fe..619c26eec 100644 --- a/src/defaultsettings.cpp +++ b/src/defaultsettings.cpp @@ -63,6 +63,13 @@ void set_default_settings(Settings *settings) settings->setDefault("max_out_chat_queue_size", "20"); settings->setDefault("pause_on_lost_focus", "false"); settings->setDefault("enable_register_confirmation", "true"); + + // Cheat Menu + settings->setDefault("cheat_menu_font", "FM_Mono"); + settings->setDefault("m_bg_color_alpha", "173"); + settings->setDefault("m_active_bg_color_alpha", "210"); + settings->setDefault("m_font_color_alpha", "195"); + settings->setDefault("m_selected_font_color_alpha", "235"); // Cheats settings->setDefault("xray", "false"); diff --git a/src/gui/cheatMenu.cpp b/src/gui/cheatMenu.cpp index 1485541c2..5a7f52477 100644 --- a/src/gui/cheatMenu.cpp +++ b/src/gui/cheatMenu.cpp @@ -17,14 +17,57 @@ with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ -#include "cheatMenu.h" #include "script/scripting_client.h" #include "client/client.h" #include "client/fontengine.h" +#include "cheatMenu.h" +#include <cstddef> + +FontMode CheatMenu::fontStringToEnum(std::string str) { + if (str == "FM_Standard") + return FM_Standard; + else if (str == "FM_Mono") + return FM_Mono; + else if (str == "FM_Fallback") + return FM_Fallback; + else if (str == "FM_Simple") + return FM_Simple; + else if (str == "FM_SimpleMono") + return FM_SimpleMono; + else if (str == "FM_MaxMode") + return FM_MaxMode; + else if (str == "FM_Unspecified") + return FM_Unspecified; + else + return FM_Standard; +} CheatMenu::CheatMenu(Client *client) : m_client(client) { - m_font = g_fontengine->getFont(FONT_SIZE_UNSPECIFIED, FM_Fallback); + FontMode fontMode = fontStringToEnum(g_settings->get("cheat_menu_font")); + irr::core::vector3df bg_color; + irr::core::vector3df active_bg_color; + irr::core::vector3df font_color; + irr::core::vector3df selected_font_color; + + g_settings->getV3FNoEx("m_bg_color", bg_color); + g_settings->getV3FNoEx("m_active_bg_color", active_bg_color); + g_settings->getV3FNoEx("m_font_color", font_color); + g_settings->getV3FNoEx("m_selected_font_color", selected_font_color); + + m_bg_color = video::SColor(g_settings->getU32("m_bg_color_alpha"), + bg_color.X, bg_color.Y, bg_color.Z); + + m_active_bg_color = video::SColor(g_settings->getU32("m_active_bg_color_alpha"), + active_bg_color.X, active_bg_color.Y, active_bg_color.Z); + + m_font_color = video::SColor(g_settings->getU32("m_font_color_alpha"), + font_color.X, font_color.Y, font_color.Z); + + m_selected_font_color = video::SColor(g_settings->getU32("m_selected_font_color_alpha"), + selected_font_color.X, selected_font_color.Y, selected_font_color.Z); + + m_font = g_fontengine->getFont(FONT_SIZE_UNSPECIFIED, fontMode); if (!m_font) { errorstream << "CheatMenu: Unable to load fallback font" << std::endl; @@ -37,29 +80,41 @@ CheatMenu::CheatMenu(Client *client) : m_client(client) m_fontsize.Y = MYMAX(m_fontsize.Y, 1); } -void CheatMenu::drawEntry(video::IVideoDriver *driver, std::string name, int number, - bool selected, bool active, CheatMenuEntryType entry_type) +void CheatMenu::drawEntry(video::IVideoDriver *driver, std::string name, + std::size_t column_align_index, std::size_t cheat_entry_index, + bool is_selected, bool is_enabled, CheatMenuEntryType entry_type) { int x = m_gap, y = m_gap, width = m_entry_width, height = m_entry_height; video::SColor *bgcolor = &m_bg_color, *fontcolor = &m_font_color; - if (entry_type == CHEAT_MENU_ENTRY_TYPE_HEAD) { + + // Align with correct column. + x += m_gap + column_align_index * (m_entry_width + m_gap); + + if (is_selected) + fontcolor = &m_selected_font_color; + if (is_enabled) bgcolor = &m_active_bg_color; + + switch (entry_type) + { + case CHEAT_MENU_ENTRY_TYPE_HEAD: height = m_head_height; - } else { - bool is_category = entry_type == CHEAT_MENU_ENTRY_TYPE_CATEGORY; - y += m_gap + m_head_height + - (number + (is_category ? 0 : m_selected_category)) * - (m_entry_height + m_gap); - x += (is_category ? 0 : m_gap + m_entry_width); - if (active) - bgcolor = &m_active_bg_color; - if (selected) - fontcolor = &m_selected_font_color; + break; + case CHEAT_MENU_ENTRY_TYPE_CATEGORY: + y += m_head_height + m_gap; + break; + case CHEAT_MENU_ENTRY_TYPE_ENTRY: + y += m_head_height + (cheat_entry_index + 1) * (m_entry_height + m_gap); + break; + default: + // TODO log an error or something. + break; } + driver->draw2DRectangle(*bgcolor, core::rect<s32>(x, y, x + width, y + height)); - if (selected) + if (is_selected) driver->draw2DRectangleOutline( - core::rect<s32>(x - 1, y - 1, x + width, y + height), + core::rect<s32>(x - 2, y - 2, x + width + 1, y + height + 1), *fontcolor); int fx = x + 5, fy = y + (height - m_fontsize.Y) / 2; core::rect<s32> fontbounds( @@ -69,24 +124,26 @@ void CheatMenu::drawEntry(video::IVideoDriver *driver, std::string name, int num void CheatMenu::draw(video::IVideoDriver *driver, bool show_debug) { - CHEAT_MENU_GET_SCRIPTPTR + ClientScripting *script{ getScript() }; + if (!script || !script->m_cheats_loaded) + return; + // Draw menu header if debug info is not being drawn. if (!show_debug) - drawEntry(driver, "Dragonfireclient", 0, false, false, - CHEAT_MENU_ENTRY_TYPE_HEAD); + drawEntry(driver, "Dragonfireclient", 0, 0, false, false, + CHEAT_MENU_ENTRY_TYPE_HEAD); + int category_count = 0; - for (auto category = script->m_cheat_categories.begin(); - category != script->m_cheat_categories.end(); category++) { + for (const auto &menu_item : script->m_cheat_categories) { bool is_selected = category_count == m_selected_category; - drawEntry(driver, (*category)->m_name, category_count, is_selected, false, - CHEAT_MENU_ENTRY_TYPE_CATEGORY); + drawEntry(driver, menu_item->m_name, category_count, 0, is_selected, + false, CHEAT_MENU_ENTRY_TYPE_CATEGORY); if (is_selected && m_cheat_layer) { int cheat_count = 0; - for (auto cheat = (*category)->m_cheats.begin(); - cheat != (*category)->m_cheats.end(); cheat++) { - drawEntry(driver, (*cheat)->m_name, cheat_count, - cheat_count == m_selected_cheat, - (*cheat)->is_enabled()); + for (const auto &sub_menu_item : menu_item->m_cheats) { + drawEntry(driver, sub_menu_item->m_name, category_count, + cheat_count, cheat_count == m_selected_cheat, + sub_menu_item->is_enabled()); cheat_count++; } } @@ -160,47 +217,57 @@ void CheatMenu::drawHUD(video::IVideoDriver *driver, double dtime) } } -void CheatMenu::selectUp() +void CheatMenu::selectLeft() { CHEAT_MENU_GET_SCRIPTPTR - int max = (m_cheat_layer ? script->m_cheat_categories[m_selected_category] - ->m_cheats.size() - : script->m_cheat_categories.size()) - - 1; - int *selected = m_cheat_layer ? &m_selected_cheat : &m_selected_category; + int max = script->m_cheat_categories.size() - 1; + int *selected = &m_selected_category; --*selected; if (*selected < 0) *selected = max; } -void CheatMenu::selectDown() +void CheatMenu::selectRight() { CHEAT_MENU_GET_SCRIPTPTR - int max = (m_cheat_layer ? script->m_cheat_categories[m_selected_category] - ->m_cheats.size() - : script->m_cheat_categories.size()) - - 1; - int *selected = m_cheat_layer ? &m_selected_cheat : &m_selected_category; + int max = script->m_cheat_categories.size() - 1; + int *selected = &m_selected_category; ++*selected; if (*selected > max) *selected = 0; } -void CheatMenu::selectRight() +void CheatMenu::selectDown() { - if (m_cheat_layer) - return; + CHEAT_MENU_GET_SCRIPTPTR + m_cheat_layer = true; - m_selected_cheat = 0; + + int max = script->m_cheat_categories[m_selected_category]->m_cheats.size(); + int *selected = &m_selected_cheat; + ++*selected; + if (*selected > max) { + *selected = 1; + } } -void CheatMenu::selectLeft() +void CheatMenu::selectUp() { - if (!m_cheat_layer) + if (!m_cheat_layer) { return; - m_cheat_layer = false; + } + + CHEAT_MENU_GET_SCRIPTPTR + + int *selected = &m_selected_cheat; + --*selected; + + if (*selected < 0) { + m_cheat_layer = false; + *selected = 1; + } } void CheatMenu::selectConfirm() diff --git a/src/gui/cheatMenu.h b/src/gui/cheatMenu.h index f67cdea5a..bedd7e048 100644 --- a/src/gui/cheatMenu.h +++ b/src/gui/cheatMenu.h @@ -19,7 +19,10 @@ with this program; if not, write to the Free Software Foundation, Inc., #pragma once +#include "client/client.h" #include "irrlichttypes_extrabloated.h" +#include "script/scripting_client.h" +#include <cstddef> #include <string> #define CHEAT_MENU_GET_SCRIPTPTR \ @@ -27,27 +30,31 @@ with this program; if not, write to the Free Software Foundation, Inc., if (!script || !script->m_cheats_loaded) \ return; -class Client; - -typedef enum +enum CheatMenuEntryType { CHEAT_MENU_ENTRY_TYPE_HEAD, CHEAT_MENU_ENTRY_TYPE_CATEGORY, CHEAT_MENU_ENTRY_TYPE_ENTRY, -} CheatMenuEntryType; +}; class CheatMenu { public: CheatMenu(Client *client); + ClientScripting *getScript() + { + return m_client->getScript(); + } + void draw(video::IVideoDriver *driver, bool show_debug); void drawHUD(video::IVideoDriver *driver, double dtime); - void drawEntry(video::IVideoDriver *driver, std::string name, int number, - bool selected, bool active, - CheatMenuEntryType entry_type = CHEAT_MENU_ENTRY_TYPE_ENTRY); + void drawEntry(video::IVideoDriver *driver, std::string name, + std::size_t column_align_index, std::size_t cheat_entry_index, + bool is_selected, bool is_enabled, + CheatMenuEntryType entry_type = CHEAT_MENU_ENTRY_TYPE_ENTRY); void selectUp(); void selectDown(); @@ -60,15 +67,17 @@ private: int m_selected_cheat = 0; int m_selected_category = 0; - int m_head_height = 50; - int m_entry_height = 40; - int m_entry_width = 200; + int m_head_height = 20; + int m_entry_height = 20; + int m_entry_width = 150; int m_gap = 3; - video::SColor m_bg_color = video::SColor(192, 255, 145, 88); - video::SColor m_active_bg_color = video::SColor(192, 255, 87, 53); - video::SColor m_font_color = video::SColor(255, 0, 0, 0); - video::SColor m_selected_font_color = video::SColor(255, 255, 252, 88); + video::SColor m_bg_color = video::SColor(173, 45, 45, 68); + video::SColor m_active_bg_color = video::SColor(210, 0, 0, 0); + video::SColor m_font_color = video::SColor(195, 255, 255, 255); + video::SColor m_selected_font_color = video::SColor(235, 255, 255, 255); + + FontMode fontStringToEnum(std::string str); Client *m_client; |