Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/tutoriallevel3/src/modules/notifications/NotificationQueueCEGUI.h @ 8703

Last change on this file since 8703 was 8636, checked in by dafrick, 14 years ago

Making NotificationQueue XML-loadable. Adding notifications to all levels.

File size: 6.5 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 *      Damian 'Mozork' Frick
24 *   Co-authors:
25 *      ...
26 *
27 */
28
29/**
30    @file NotificationQueueCEGUI.h
31    @brief Definition of the NotificationQueueCEGUI class.
32    @ingroup Notifications
33*/
34
35#ifndef _NotificationOueueCEGUI_H__
36#define _NotificationOueueCEGUI_H__
37
38#include "notifications/NotificationsPrereqs.h"
39
40#include <string>
41#include "util/Math.h"
42
43#include "NotificationManager.h"
44
45#include "NotificationQueue.h"
46
47namespace orxonox // tolua_export
48{ // tolua_export
49
50    /**
51    @brief
52        Displays @ref orxonox::Notification "Notifications" using CEGUI.
53
54        Apart form the parameters inherited by the @ref orxonox::NotificationQueue "NotificationQueue", there are some more parameters that influence the behavior of the NotificationQueueCEGUI:
55        - @b displaySize The size of the window that displays the NotificationQueue.
56        - @b position The position if the window that displays the NotificationQueue.
57        - @b alignment The horizontal alignment of the displayed Notifications.
58        - @b fontSize The font size of the displayed Notifications.
59        - @b fontColor The font color of the displayed Notifications.
60
61    @author
62        Damian 'Mozork' Frick
63
64    @see NotificationQueue
65    @ingroup Notifications
66    */
67    class _NotificationsExport NotificationQueueCEGUI // tolua_export
68        : public NotificationQueue
69    { // tolua_export
70
71        public:
72            NotificationQueueCEGUI(BaseObject* creator);
73            virtual ~NotificationQueueCEGUI();
74
75            virtual void XMLPort(Element& xmlelement, XMLPort::Mode mode);
76
77            void destroy(bool noGraphics = false); // Destroys the NotificationQueue.
78
79            void setDisplaySize(const Vector4& size); // Set the size of the window that displays the NotificationQueue.
80           
81            /**
82            @brief Get the size of the window that displays the NotificationQueue.
83            @return Returns a vector with the display size.
84            */
85            inline const Vector4& getDisplaySize(void) const
86                { return this->displaySize_; }
87
88            void setPosition(const Vector4& position); // Set the position of the window that displays the NotificationQueue.
89            /**
90            @brief Get the position of the window that displays the NotificationQueue.
91            @return Returns a vector with the position.
92            */
93            inline const Vector4& getPosition(void) const
94                { return this->position_; }
95
96            void setAlignment(const std::string& alignment); // Set the horizontal alignment of the Notifications text.
97            /**
98            @brief Get the horizontal alignment of the Notifications text.
99            @return Returns a string with the horizontal alignment property.
100            */
101            inline const std::string& getAlignment(void)
102                { return this->alignment_; }
103
104            void setFontSize(unsigned int size); // Set the font size of the text displayed by this NotificationQueue.
105            /**
106            @brief Get the font size of the text displayed by this NotificationQueue.
107            @return Returns the font size.
108            */
109            inline unsigned int getFontSize(void)
110                { return this->fontSize_; }
111
112            void setFontColor(const Vector4& color); // Set the font color if the text displayed by this NotificationQueue.
113            /**
114            @brief Get the font color of the text displayed by this NotificationQueue.
115            @return Returns a vector with the components being RGBA, with values from 0 to 1.
116            */
117            inline const Vector4& getFontColor(void) const
118                { return this->fontColor_; }
119            /**
120            @brief Get the font color of the text displayed by this NotificationQueue.
121            @return Returns a string with the ARGB values in hexadecimal format.
122            */
123            inline const std::string& getFontColorStr(void) const
124                { return this->fontColorStr_; }
125
126            static NotificationQueueCEGUI* getQueue(const std::string& name); // tolua_export // Get the NotificationQueueCEGUI with the input name.
127           
128        protected:
129            virtual void create(void); // Creates the NotificationQueue in lua.
130           
131            virtual void notificationPushed(Notification* notification); // Is called by the NotificationQueue when a notification was pushed
132            virtual void notificationPopped(void); // Is called by the NotificationQueue when a notification was popped.
133            virtual void notificationRemoved(unsigned int index); // Is called when a notification was removed.
134           
135            virtual void clear(bool noGraphics = false); // Clears the NotificationQueue by removing all NotificationContainers.
136
137        protected:
138            static const std::string NOTIFICATION_LAYER; //!< The name of the NotificationLayer menu sheet.
139           
140        private:
141            Vector4 displaySize_; //!< The size of the window that displays the NotificationQueue.
142            Vector4 position_; //!< The position of the window that displays the NotificationQueue.
143            std::string alignment_; //!< The horizontal alignment of the Notifications text.
144            unsigned int fontSize_; //!< The font size of the Notifications text.
145            Vector4 fontColor_; //!< The font color of the Notifications text as a vector, in RGBA form, with values from 0 to 1.
146            std::string fontColorStr_; //!< The font color of the Notifications text as a string with the ARGB hexadecimal values.
147
148            void initialize(void); // Initializes The NotificationQueueCEGUI.
149
150    }; // tolua_export
151
152} // tolua_export
153
154#endif /* _NotificationQueueCEGUI_H__ */
Note: See TracBrowser for help on using the repository browser.