]> git.lizzy.rs Git - dragonfireclient.git/blobdiff - src/client/gameui.h
Merge branch 'master' of https://github.com/minetest/minetest
[dragonfireclient.git] / src / client / gameui.h
index ebb7842c4d18c950b6fd0ae534ef22ef16a3b53c..e22be068b2ced66d30cf27f85878390eef936ae7 100644 (file)
@@ -20,13 +20,16 @@ with this program; if not, write to the Free Software Foundation, Inc.,
 
 #pragma once
 
+#include "irrlichttypes.h"
 #include <IGUIEnvironment.h>
+#include "gui/guiFormSpecMenu.h"
 #include "util/enriched_string.h"
 #include "util/pointedthing.h"
 #include "game.h"
 
 using namespace irr;
 class Client;
+class GUIChatConsole;
 struct MapDrawControl;
 
 /*
@@ -46,7 +49,7 @@ class GameUI
        friend class TestGameUI;
 
 public:
-       GameUI() = default;
+       GameUI();
        ~GameUI() = default;
 
        // Flags that can, or may, change during main game loop
@@ -54,15 +57,17 @@ class GameUI
        {
                bool show_chat = true;
                bool show_hud = true;
-               bool show_minimap = true;
-               bool show_debug = true;
-               bool show_profiler_graph = true;
+               bool show_minimap = false;
+               bool show_minimal_debug = false;
+               bool show_basic_debug = false;
+               bool show_profiler_graph = false;
+               bool show_cheat_menu = true;
        };
 
        void init();
        void update(const RunStats &stats, Client *client, MapDrawControl *draw_control,
                        const CameraOrientation &cam, const PointedThing &pointed_old,
-                       float dtime);
+                       const GUIChatConsole *chat_console, float dtime);
 
        void initFlags();
        const Flags &getFlags() const { return m_flags; }
@@ -80,30 +85,57 @@ class GameUI
        void showTranslatedStatusText(const char *str);
        inline void clearStatusText() { m_statustext.clear(); }
 
+       bool isChatVisible()
+       {
+               return m_flags.show_chat && m_recent_chat_count != 0 && m_profiler_current_page == 0;
+       }
        void setChatText(const EnrichedString &chat_text, u32 recent_chat_count);
+       void updateChatSize();
 
        void updateProfiler();
 
        void toggleChat();
+       void toggleCheatMenu();
        void toggleHud();
        void toggleProfiler();
 
+       GUIFormSpecMenu *&updateFormspec(const std::string &formname)
+       {
+               m_formname = formname;
+               return m_formspec;
+       }
+
+       const std::string &getFormspecName() { return m_formname; }
+       GUIFormSpecMenu *&getFormspecGUI() { return m_formspec; }
+       void deleteFormspec();
+
 private:
        Flags m_flags;
 
+       float m_drawtime_avg = 0;
+
        gui::IGUIStaticText *m_guitext = nullptr;  // First line of debug text
        gui::IGUIStaticText *m_guitext2 = nullptr; // Second line of debug text
-
+       gui::IGUIStaticText *m_guitext_coords = nullptr;
+       
        gui::IGUIStaticText *m_guitext_info = nullptr; // At the middle of the screen
        std::wstring m_infotext;
 
        gui::IGUIStaticText *m_guitext_status = nullptr;
        std::wstring m_statustext;
        float m_statustext_time = 0.0f;
+       video::SColor m_statustext_initial_color;
 
-       gui::IGUIStaticText *m_guitext_chat; // Chat text
+       gui::IGUIStaticText *m_guitext_chat = nullptr; // Chat text
+       u32 m_recent_chat_count = 0;
+       core::rect<s32> m_current_chat_size{0, 0, 0, 0};
 
-       gui::IGUIStaticText *m_guitext_profiler; // Profiler text
+       gui::IGUIStaticText *m_guitext_profiler = nullptr; // Profiler text
        u8 m_profiler_current_page = 0;
        const u8 m_profiler_max_page = 3;
+
+       // Default: "". If other than "": Empty show_formspec packets will only
+       // close the formspec when the formname matches
+       std::string m_formname;
+       GUIFormSpecMenu *m_formspec = nullptr;
 };