Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/trunk/src/libraries/core/GUIManager.h @ 8144

Last change on this file since 8144 was 8079, checked in by landauf, 14 years ago

merged usability branch back to trunk

incomplete summary of the changes in this branch:

  • enhanced keyboard navigation in GUIs
  • implemented new graphics menu and changeable window size at runtime
  • added developer mode
  • HUD shows if game is paused, game pauses if ingame menu is opened
  • removed a few obsolete commands and hid some that are more for internal use
  • numpad works in console and gui
  • faster loading of level info
  • enhanced usage of compositors (Shader class)
  • improved camera handling, configurable FOV and aspect ratio
  • Property svn:eol-style set to native
File size: 7.5 KB
RevLine 
[1638]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
[3196]24 *      Benjamin Knecht
[1638]25 *   Co-authors:
[3196]26 *      ...
[1638]27 *
28 */
29
[7401]30/**
31    @file
32    @ingroup Graphics
33*/
34
[1638]35#ifndef _GUIManager_H__
36#define _GUIManager_H__
37
[3346]38#include "CorePrereqs.h"
[3196]39
40#include <map>
[6417]41#include <set>
[3196]42#include <string>
[1638]43#include <CEGUIForwardRefs.h>
[3338]44#include <boost/scoped_ptr.hpp>
[5695]45#include <boost/shared_ptr.hpp>
[3196]46
47#include "util/OgreForwardRefs.h"
[6746]48#include "util/TriBool.h"
[3366]49#include "util/Singleton.h"
[3346]50#include "input/InputHandler.h"
[8079]51#include "Core.h"
[7801]52#include "OrxonoxClass.h"
[7873]53#include "WindowEventListener.h"
[1638]54
[6746]55// Tolua includes (have to be relative to the current directory)
56/*
57$cfile "../util/TriBool.h" // tolua_export
58*/
59
[6417]60namespace orxonox // tolua_export
61{ // tolua_export
[5693]62    class PlayerInfo; // Forward declaration
63
[1638]64    /**
[2896]65    @class GUIManager
[1638]66    @brief
[2896]67        Provides a simple interface to CEGUI with tolua methods and console commands. It also acts as a key and mouse handler.
68
69        The GUIManager is a singleton and can be called anywhere when access on the GUI is needed.
70
71        Since the GUI needs user input, the GUIManager implements the functions needed to act as a key and/or mouse handler.
72        Those input events are then injected into CEGUI in Lua.
[1638]73    */
[6417]74    class _CoreExport GUIManager // tolua_export
[7873]75        : public Singleton<GUIManager>, public InputHandler, public WindowEventListener
[6417]76    { // tolua_export
[3366]77        friend class Singleton<GUIManager>;
[1638]78    public:
[6746]79        GUIManager(const std::pair<int, int>& mousePosition);
[1646]80        ~GUIManager();
81
[7801]82        void setConfigValues(void);
83        void changedGUIScheme(void);
84
[6417]85        void preUpdate(const Clock& time);
[1640]86
[6746]87        void loadGUI(const std::string& name);
[7403]88        static void showGUI(const std::string& name, bool bHidePrevious = false, bool bNoInput = false);
89        void showGUIExtra(const std::string& name, const std::string& ptr, bool bHidePrevious = false, bool bNoInput = false);
[6417]90        static void hideGUI(const std::string& name);
[8079]91        static void toggleGUI(const std::string& name, bool bHidePrevious = false, bool bNoInput = false);
92        void toggleGUIHelper(const std::string& name, bool bHidePrevious, bool bNoInput, bool show); // tolua_export
[6417]93        void keyESC();
[6746]94        void setBackgroundImage(const std::string& imageSet, const std::string imageName); // tolua_export
95        void setBackgroundImage(const std::string& image);
[1638]96
[8079]97        /**
98        @brief Helper method to get the developer's mode without having to export Core.h.
99        @see Core::inDevMode
100        */
101        static bool inDevMode(void) { return Core::getInstance().inDevMode(); } // tolua_export
102
[6746]103        //! Creates a new InputState to be used with a GUI Sheet
104        const std::string& createInputState(const std::string& name, TriBool::Value showCursor = TriBool::True, TriBool::Value useKeyboard = TriBool::True, bool bBlockJoyStick = false); // tolua_export
[7163]105        LuaState* getLuaState(void)
106            { return this->luaState_.get(); }
[6746]107
108        //! Returns the root window for all menu sheets
109        CEGUI::Window* getMenuRootWindow() { return this->menuRootWindow_; } // tolua_export
110        //! Returns the root window for all HUD sheets
111        CEGUI::Window* getHUDRootWindow() { return this->hudRootWindow_; } // tolua_export
112
[2896]113        void setCamera(Ogre::Camera* camera);
[5929]114        Ogre::Camera* getCamera() { return this->camera_; }
[2896]115
[5693]116        inline void setPlayer(const std::string& guiname, PlayerInfo* player)
117            { this->players_[guiname] = player; }
[7163]118        inline orxonox::PlayerInfo* getPlayer(const std::string& guiname) const { std::map<std::string, PlayerInfo*>::const_iterator it = this->players_.find(guiname); return (it != this->players_.end()) ? it->second : 0; } // tolua_export
[5693]119
[6417]120        // TODO: Temporary hack because the tolua exported CEGUI method does not seem to work
121        static void subscribeEventHelper(CEGUI::Window* window, const std::string& event, const std::string& function); //tolua_export
[7648]122        static void setTooltipTextHelper(CEGUI::ListboxItem* item, const std::string& toooltip); //tolua_export
123        static void setItemTooltipsEnabledHelper(CEGUI::Listbox* listbox, bool enabled); //tolua_export
[6417]124
[6746]125        static GUIManager& getInstance() { return Singleton<GUIManager>::getInstance(); } // tolua_export
126
[1638]127    private:
[3339]128        GUIManager(const GUIManager& instance); //!< private and undefined copy c'tor (this is a singleton class)
[7163]129        void executeCode(const std::string& str);
[1638]130
[6746]131        template <typename FunctionType>
132        bool protectedCall(FunctionType function);
133
[2896]134        // keyHandler functions
[7163]135        void buttonPressed (const KeyEvent& evt);
136        void buttonReleased(const KeyEvent& evt);
[1638]137
[2896]138        // mouseHandler functions
[3327]139        void buttonPressed (MouseButtonCode::ByEnum id);
140        void buttonReleased(MouseButtonCode::ByEnum id);
141        void mouseMoved    (IntVector2 abs, IntVector2 rel, IntVector2 clippingSize);
142        void mouseScrolled (int abs, int rel);
[7874]143        void mouseLeft     ();
[6749]144
[7873]145        // window event handler
146        virtual void windowResized(unsigned int newWidth, unsigned int newHeight);
[7874]147        virtual void windowFocusChanged(bool bFocus);
[7873]148
[5695]149        scoped_ptr<CEGUI::OgreCEGUIRenderer> guiRenderer_;      //!< CEGUI's interface to the Ogre Engine
150        scoped_ptr<LuaState>                 luaState_;         //!< LuaState, access point to the Lua engine
151        scoped_ptr<CEGUI::LuaScriptModule>   scriptModule_;     //!< CEGUI's script module to use Lua
152        scoped_ptr<CEGUI::System>            guiSystem_;        //!< CEGUI's main system
153        shared_ptr<ResourceInfo>             rootFileInfo_;     //!< Resource information about the root script
154        CEGUI::ResourceProvider*             resourceProvider_; //!< CEGUI's resource provider
155        CEGUI::Logger*                       ceguiLogger_;      //!< CEGUI's logger to be able to log CEGUI errors in our log
[6746]156        CEGUI::Window*                       rootWindow_;       //!< Root node for all windows
157        CEGUI::Window*                       hudRootWindow_;    //!< Root node for the HUD sheets
158        CEGUI::Window*                       menuRootWindow_;   //!< Root node for the menu sheets (used by Lua)
159        std::map<std::string, PlayerInfo*>   players_;          //!< Stores the player (owner) for each GUI
[5929]160        Ogre::Camera*                        camera_;           //!< Camera used to render the scene with the GUI
[1638]161
[5695]162        static GUIManager*                   singletonPtr_s;    //!< Singleton reference to GUIManager
[1638]163
[7801]164        // The used CEGUI scheme.
165        static const std::string defaultScheme_;
166        std::string guiScheme_;
167
[6417]168    }; // tolua_export
169} // tolua_export
[1638]170
171#endif /* _GUIManager_H__ */
Note: See TracBrowser for help on using the repository browser.