2008-05-01 16:33:53 -04:00
|
|
|
// $Id: input.hpp 694 2006-08-29 07:42:36Z hiker $
|
|
|
|
//
|
|
|
|
// SuperTuxKart - a fun racing game with go-kart
|
|
|
|
// Copyright (C) 2007-2008 Robert Schuster <robertschuster@fsfe.org>
|
|
|
|
//
|
|
|
|
// This program is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU General Public License
|
2008-06-12 20:53:52 -04:00
|
|
|
// as published by the Free Software Foundation; either version 3
|
2008-05-01 16:33:53 -04:00
|
|
|
// of the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with this program; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
|
2008-12-30 19:06:55 -05:00
|
|
|
#ifndef HEADER_INPUT_HPP
|
|
|
|
#define HEADER_INPUT_HPP
|
2007-11-26 09:28:15 -05:00
|
|
|
|
2009-01-04 18:03:37 -05:00
|
|
|
#include <string>
|
2007-11-26 09:28:15 -05:00
|
|
|
|
2009-03-23 14:38:06 -04:00
|
|
|
const int DEADZONE_MOUSE = 150;
|
|
|
|
const int DEADZONE_MOUSE_SENSE = 200;
|
|
|
|
const int DEADZONE_JOYSTICK = 2000;
|
|
|
|
const int MULTIPLIER_MOUSE = 750;
|
|
|
|
|
2007-11-26 09:28:15 -05:00
|
|
|
struct Input
|
|
|
|
{
|
2009-07-10 21:56:07 -04:00
|
|
|
static const int MAX_VALUE = 32768;
|
|
|
|
|
2008-12-30 19:06:55 -05:00
|
|
|
enum AxisDirection {
|
|
|
|
AD_NEGATIVE,
|
|
|
|
AD_POSITIVE,
|
|
|
|
AD_NEUTRAL
|
|
|
|
};
|
|
|
|
|
|
|
|
enum InputType {
|
|
|
|
IT_NONE = 0,
|
|
|
|
IT_KEYBOARD,
|
|
|
|
IT_STICKMOTION,
|
|
|
|
IT_STICKBUTTON,
|
|
|
|
IT_STICKHAT,
|
|
|
|
IT_MOUSEMOTION,
|
|
|
|
IT_MOUSEBUTTON
|
|
|
|
};
|
|
|
|
static const int IT_LAST = IT_MOUSEBUTTON;
|
|
|
|
|
2007-11-26 09:28:15 -05:00
|
|
|
InputType type;
|
2009-05-30 14:57:25 -04:00
|
|
|
int deviceID;
|
|
|
|
int btnID; // or axis ID for gamepads axes
|
|
|
|
int axisDirection;
|
2007-11-26 09:28:15 -05:00
|
|
|
|
|
|
|
Input()
|
2009-05-30 14:57:25 -04:00
|
|
|
: type(IT_NONE), deviceID(0), btnID(0), axisDirection(0)
|
2007-11-26 09:28:15 -05:00
|
|
|
{
|
|
|
|
// Nothing to do.
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Creates an Input instance which represents an arbitrary way of getting
|
|
|
|
* game input using a type specifier and 3 integers.
|
|
|
|
*
|
|
|
|
* Meaning of the 3 integers for each InputType:
|
|
|
|
* IT_NONE: This means nothing. In certain cases this is regarded as an
|
|
|
|
* unset binding.
|
2009-05-02 20:50:09 -04:00
|
|
|
* IT_KEYBOARD: id0 is a irrLicht value.
|
2007-11-26 09:28:15 -05:00
|
|
|
* IT_STICKMOTION: id0 - stick index, id1 - axis index, id2 - axis direction
|
|
|
|
* (negative, positive). You can assume that axis 0 is the X-Axis where the
|
|
|
|
* negative direction is to the left and that axis 1 is the Y-Axis with the
|
|
|
|
* negative direction being upwards.
|
|
|
|
* IT_STICKBUTTON: id0 - stick index, id1 - button index. Button 0 and 1 are
|
|
|
|
* usually reached most easily.
|
|
|
|
* IT_STICKHAT: This is not yet implemented.
|
|
|
|
* IT_MOUSEMOTION: id0 - axis index (0 -> X, 1 -> Y). Mouse wheel is
|
|
|
|
* represented as buttons!
|
|
|
|
* IT_MOUSEBUTTON: id0 - button number (1 -> left, 2 -> middle, 3 -> right,
|
|
|
|
* ...)
|
|
|
|
*
|
|
|
|
* Note: For joystick bindings that are actice in the menu the joystick's
|
|
|
|
* index should be zero. The binding will react to all joysticks connected
|
|
|
|
* to the system.
|
|
|
|
*/
|
2009-05-30 14:57:25 -04:00
|
|
|
Input(InputType ntype, int deviceID , int btnID = 0, int axisDirection= 0)
|
|
|
|
: type(ntype), deviceID(deviceID), btnID(btnID), axisDirection(axisDirection)
|
2007-11-26 09:28:15 -05:00
|
|
|
{
|
|
|
|
// Nothing to do.
|
|
|
|
}
|
2009-05-23 20:52:31 -04:00
|
|
|
|
2009-05-29 21:41:09 -04:00
|
|
|
static std::string getInputAsString(const Input::InputType type, const int id, const Input::AxisDirection dir=AD_NEUTRAL);
|
2009-05-23 20:52:31 -04:00
|
|
|
|
2007-11-26 09:28:15 -05:00
|
|
|
};
|
|
|
|
|
2009-03-23 12:00:47 -04:00
|
|
|
enum PlayerAction
|
|
|
|
{
|
|
|
|
PA_FIRST = -1,
|
|
|
|
|
|
|
|
PA_LEFT = 0,
|
|
|
|
PA_RIGHT,
|
|
|
|
PA_ACCEL,
|
|
|
|
PA_BRAKE,
|
|
|
|
PA_NITRO,
|
|
|
|
PA_DRIFT,
|
|
|
|
PA_RESCUE,
|
|
|
|
PA_FIRE,
|
|
|
|
PA_LOOK_BACK,
|
|
|
|
|
|
|
|
PA_COUNT
|
2007-11-26 09:28:15 -05:00
|
|
|
};
|
2009-03-23 12:00:47 -04:00
|
|
|
|
|
|
|
static std::string KartActionStrings[PA_COUNT] = {std::string("left"),
|
2009-01-04 18:03:37 -05:00
|
|
|
std::string("right"),
|
|
|
|
std::string("accel"),
|
|
|
|
std::string("brake"),
|
|
|
|
std::string("nitro"),
|
|
|
|
std::string("drift"),
|
|
|
|
std::string("rescue"),
|
|
|
|
std::string("fire"),
|
|
|
|
std::string("lookBack")};
|
2007-11-26 09:28:15 -05:00
|
|
|
|
2009-03-23 12:00:47 -04:00
|
|
|
enum StaticAction
|
2007-11-26 09:28:15 -05:00
|
|
|
{
|
|
|
|
// Below this are synthetic game actions which are never triggered through
|
|
|
|
// an input device.
|
|
|
|
GA_NULL, // Nothing dummy entry.
|
|
|
|
GA_SENSE_CANCEL, // Input sensing canceled.
|
|
|
|
GA_SENSE_COMPLETE, // Input sensing successfully finished.
|
|
|
|
|
|
|
|
// Below this point are the game actions which can happen while in menu
|
|
|
|
// mode.
|
|
|
|
|
|
|
|
GA_ENTER, // Enter menu, acknowledge, ...
|
|
|
|
GA_LEAVE, // Leave a menu.
|
|
|
|
|
|
|
|
GA_CLEAR_MAPPING, // Clear an input mapping.
|
|
|
|
|
|
|
|
GA_INC_SCROLL_SPEED,
|
|
|
|
GA_INC_SCROLL_SPEED_FAST,
|
|
|
|
GA_DEC_SCROLL_SPEED,
|
|
|
|
GA_DEC_SCROLL_SPEED_FAST,
|
|
|
|
|
|
|
|
GA_CURSOR_UP,
|
|
|
|
GA_CURSOR_DOWN,
|
|
|
|
GA_CURSOR_LEFT,
|
|
|
|
GA_CURSOR_RIGHT,
|
|
|
|
|
|
|
|
|
|
|
|
GA_TOGGLE_FULLSCREEN, // Switch between windowed/fullscreen mode
|
|
|
|
GA_LEAVE_RACE, // Switch from race to menu.
|
|
|
|
|
|
|
|
GA_DEBUG_ADD_MISSILE,
|
2008-07-27 20:34:45 -04:00
|
|
|
GA_DEBUG_ADD_BOWLING,
|
2007-12-08 08:04:56 -05:00
|
|
|
GA_DEBUG_ADD_HOMING,
|
2007-11-26 09:28:15 -05:00
|
|
|
GA_DEBUG_TOGGLE_FPS,
|
|
|
|
GA_DEBUG_TOGGLE_WIREFRAME,
|
|
|
|
GA_DEBUG_HISTORY
|
|
|
|
|
|
|
|
};
|
2009-03-23 12:00:47 -04:00
|
|
|
|
|
|
|
|
2009-03-23 15:41:14 -04:00
|
|
|
|
2007-11-26 09:28:15 -05:00
|
|
|
/* Some constants to make future changes more easier to handle. If you use
|
|
|
|
* any of the GameAction constants to mark the beginning or end of a range
|
|
|
|
* or denote a count then something is wrong with your code. ;)
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** Generally the first GameAction constant. Unlikely to change. */
|
|
|
|
const int GA_FIRST = GA_NULL;
|
|
|
|
|
|
|
|
/** A usefull value for array allocations. Should always be to the
|
|
|
|
* last constant + 1.
|
|
|
|
*/
|
|
|
|
const int GA_COUNT = (GA_DEBUG_HISTORY + 1);
|
|
|
|
|
|
|
|
/* The range of GameAction constants that is used while in menu mode. */
|
|
|
|
const int GA_FIRST_MENU = GA_ENTER;
|
|
|
|
const int GA_LAST_MENU = GA_CURSOR_RIGHT;
|
|
|
|
|
|
|
|
|
|
|
|
/* The range of GameAction constants which are used ingame but are considered
|
|
|
|
* fixed and their Inputs should not be used by the players.
|
|
|
|
*/
|
|
|
|
const int GA_FIRST_INGAME_FIXED = GA_TOGGLE_FULLSCREEN;
|
|
|
|
const int GA_LAST_INGAME_FIXED = GA_DEBUG_HISTORY;
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|