1 | /* |
---|
2 | orxonox - the future of 3D-vertical-scrollers |
---|
3 | |
---|
4 | Copyright (C) 2004 orx |
---|
5 | |
---|
6 | This program is free software; you can redistribute it and/or modify |
---|
7 | it under the terms of the GNU General Public License as published by |
---|
8 | the Free Software Foundation; either version 2, or (at your option) |
---|
9 | any later version. |
---|
10 | |
---|
11 | This program 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 General Public License for more details. |
---|
15 | |
---|
16 | You should have received a copy of the GNU General Public License |
---|
17 | along with this program; if not, write to the Free Software Foundation, |
---|
18 | Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
---|
19 | |
---|
20 | |
---|
21 | ### File Specific: |
---|
22 | main-programmer: Benjamin Grauer |
---|
23 | |
---|
24 | */ |
---|
25 | |
---|
26 | #include "gui_flags.h" |
---|
27 | |
---|
28 | /** |
---|
29 | \brief Creates the Flags-Frame |
---|
30 | */ |
---|
31 | GuiFlags::GuiFlags(void) |
---|
32 | { |
---|
33 | this->flagsFrame = new Frame("Orxonox-Startup-Flags:"); |
---|
34 | this->flagsBox = new Box('v'); |
---|
35 | |
---|
36 | this->flagsLabel = new Label(); |
---|
37 | this->flagsLabel->setSize(260,60); |
---|
38 | this->flagsBox->fill(flagsLabel); |
---|
39 | this->shortFlags = new CheckButton("shortFlags"); |
---|
40 | this->shortFlags->setDefaultValue(0); |
---|
41 | this->flagsBox->fill(shortFlags); |
---|
42 | |
---|
43 | this->flagsFrame->fill(flagsBox); |
---|
44 | this->setMainWidget(flagsFrame); |
---|
45 | } |
---|
46 | |
---|
47 | /** |
---|
48 | \brief Destructs the Flags-stuff |
---|
49 | */ |
---|
50 | GuiFlags::~GuiFlags(void) |
---|
51 | { |
---|
52 | // nothing to do here |
---|
53 | } |
---|
54 | |
---|
55 | /** |
---|
56 | \brief Sets the Flags from widget downwards. |
---|
57 | \param widget the Widget from which on to scan for deeper Options and their settings. |
---|
58 | */ |
---|
59 | void GuiFlags::setTextFromFlags(Widget* widget) |
---|
60 | { |
---|
61 | FlagInfo flagInfo; |
---|
62 | flagInfo.shortFlags = this->shortFlags; |
---|
63 | flagInfo.flagsLabel = this->flagsLabel; |
---|
64 | |
---|
65 | this->flagsLabel->ereaseText(); |
---|
66 | this->flagsLabel->appendText(executable); |
---|
67 | widget->walkThrough(GuiFlags::flagsText, &flagInfo, 0); |
---|
68 | // flagsLabel->setTitle(flagText); |
---|
69 | } |
---|
70 | |
---|
71 | /** |
---|
72 | \brief this actually sets the flagtext, and appends it to flagText |
---|
73 | \param widget like GuiFlags::setTextFromFlags(widget) |
---|
74 | \param flagInfo Information aboout the Flag that should be updated. |
---|
75 | */ |
---|
76 | void GuiFlags::flagsText(Widget* widget, void* flagInfo) |
---|
77 | { |
---|
78 | FlagInfo* info =(FlagInfo*)flagInfo; |
---|
79 | if(widget->optionType > GUI_NOTHING) |
---|
80 | if (static_cast<Option*>(widget)->value != static_cast<Option*>(widget)->defaultValue ) |
---|
81 | { |
---|
82 | if(info->shortFlags->isActive() && static_cast<Option*>(widget)->flagNameShort) |
---|
83 | { |
---|
84 | info->flagsLabel->appendText(" -"); |
---|
85 | info->flagsLabel->appendText(static_cast<Option*>(widget)->flagNameShort); |
---|
86 | } |
---|
87 | else if(!info->shortFlags->isActive() && static_cast<Option*>(widget)->flagName) |
---|
88 | { |
---|
89 | info->flagsLabel->appendText(" --"); |
---|
90 | info->flagsLabel->appendText(static_cast<Option*>(widget)->flagName); |
---|
91 | } |
---|
92 | |
---|
93 | if(static_cast<Option*>(widget)->optionType > GUI_BOOL) |
---|
94 | { |
---|
95 | info->flagsLabel->appendText("="); |
---|
96 | info->flagsLabel->appendInt(static_cast<Option*>(widget)->value); |
---|
97 | } |
---|
98 | } |
---|
99 | } |
---|