2008-05-01 16:33:53 -04:00
|
|
|
//
|
|
|
|
// SuperTuxKart - a fun racing game with go-kart
|
2015-03-29 20:31:42 -04:00
|
|
|
// Copyright (C) 2007-2015 Robert Schuster <robertschuster@fsfe.org>
|
|
|
|
// Copyright (C) 2012-2015 SuperTuxKart-Team
|
2008-05-01 16:33:53 -04:00
|
|
|
//
|
|
|
|
// 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
|
|
|
|
2011-10-25 13:46:14 -04:00
|
|
|
/**
|
|
|
|
* \defgroup input
|
|
|
|
* Contains classes for input management (keyboard and gamepad)
|
|
|
|
*/
|
2010-04-23 16:36:13 -04:00
|
|
|
|
2009-01-04 18:03:37 -05:00
|
|
|
#include <string>
|
2009-08-30 14:21:59 -04:00
|
|
|
#include <irrString.h>
|
2007-11-26 09:28:15 -05:00
|
|
|
|
2010-04-23 16:36:13 -04:00
|
|
|
/**
|
|
|
|
* \ingroup input
|
|
|
|
*/
|
2007-11-26 09:28:15 -05:00
|
|
|
struct Input
|
|
|
|
{
|
2009-07-10 21:56:07 -04:00
|
|
|
static const int MAX_VALUE = 32768;
|
2013-05-30 15:47:39 -04:00
|
|
|
|
2011-04-12 21:47:06 -04:00
|
|
|
static const int HAT_H_ID = 100;
|
|
|
|
static const int HAT_V_ID = 101;
|
2013-05-30 15:47:39 -04:00
|
|
|
|
2010-04-23 16:36:13 -04:00
|
|
|
enum AxisDirection
|
|
|
|
{
|
2008-12-30 19:06:55 -05:00
|
|
|
AD_NEGATIVE,
|
|
|
|
AD_POSITIVE,
|
|
|
|
AD_NEUTRAL
|
|
|
|
};
|
|
|
|
|
2013-07-01 18:50:59 -04:00
|
|
|
enum AxisRange
|
|
|
|
{
|
|
|
|
AR_HALF,
|
|
|
|
AR_FULL
|
|
|
|
};
|
|
|
|
|
2010-04-23 16:36:13 -04:00
|
|
|
enum InputType
|
|
|
|
{
|
2008-12-30 19:06:55 -05:00
|
|
|
IT_NONE = 0,
|
|
|
|
IT_KEYBOARD,
|
|
|
|
IT_STICKMOTION,
|
|
|
|
IT_STICKBUTTON,
|
2011-04-12 21:47:06 -04:00
|
|
|
//IT_STICKHAT,
|
2008-12-30 19:06:55 -05:00
|
|
|
IT_MOUSEMOTION,
|
|
|
|
IT_MOUSEBUTTON
|
|
|
|
};
|
|
|
|
static const int IT_LAST = IT_MOUSEBUTTON;
|
|
|
|
|
2010-11-11 15:59:49 -05:00
|
|
|
InputType m_type;
|
|
|
|
int m_device_id;
|
|
|
|
int m_button_id; // or axis ID for gamepads axes
|
|
|
|
int m_axis_direction;
|
2013-07-01 18:50:59 -04:00
|
|
|
int m_axis_range;
|
2010-11-11 15:59:49 -05:00
|
|
|
wchar_t m_character;
|
2007-11-26 09:28:15 -05:00
|
|
|
|
2009-12-17 19:36:35 -05:00
|
|
|
Input()
|
2013-05-30 15:47:39 -04:00
|
|
|
: m_type(IT_NONE), m_device_id(0), m_button_id(0),
|
2014-01-26 19:21:07 -05:00
|
|
|
m_axis_direction(0), m_axis_range(Input::AR_FULL), m_character(0)
|
2009-12-17 19:36:35 -05:00
|
|
|
{
|
|
|
|
// Nothing to do.
|
|
|
|
}
|
2013-05-30 15:47:39 -04:00
|
|
|
|
2009-12-17 19:36:35 -05:00
|
|
|
/** 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.
|
|
|
|
* IT_KEYBOARD: id0 is a irrLicht value.
|
|
|
|
* 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
|
2007-11-26 09:28:15 -05:00
|
|
|
* negative direction is to the left and that axis 1 is the Y-Axis with the
|
2009-12-17 19:36:35 -05:00
|
|
|
* 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,
|
2013-05-30 15:47:39 -04:00
|
|
|
* ...)
|
2009-12-17 19:36:35 -05:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
2013-05-30 15:47:39 -04:00
|
|
|
Input(InputType ntype, int deviceID , int btnID = 0, int axisDirection= 0)
|
|
|
|
: m_type(ntype), m_device_id(deviceID), m_button_id(btnID),
|
2014-01-25 21:05:00 -05:00
|
|
|
m_axis_direction(axisDirection), m_axis_range(Input::AR_FULL)
|
2009-12-17 19:36:35 -05:00
|
|
|
{
|
|
|
|
// Nothing to do.
|
|
|
|
}
|
2013-05-30 15:47:39 -04:00
|
|
|
|
2010-11-15 16:55:50 -05:00
|
|
|
}; // struct Input
|
2007-11-26 09:28:15 -05:00
|
|
|
|
2010-04-23 16:36:13 -04:00
|
|
|
/**
|
|
|
|
* \brief types of input events / what actions the players can do
|
|
|
|
* \ingroup input
|
|
|
|
*/
|
2009-03-23 12:00:47 -04:00
|
|
|
enum PlayerAction
|
|
|
|
{
|
2010-05-03 14:56:55 -04:00
|
|
|
PA_BEFORE_FIRST = -1,
|
2013-05-30 15:47:39 -04:00
|
|
|
|
2010-05-03 14:56:55 -04:00
|
|
|
PA_STEER_LEFT = 0,
|
|
|
|
PA_STEER_RIGHT,
|
2009-12-17 19:36:35 -05:00
|
|
|
PA_ACCEL,
|
|
|
|
PA_BRAKE,
|
|
|
|
PA_NITRO,
|
|
|
|
PA_DRIFT,
|
|
|
|
PA_RESCUE,
|
|
|
|
PA_FIRE,
|
|
|
|
PA_LOOK_BACK,
|
2011-08-18 21:40:27 -04:00
|
|
|
PA_PAUSE_RACE,
|
2013-05-30 15:47:39 -04:00
|
|
|
|
2010-05-03 14:56:55 -04:00
|
|
|
PA_MENU_UP,
|
|
|
|
PA_MENU_DOWN,
|
|
|
|
PA_MENU_LEFT,
|
|
|
|
PA_MENU_RIGHT,
|
|
|
|
PA_MENU_SELECT,
|
|
|
|
PA_MENU_CANCEL,
|
2013-05-30 15:47:39 -04:00
|
|
|
|
2009-03-23 12:00:47 -04:00
|
|
|
PA_COUNT
|
2007-11-26 09:28:15 -05:00
|
|
|
};
|
2009-03-23 12:00:47 -04:00
|
|
|
|
2010-05-03 14:56:55 -04:00
|
|
|
const PlayerAction PA_FIRST_GAME_ACTION = PA_STEER_LEFT;
|
2011-08-18 21:40:27 -04:00
|
|
|
const PlayerAction PA_LAST_GAME_ACTION = PA_PAUSE_RACE;
|
2010-05-03 14:56:55 -04:00
|
|
|
const PlayerAction PA_FIRST_MENU_ACTION = PA_MENU_UP;
|
|
|
|
const PlayerAction PA_LAST_MENU_ACTION = PA_MENU_CANCEL;
|
|
|
|
|
2010-04-23 16:36:13 -04:00
|
|
|
/**
|
|
|
|
* \brief human-readable strings for each PlayerAction
|
|
|
|
* \ingroup input
|
|
|
|
*/
|
2013-05-30 15:47:39 -04:00
|
|
|
static std::string KartActionStrings[PA_COUNT] = {std::string("steerLeft"),
|
2010-05-03 14:56:55 -04:00
|
|
|
std::string("steerRight"),
|
2009-01-04 18:03:37 -05:00
|
|
|
std::string("accel"),
|
|
|
|
std::string("brake"),
|
|
|
|
std::string("nitro"),
|
|
|
|
std::string("drift"),
|
|
|
|
std::string("rescue"),
|
|
|
|
std::string("fire"),
|
2010-05-03 14:56:55 -04:00
|
|
|
std::string("lookBack"),
|
2011-08-18 21:40:27 -04:00
|
|
|
std::string("pauserace"),
|
2010-05-03 14:56:55 -04:00
|
|
|
std::string("menuUp"),
|
|
|
|
std::string("menuDown"),
|
|
|
|
std::string("menuLeft"),
|
|
|
|
std::string("menuRight"),
|
|
|
|
std::string("menuSelect"),
|
|
|
|
std::string("menuCancel")
|
|
|
|
};
|
2007-11-26 09:28:15 -05:00
|
|
|
|
|
|
|
#endif
|