Neo  0.5.0
Developer Documentation
CheckButton.h
Go to the documentation of this file.
1 /*
2  * Copyright 2014 (C) Yannick Pflanzer <neo-engine.de>
3  *
4  * This file is part of Neo2D.
5  *
6  * Neo2D is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU Lesser General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * Neo2D is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public License
17  * along with Neo2D. If not, see <http://www.gnu.org/licenses/>.
18  *
19  * Diese Datei ist Teil von Neo2D.
20  *
21  * Neo2D ist Freie Software: Sie können es unter den Bedingungen
22  * der GNU Lesser General Public License, wie von der Free Software Foundation,
23  * Version 3 der Lizenz oder (nach Ihrer Wahl) jeder späteren
24  * veröffentlichten Version, weiterverbreiten und/oder modifizieren.
25  *
26  * Neo2D wird in der Hoffnung, dass es nützlich sein wird, aber
27  * OHNE JEDE GEWÄHRLEISTUNG, bereitgestellt; sogar ohne die implizite
28  * Gewährleistung der MARKTFÄHIGKEIT oder EIGNUNG FÜR EINEN BESTIMMTEN ZWECK.
29  * Siehe die GNU Lesser General Public License für weitere Details.
30  *
31  * Sie sollten eine Kopie der GNU Lesser General Public License zusammen mit
32  * diesem
33  * Programm erhalten haben. Wenn nicht, siehe <http://www.gnu.org/licenses/>.
34  */
35 
36 #ifndef __CHECKBUTTON_H__
37 #define __CHECKBUTTON_H__
38 
39 #include <NeoEngine.h>
40 #include <Widget.h>
41 #include <Button.h>
42 #include <Label.h>
43 
44 namespace Neo2D
45 {
46 namespace Gui
47 {
48 
49 using namespace Neo;
50 
55 {
62 };
63 
69 class NEO2D_EXPORT CheckButton : public Widget
70 {
71 protected:
74 
75  bool m_value;
76 
77  static void buttonCallback(Widget* w, long int data);
78 
79 public:
80  CheckButton(unsigned int x, unsigned int y, unsigned int size, const char* label);
81 
82  void setValue(bool v)
83  {
84  if(v) m_button.setLabel("x");
85  else m_button.setLabel("");
86 
87  m_value = v;
88  }
89 
90  bool getValue() { return m_value; }
91 
92  void setLabel(const char* label) { m_label.setLabel(label); }
93  const char* getLabel() { return m_label.getLabel(); }
94 
95  void draw(Vector2 offset);
96  void update();
97 };
98 }
99 }
100 #endif
void setLabel(const char *label)
Definition: CheckButton.h:92
CHECKBUTTON_STATE
Definition: CheckButton.h:54
Implements a simple check button that calls the specified callback and represents a boolean state...
Definition: CheckButton.h:69
Button m_button
Definition: CheckButton.h:72
bool getValue()
Definition: CheckButton.h:90
The Label class displays a string on the screen.
Definition: Label.h:55
The Widget class contains all information that is common to all GUI widgets.
Definition: Widget.h:72
bool m_value
Definition: CheckButton.h:75
void setLabel(const char *l)
Changes the current label of the widget.
Definition: Widget.h:228
void setValue(bool v)
Definition: CheckButton.h:82
Implements a simple pushable button that calls the specified callback.
Definition: Button.h:67
If the button is neither selected nor pressed.
Definition: CheckButton.h:57
Definition: Vector2.h:31
Definition: Button.h:42
If the mouse is hovering over the button and the left mouse button is pressed.
Definition: CheckButton.h:61
const char * getLabel()
Definition: CheckButton.h:93
If the button has the mouse cursor over it.
Definition: CheckButton.h:59
const char * getLabel()
Gets the currently displayed label a C string.
Definition: Widget.h:222
Definition: Color.h:29
Label m_label
Definition: CheckButton.h:73