Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/trunk/src/libraries/core/input/KeyBinder.h @ 5738

Last change on this file since 5738 was 5738, checked in by landauf, 15 years ago

merged libraries2 back to trunk

  • Property svn:eol-style set to native
File size: 8.3 KB
RevLine 
[971]1/*
2 *   ORXONOX - the hottest 3D action shooter ever to exist
[1349]3 *                    > www.orxonox.net <
[971]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 */
[973]28
[971]29/**
[1755]30@file
31@brief
32    Different definitions of input processing.
33*/
[973]34
[1413]35#ifndef _KeyBinder_H__
36#define _KeyBinder_H__
[973]37
[3327]38#include "InputPrereqs.h"
[1062]39
[3196]40#include <cassert>
41#include <string>
[1349]42#include <vector>
[5695]43#include <boost/shared_ptr.hpp>
[2662]44
[3327]45#include "InputHandler.h"
[1520]46#include "Button.h"
47#include "HalfAxis.h"
[1887]48#include "InputCommands.h"
[3327]49#include "JoyStickQuantityListener.h"
[973]50
51namespace orxonox
52{
[1755]53    /**
54    @brief
55        Handles mouse, keyboard and joy stick input while in the actual game mode.
56        Manages the key bindings.
57    */
[3327]58    class _CoreExport KeyBinder : public InputHandler, public JoyStickQuantityListener
[1755]59    {
60    public:
61        KeyBinder ();
62        virtual ~KeyBinder();
[1022]63
[2710]64        void loadBindings(const std::string& filename);
[1755]65        void clearBindings();
[1887]66        bool setBinding(const std::string& binding, const std::string& name, bool bTemporary = false);
[1755]67        void setConfigValues();
68        void resetJoyStickAxes();
[1349]69
[1755]70    protected: // functions
[3327]71        void allDevicesUpdated(float dt);
72        void mouseUpdated(float dt);
73        void joyStickUpdated(unsigned int joyStick, float dt);
[1887]74        // internal
[2087]75        void tickHalfAxis(HalfAxis& halfAxis);
[1413]76
[1887]77        void buttonThresholdChanged();
[3327]78        // from JoyStickQuantityListener interface
79        virtual void JoyStickQuantityChanged(const std::vector<JoyStick*>& joyStickList);
[1887]80        void initialiseJoyStickBindings();
81        void compilePointerLists();
[1219]82
[3327]83        void buttonPressed (const KeyEvent& evt);
84        void buttonReleased(const KeyEvent& evt);
85        void buttonHeld    (const KeyEvent& evt);
[1022]86
[3327]87        void buttonPressed (MouseButtonCode::ByEnum button);
88        void buttonReleased(MouseButtonCode::ByEnum button);
89        void buttonHeld    (MouseButtonCode::ByEnum button);
90        void mouseMoved    (IntVector2 abs, IntVector2 rel, IntVector2 clippingSize);
91        void mouseScrolled (int abs, int rel);
[1022]92
[3327]93        void buttonPressed (unsigned int device, JoyStickButtonCode::ByEnum button);
94        void buttonReleased(unsigned int device, JoyStickButtonCode::ByEnum button);
95        void buttonHeld    (unsigned int device, JoyStickButtonCode::ByEnum button);
96        void axisMoved     (unsigned int device, unsigned int axis, float value);
[1349]97
[1755]98    protected: // variables
[1887]99        //! Currently active joy sticks
[3327]100        std::vector<JoyStick*>  joySticks_;
[1022]101
[1887]102        //! Actual key bindings for keys on the keyboard
103        Button keys_            [KeyCode::numberOfKeys];
104        //! Number of mouse buttons in KeyBinder (+4)
[1888]105        static const unsigned int numberOfMouseButtons_ = MouseButtonCode::numberOfButtons + 4;
[1887]106        //! Actual key bindings for mouse buttons including the wheel(s)
107        Button mouseButtons_    [numberOfMouseButtons_];
108        //! Actual key bindings for mouse axes
109        HalfAxis mouseAxes_     [MouseAxisCode::numberOfAxes * 2];
[1219]110
[1887]111        //! Helper class to use something like std:vector<Button[64]>
112        struct JoyStickButtonVector
113        {
114            Button& operator[](unsigned int index) { return buttons[index]; }
115            Button buttons[JoyStickButtonCode::numberOfButtons];
116        };
117        //! Actual key bindings for joy stick buttons
[5695]118        std::vector<shared_ptr<JoyStickButtonVector> > joyStickButtons_;
[1887]119        //! Helper class to use something like std:vector<HalfAxis[48]>
120        struct JoyStickAxisVector
121        {
122            HalfAxis& operator[](unsigned int index) { return halfAxes[index]; }
123            HalfAxis halfAxes[JoyStickAxisCode::numberOfAxes * 2];
124        };
125        //! Actual key bindings for joy stick axes (and sliders)
[5695]126        std::vector<shared_ptr<JoyStickAxisVector> > joyStickAxes_;
[1219]127
[1887]128        //! Pointer map with all Buttons, including half axes
129        std::map<std::string, Button*> allButtons_;
130        //! Pointer list with all half axes
131        std::vector<HalfAxis*> allHalfAxes_;
[1349]132
[1755]133        /**
134        @brief
135            Commands that have additional parameters (axes) are executed at the end of
[2896]136            update() so that all values can be buffered for single execution.
[1755]137        */
138        std::vector<BufferedParamCommand*> paramCommandBuffer_;
[1349]139
[1755]140        //! Keeps track of the absolute mouse value (incl. scroll wheel)
141        int mousePosition_[2];
142        //! Used to derive mouse input if requested
143        int mouseRelative_[2];
144        float deriveTime_;
[1349]145
[2103]146        //! Config file used. ConfigFileType::NoType in case of KeyDetector. Also indicates whether we've already loaded.
147        ConfigFileType configFile_;
[1755]148
[1887]149    private:
[1755]150        //##### ConfigValues #####
[2087]151        //! Whether to filter small value analog input
152        bool bFilterAnalogNoise_;
[1755]153        //! Threshold for analog triggers until which the state is 0.
154        float analogThreshold_;
155        //! Threshold for analog triggers until which the button is not pressed.
156        float buttonThreshold_;
157        //! Derive mouse input for absolute values?
158        bool bDeriveMouseInput_;
159        //! Accuracy of the mouse input deriver. The higher the more precise, but laggier.
160        float derivePeriod_;
161        //! mouse sensitivity
162        float mouseSensitivity_;
163        //! mouse sensitivity if mouse input is derived
164        float mouseSensitivityDerived_;
[1887]165        //! Equals one step of the mousewheel
[2087]166        int mouseWheelStepSize_;
[1887]167
168        //##### Constant config variables #####
169        // Use some value at about 1000. This can be configured with mouseSensitivity_ anyway.
170        static const int mouseClippingSize_ = 1024;
[1755]171    };
[1887]172
[3327]173    inline void KeyBinder::buttonPressed (const KeyEvent& evt)
174    { assert(!keys_[evt.getKeyCode()].name_.empty()); keys_[evt.getKeyCode()].execute(KeybindMode::OnPress); }
[1887]175
[3327]176    inline void KeyBinder::buttonReleased(const KeyEvent& evt)
177    { assert(!keys_[evt.getKeyCode()].name_.empty()); keys_[evt.getKeyCode()].execute(KeybindMode::OnRelease); }
[1887]178
[3327]179    inline void KeyBinder::buttonHeld    (const KeyEvent& evt)
180    { assert(!keys_[evt.getKeyCode()].name_.empty()); keys_[evt.getKeyCode()].execute(KeybindMode::OnHold); }
[1887]181
182
[3327]183    inline void KeyBinder::buttonPressed (MouseButtonCode::ByEnum button)
184    { mouseButtons_[button].execute(KeybindMode::OnPress); }
[1887]185
[3327]186    inline void KeyBinder::buttonReleased(MouseButtonCode::ByEnum button)
187    { mouseButtons_[button].execute(KeybindMode::OnRelease); }
[1887]188
[3327]189    inline void KeyBinder::buttonHeld    (MouseButtonCode::ByEnum button)
190    { mouseButtons_[button].execute(KeybindMode::OnHold); }
[1887]191
192
[3327]193    inline void KeyBinder::buttonPressed (unsigned int device, JoyStickButtonCode::ByEnum button)
[5695]194    { (*joyStickButtons_[device])[button].execute(KeybindMode::OnPress); }
[1887]195
[3327]196    inline void KeyBinder::buttonReleased(unsigned int device, JoyStickButtonCode::ByEnum button)
[5695]197    { (*joyStickButtons_[device])[button].execute(KeybindMode::OnRelease); }
[1887]198
[3327]199    inline void KeyBinder::buttonHeld    (unsigned int device, JoyStickButtonCode::ByEnum button)
[5695]200    { (*joyStickButtons_[device])[button].execute(KeybindMode::OnHold); }
[1887]201
[3327]202    inline void KeyBinder::allDevicesUpdated(float dt)
[1887]203    {
204        // execute all buffered bindings (additional parameter)
205        for (unsigned int i = 0; i < paramCommandBuffer_.size(); i++)
[2087]206        {
207            paramCommandBuffer_[i]->rel_ *= dt;
[1887]208            paramCommandBuffer_[i]->execute();
[2087]209        }
[1887]210
211        // always reset the relative movement of the mouse
212        for (unsigned int i = 0; i < MouseAxisCode::numberOfAxes * 2; i++)
213            mouseAxes_[i].relVal_ = 0.0f;
214    }
[1413]215}
[973]216
[1413]217#endif /* _KeyBinder_H__ */
Note: See TracBrowser for help on using the repository browser.