i6engine  1.0
GUIController.h
Go to the documentation of this file.
1 /*
2  * i6engine
3  * Copyright (2016) Daniel Bonrath, Michael Baer, All rights reserved.
4  *
5  * This file is part of i6engine; i6engine is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU Lesser General Public
7  * License as published by the Free Software Foundation; either
8  * version 2.1 of the License, or (at your option) any later version.
9  *
10  * This library is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13  * Lesser General Public License for more details.
14  *
15  * You should have received a copy of the GNU Lesser General Public
16  * License along with this library; if not, write to the Free Software
17  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
18  */
19 
25 #ifndef __I6ENGINE_MODULES_GUICONTROLLER_H__
26 #define __I6ENGINE_MODULES_GUICONTROLLER_H__
27 
29 
31 
32 namespace i6e {
33 namespace modules {
34 
35  class GraphicsManager;
36  class GUIMailbox;
37  class GUIManager;
38 
45  friend class GraphicsManager;
46 
47  public:
51  GUIController();
52 
57 
58  private:
59  GUIManager * _manager;
60  GUIMailbox * _mailbox;
61 
70  void OnThreadStart() override;
71 
79  void ShutDown() override;
80 
86  void Tick() override;
87 
91  GUIController(const GUIController &) = delete;
92 
96  const GUIController & operator=(const GUIController &) = delete;
97 
99  };
100 
101 } /* namespace modules */
102 } /* namespace i6e */
103 
104 #endif /* __I6ENGINE_MODULES_GUICONTROLLER_H__ */
105 
Extracts the contents of incoming messages on the "Gui" channel and calls the corresponding methods o...
Definition: GUIMailbox.h:45
Responsible for initializing and updating the gui.
Definition: GUIController.h:44
Part of the Subsystem that keeps the whole module running.
#define ASSERT_THREAD_SAFETY_HEADER
This class interacts with CEGUI. It's methods are executed in the OGRE / CEGUI thread.
Definition: GUIManager.h:77