]> git.mxchange.org Git - flightgear.git/blob - src/Input/jsinput.h
Add aubmodels to AI objects
[flightgear.git] / src / Input / jsinput.h
1 // jsinput.h -- wait for and identify input from joystick
2 //
3 // Written by Tony Peden, started May 2001
4 //
5 // Copyright (C) 2001  Tony Peden (apeden@earthlink.net)
6 //
7 // This program is free software; you can redistribute it and/or
8 // modify it under the terms of the GNU General Public License as
9 // published by the Free Software Foundation; either version 2 of the
10 // License, or (at your option) any later version.
11 //
12 // This program is distributed in the hope that it will be useful, but
13 // WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15 // General Public License for more details.
16 //
17 // You should have received a copy of the GNU General Public License
18 // along with this program; if not, write to the Free Software
19 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
20
21
22
23 #ifndef _JSINPUT_H
24 #define _JSINPUT_H
25
26 #include "jssuper.h"
27
28 class jsInput {
29   private:
30     jsSuper *jss;
31     bool pretty_display;
32     float axes[_JS_MAX_AXES];
33     float axes_iv[MAX_JOYSTICKS][_JS_MAX_AXES];
34     int button_iv[MAX_JOYSTICKS];
35
36     int joystick,axis,button;
37     bool axis_positive;
38
39     float axis_threshold;
40
41   public:
42     jsInput(jsSuper *jss);
43     ~jsInput(void);
44
45     inline void displayValues(bool bb) { pretty_display=bb; }
46
47     int getInput(void);
48     void findDeadBand(void);
49
50     inline int getInputJoystick(void) { return joystick; }
51     inline int getInputAxis(void)     { return axis; }
52     inline int getInputButton(void)   { return button; }
53     inline bool getInputAxisPositive(void) { return axis_positive; }
54
55     inline float getReturnThreshold(void) { return axis_threshold; }
56     inline void setReturnThreshold(float ff)
57               { if(fabs(ff) <= 1.0) axis_threshold=ff; }
58 };
59
60
61 #endif