Orxonox  0.0.5 Codename: Arcturus
Button.h
Go to the documentation of this file.
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
24  * Co-authors:
25  * ...
26  *
27  */
28 
35 #ifndef _Button_H__
36 #define _Button_H__
37 
38 #include "InputPrereqs.h"
39 
40 #include <string>
41 #include <vector>
42 #include "InputCommands.h"
43 
44 namespace orxonox
45 {
47  {
48  public:
49  Button();
50  virtual ~Button();
51  virtual void clear();
52  virtual bool addParamCommand(ParamCommand* command) { return false; }
53  void parse(const std::string& binding);
54  void readBinding(ConfigFile* configFile, ConfigFile* fallbackFile);
55  void setBinding(ConfigFile* configFile, ConfigFile* fallbackFile, const std::string& binding, bool bTemporary);
56  bool execute(KeybindMode::Value mode, float abs = 1.0f, float rel = 1.0f);
57 
65  BaseCommand** commands_[3];
67  unsigned int nCommands_[3];
73  std::vector<BufferedParamCommand*>* paramCommandBuffer_;
74 
75  private:
76  void parseError(const std::string& message, bool serious);
77  void addCommand(BaseCommand* cmd, KeybindMode::Value mode, std::vector<BaseCommand*> commands[3]);
78  };
79 
80  inline bool Button::execute(KeybindMode::Value mode, float abs, float rel)
81  {
82  // execute all the parsed commands in the string
83  for (unsigned int iCommand = 0; iCommand < nCommands_[mode]; iCommand++)
84  commands_[mode][iCommand]->execute(abs, rel);
85  return true;
86  }
87 
88 }
89 
90 #endif /* _Button_H__ */
float buttonThreshold_
Says how much it takes for an analog axis to trigger a button Note: This variable is here to have onl...
Definition: Button.h:70
std::string bindingString_
The configured string value.
Definition: Button.h:59
::std::string string
Definition: gtest-port.h:756
This class represents a config file, which is stored on the hard-disk and contains config values in d...
Definition: ConfigFile.h:51
Output level, used for messages directed to the user (e.g. "Press any key to continue") ...
Definition: OutputDefinitions.h:89
std::string name_
Name of the trigger as strings.
Definition: Button.h:61
Declarations of all key/button/axis code enumeration and string literals and an input device enumerat...
bool bButtonThresholdUser_
Definition: Button.h:71
Die Wagnis Klasse hat die folgenden Aufgaben:
Definition: ApplicationPaths.cc:66
ARGUMENT_COMPLETION_FUNCTION_IMPLEMENTATION_MULTI() command(const std::string &fragment)
Returns a list of commands and groups and also supports auto-completion of the arguments of these com...
Definition: ArgumentCompletionFunctions.cc:178
std::vector< BufferedParamCommand * > * paramCommandBuffer_
Pointer to the list of parametrised commands.
Definition: Button.h:73
Different definitions of input processing.
Value
Definition: CorePrereqs.h:124
#define _CoreExport
Definition: CorePrereqs.h:61
Definition: InputCommands.h:55
bool execute(KeybindMode::Value mode, float abs=1.0f, float rel=1.0f)
Definition: Button.h:80
std::string groupName_
Name of the group of input triggers.
Definition: Button.h:63
virtual bool addParamCommand(ParamCommand *command)
Definition: Button.h:52
Definition: InputCommands.h:102
Definition: Button.h:46