Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/menu/src/libraries/core/GUIManager.h @ 6130

Last change on this file since 6130 was 6048, checked in by scheusso, 15 years ago

ESC handling in ingame menu: if theres already an opened GUI sheet then hide it, if not open the ingame menu
in mainmenu everything should remain the same

  • Property svn:eol-style set to native
File size: 5.0 KB
Line 
1/*
2 *   ORXONOX - the hottest 3D action shooter ever to exist
3 *                    > www.orxonox.net <
4 *
5 *
6 *   License notice:
7 *
8 *   This program is free software; you can redistribute it and/or
9 *   modify it under the terms of the GNU General Public License
10 *   as published by the Free Software Foundation; either version 2
11 *   of the License, or (at your option) any later version.
12 *
13 *   This program is distributed in the hope that it will be useful,
14 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
15 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 *   GNU General Public License for more details.
17 *
18 *   You should have received a copy of the GNU General Public License
19 *   along with this program; if not, write to the Free Software
20 *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
21 *
22 *   Author:
23 *      Reto Grieder
24 *      Benjamin Knecht
25 *   Co-authors:
26 *      ...
27 *
28 */
29
30#ifndef _GUIManager_H__
31#define _GUIManager_H__
32
33#include "CorePrereqs.h"
34
35#include <map>
36#include <set>
37#include <string>
38#include <CEGUIForwardRefs.h>
39#include <boost/scoped_ptr.hpp>
40#include <boost/shared_ptr.hpp>
41
42#include "util/OgreForwardRefs.h"
43#include "util/Singleton.h"
44#include "input/InputHandler.h"
45
46namespace orxonox
47{
48    class PlayerInfo; // Forward declaration
49
50    /**
51    @class GUIManager
52    @brief
53        Provides a simple interface to CEGUI with tolua methods and console commands. It also acts as a key and mouse handler.
54
55        The GUIManager is a singleton and can be called anywhere when access on the GUI is needed.
56        Creation of the GUIManager is therefore not possible and the cunstructor is private.
57
58        Since the GUI needs user input, the GUIManager implements the functions needed to act as a key and/or mouse handler.
59        Those input events are then injected into CEGUI in Lua.
60    */
61    class _CoreExport GUIManager : public Singleton<GUIManager>, public InputHandler
62    {
63        friend class Singleton<GUIManager>;
64    public:
65        GUIManager(Ogre::RenderWindow* renderWindow, const std::pair<int, int>& mousePosition, bool bFullScreen);
66        ~GUIManager();
67
68        void update(const Clock& time); 
69
70        static void showGUI(const std::string& name, bool hidePrevious=false, bool showCursor=true);
71        void showGUIExtra(const std::string& name, const std::string& ptr, bool hidePrevious=false, bool showCursor=true);
72        static void hideGUI(const std::string& name);
73        void toggleIngameGUI();
74        void keyESC();
75        void setBackground(const std::string& name);
76
77        void setCamera(Ogre::Camera* camera);
78        Ogre::Camera* getCamera() { return this->camera_; }
79
80        static GUIManager* getInstancePtr() { return singletonPtr_s; }
81
82        inline void setPlayer(const std::string& guiname, PlayerInfo* player)
83            { this->players_[guiname] = player; }
84        inline PlayerInfo* getPlayer(const std::string& guiname) const
85            { std::map<std::string, PlayerInfo*>::const_iterator it = this->players_.find(guiname); return (it != this->players_.end()) ? it->second : 0; }
86
87    private:
88        GUIManager(const GUIManager& instance); //!< private and undefined copy c'tor (this is a singleton class)
89
90        std::set<std::string> showingGUIs_; //!< Keeps track of all the GUIs that are currently showing.
91
92        void executeCode(const std::string& str);
93
94        // keyHandler functions
95        void keyPressed (const KeyEvent& evt);
96        void keyReleased(const KeyEvent& evt);
97
98        // mouseHandler functions
99        void buttonPressed (MouseButtonCode::ByEnum id);
100        void buttonReleased(MouseButtonCode::ByEnum id);
101        void mouseMoved    (IntVector2 abs, IntVector2 rel, IntVector2 clippingSize);
102        void mouseScrolled (int abs, int rel);
103
104        scoped_ptr<CEGUI::OgreCEGUIRenderer> guiRenderer_;      //!< CEGUI's interface to the Ogre Engine
105        scoped_ptr<LuaState>                 luaState_;         //!< LuaState, access point to the Lua engine
106        scoped_ptr<CEGUI::LuaScriptModule>   scriptModule_;     //!< CEGUI's script module to use Lua
107        scoped_ptr<CEGUI::System>            guiSystem_;        //!< CEGUI's main system
108        shared_ptr<ResourceInfo>             rootFileInfo_;     //!< Resource information about the root script
109        Ogre::RenderWindow*                  renderWindow_;     //!< Ogre's render window to give CEGUI access to it
110        CEGUI::ResourceProvider*             resourceProvider_; //!< CEGUI's resource provider
111        CEGUI::Logger*                       ceguiLogger_;      //!< CEGUI's logger to be able to log CEGUI errors in our log
112        std::map<std::string, PlayerInfo*>   players_;          //!< Stores the player (owner) for each gui
113        Ogre::Camera*                        camera_;           //!< Camera used to render the scene with the GUI
114
115        static GUIManager*                   singletonPtr_s;    //!< Singleton reference to GUIManager
116        bool                                 bShowIngameGUI_;
117
118    };
119}
120
121#endif /* _GUIManager_H__ */
Note: See TracBrowser for help on using the repository browser.