X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;f=src%2FguiMainMenu.h;h=4b73dcb9d87b5eb7ce6fd711de02af0bcbe03feb;hb=18350ad37fbfb7027f2ab82ead5be58c1435cdf0;hp=87608822b41709bb04623478564fa89d65a0ae0f;hpb=a72dc388c37eb3ba466214ea988fa5e761c1d36d;p=minetest.git diff --git a/src/guiMainMenu.h b/src/guiMainMenu.h index 87608822b..4b73dcb9d 100644 --- a/src/guiMainMenu.h +++ b/src/guiMainMenu.h @@ -1,6 +1,6 @@ /* Minetest-c55 -Copyright (C) 2010 celeron55, Perttu Ahola +Copyright (C) 2010-2012 celeron55, Perttu Ahola This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -22,46 +22,16 @@ with this program; if not, write to the Free Software Foundation, Inc., #include "common_irrlicht.h" #include "modalMenu.h" -#include "utility.h" #include -// For IGameCallback -#include "guiPauseMenu.h" #include - -enum -{ - GUI_ID_QUIT_BUTTON = 101, - GUI_ID_NAME_INPUT, - GUI_ID_ADDRESS_INPUT, - GUI_ID_PORT_INPUT, - GUI_ID_FANCYTREE_CB, - GUI_ID_SMOOTH_LIGHTING_CB, - GUI_ID_3D_CLOUDS_CB, - GUI_ID_OPAQUE_WATER_CB, - GUI_ID_DAMAGE_CB, - GUI_ID_CREATIVE_CB, - GUI_ID_JOIN_GAME_BUTTON, - GUI_ID_CHANGE_KEYS_BUTTON, - GUI_ID_DELETE_WORLD_BUTTON, - GUI_ID_WORLD_LISTBOX, -}; +#include "subgame.h" +class IGameCallback; struct MainMenuData { - MainMenuData(): - // Client opts - fancy_trees(false), - smooth_lighting(false), - // Server opts - creative_mode(false), - enable_damage(false), - selected_world(0), - // Actions - delete_world(false) - {} - // These are in the native format of the gui elements - + // Generic + int selected_tab; // Client options std::wstring address; std::wstring port; @@ -75,10 +45,29 @@ struct MainMenuData bool creative_mode; bool enable_damage; int selected_world; - // If map deletion is requested, this is set to true - bool delete_world; + bool simple_singleplayer_mode; + // Actions + std::wstring create_world_name; + std::string create_world_gameid; + bool only_refresh; + + std::vector worlds; + std::vector games; - std::list worlds; + MainMenuData(): + // Generic + selected_tab(0), + // Client opts + fancy_trees(false), + smooth_lighting(false), + // Server opts + creative_mode(false), + enable_damage(false), + selected_world(0), + simple_singleplayer_mode(false), + // Actions + only_refresh(false) + {} }; class GUIMainMenu : public GUIModalMenu @@ -92,21 +81,17 @@ class GUIMainMenu : public GUIModalMenu ~GUIMainMenu(); void removeChildren(); - /* - Remove and re-add (or reposition) stuff - */ + // Remove and re-add (or reposition) stuff void regenerateGui(v2u32 screensize); - void drawMenu(); - + void readInput(MainMenuData *dst); void acceptInput(); - bool getStatus() - { - return m_accepted; - } - + { return m_accepted; } bool OnEvent(const SEvent& event); + void createNewWorld(std::wstring name, std::string gameid); + void deleteWorld(const std::vector &paths); + int getTab(); private: MainMenuData *m_data; @@ -117,6 +102,12 @@ class GUIMainMenu : public GUIModalMenu gui::IGUIElement* parent; s32 id; IMenuManager *menumgr; + + bool m_is_regenerating; + v2s32 m_topleft_client; + v2s32 m_size_client; + v2s32 m_topleft_server; + v2s32 m_size_server; }; #endif