]> git.lizzy.rs Git - minetest.git/blobdiff - src/modalMenu.h
Add clouds API
[minetest.git] / src / modalMenu.h
index 62bfabc06b7c9818bc4b6538b3d1db253c58631c..38a26535e4ffe752d876910971ba69aeef8c441c 100644 (file)
@@ -21,6 +21,9 @@ with this program; if not, write to the Free Software Foundation, Inc.,
 #define MODALMENU_HEADER
 
 #include "irrlichttypes_extrabloated.h"
+#ifdef HAVE_TOUCHSCREENGUI
+#include "touchscreengui.h"
+#endif
 
 class GUIModalMenu;
 
@@ -28,8 +31,8 @@ class IMenuManager
 {
 public:
        // A GUIModalMenu calls these when this class is passed as a parameter
-       virtual void createdMenu(GUIModalMenu *menu) = 0;
-       virtual void deletingMenu(GUIModalMenu *menu) = 0;
+       virtual void createdMenu(gui::IGUIElement *menu) = 0;
+       virtual void deletingMenu(gui::IGUIElement *menu) = 0;
 };
 
 /*
@@ -40,14 +43,13 @@ class IMenuManager
 class GUIModalMenu : public gui::IGUIElement
 {
 public:
-       GUIModalMenu(gui::IGUIEnvironment* env,
-                       gui::IGUIElement* parent, s32 id,
+       GUIModalMenu(gui::IGUIEnvironment* env, gui::IGUIElement* parent, s32 id,
                        IMenuManager *menumgr):
                IGUIElement(gui::EGUIET_ELEMENT, env, parent, id,
                                core::rect<s32>(0,0,100,100))
        {
                //m_force_regenerate_gui = false;
-               
+
                m_menumgr = menumgr;
                m_allow_focus_removal = false;
                m_screensize_old = v2u32(0,0);
@@ -56,6 +58,7 @@ class GUIModalMenu : public gui::IGUIElement
                Environment->setFocus(this);
                m_menumgr->createdMenu(this);
        }
+
        virtual ~GUIModalMenu()
        {
                m_menumgr->deletingMenu(this);
@@ -75,7 +78,7 @@ class GUIModalMenu : public gui::IGUIElement
        {
                if(!IsVisible)
                        return;
-                       
+
                video::IVideoDriver* driver = Environment->getVideoDriver();
                v2u32 screensize = driver->getScreenSize();
                if(screensize != m_screensize_old /*|| m_force_regenerate_gui*/)
@@ -87,12 +90,14 @@ class GUIModalMenu : public gui::IGUIElement
 
                drawMenu();
        }
-       
+
        /*
                This should be called when the menu wants to quit.
 
                WARNING: THIS DEALLOCATES THE MENU FROM MEMORY. Return
                immediately if you call this from the menu itself.
+
+               (More precisely, this decrements the reference count.)
        */
        void quitMenu()
        {
@@ -101,6 +106,10 @@ class GUIModalMenu : public gui::IGUIElement
                Environment->removeFocus(this);
                m_menumgr->deletingMenu(this);
                this->remove();
+#ifdef HAVE_TOUCHSCREENGUI
+               if (g_touchscreengui)
+                       g_touchscreengui->show();
+#endif
        }
 
        void removeChildren()
@@ -122,7 +131,9 @@ class GUIModalMenu : public gui::IGUIElement
 
        virtual void regenerateGui(v2u32 screensize) = 0;
        virtual void drawMenu() = 0;
+       virtual bool preprocessEvent(const SEvent& event) { return false; };
        virtual bool OnEvent(const SEvent& event) { return false; };
+       virtual bool pausesGame(){ return false; } // Used for pause menu
 
 protected:
        //bool m_force_regenerate_gui;