mirror of
https://github.com/RetroDECK/Supermodel.git
synced 2024-11-25 15:15:40 +00:00
9ffce8b92a
Making changes to a header file should no longer force the entire project to recompile.
223 lines
5.6 KiB
C++
223 lines
5.6 KiB
C++
/**
|
|
** Supermodel
|
|
** A Sega Model 3 Arcade Emulator.
|
|
** Copyright 2011 Bart Trzynadlowski, Nik Henson
|
|
**
|
|
** This file is part of Supermodel.
|
|
**
|
|
** Supermodel is free software: you can redistribute it and/or modify it under
|
|
** the terms of the GNU General Public License as published by the Free
|
|
** Software Foundation, either version 3 of the License, or (at your option)
|
|
** any later version.
|
|
**
|
|
** Supermodel 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 Supermodel. If not, see <http://www.gnu.org/licenses/>.
|
|
**/
|
|
|
|
/*
|
|
* Input.h
|
|
*
|
|
* Header file for base input class, CInput, defining an input source. Also
|
|
* defines Game::INPUT_UI.
|
|
*/
|
|
|
|
#ifndef INCLUDED_INPUT_H
|
|
#define INCLUDED_INPUT_H
|
|
|
|
#include "InputSource.h"
|
|
#include "Types.h"
|
|
#include "Game.h"
|
|
#include "Util/NewConfig.h"
|
|
|
|
class CInputSystem;
|
|
|
|
// Flags for inputs
|
|
#define INPUT_FLAGS_SWITCH 0x0001
|
|
#define INPUT_FLAGS_ANALOG 0x0002
|
|
#define INPUT_FLAGS_AXIS 0x0004
|
|
#define INPUT_FLAGS_VIRTUAL 0x0008
|
|
|
|
#define MAX_MAPPING_LENGTH 255
|
|
|
|
#define NUM_FF_EFFECTS 3
|
|
|
|
enum EForceFeedback
|
|
{
|
|
FFStop = -1,
|
|
FFConstantForce = 0,
|
|
FFSelfCenter = 1,
|
|
FFFriction = 2,
|
|
FFVibrate = 3
|
|
};
|
|
|
|
struct ForceFeedbackCmd
|
|
{
|
|
EForceFeedback id; // Type of effect to apply
|
|
float force; // Intensity (and, for FFConstantForce, direction) of effect with 0.0f = off and +/1.0f = maximum
|
|
};
|
|
|
|
/*
|
|
* Base class for any type of Model3 input control.
|
|
*/
|
|
class CInput
|
|
{
|
|
private:
|
|
// Current mapping(s) for input, eg JOY1_XAXIS_POS
|
|
char m_mapping[MAX_MAPPING_LENGTH + 1];
|
|
|
|
// Default mapping for input
|
|
const char *m_defaultMapping;
|
|
|
|
// Assigned input system
|
|
CInputSystem *m_system;
|
|
|
|
/*
|
|
* Creates an input source using the current input system and assigns it to this input.
|
|
*/
|
|
void CreateSource();
|
|
|
|
protected:
|
|
// Current input source
|
|
CInputSource *m_source;
|
|
|
|
/*
|
|
* Constructs an input with the given identifier, label, flags, game flags, default mapping and initial value.
|
|
*/
|
|
CInput(const char *inputId, const char *inputLabel, unsigned inputFlags, unsigned inputGameFlags,
|
|
const char *defaultMapping = "NONE", UINT16 initValue = 0);
|
|
|
|
public:
|
|
virtual ~CInput();
|
|
|
|
// Input identifier
|
|
const char *id;
|
|
|
|
// Input label
|
|
const char *label;
|
|
|
|
// Input flags
|
|
const unsigned flags;
|
|
|
|
// Input game flags
|
|
const unsigned gameFlags;
|
|
|
|
// Current input value
|
|
UINT16 value;
|
|
|
|
// Previous input value
|
|
UINT16 prevValue;
|
|
|
|
/*
|
|
* Initializes this input with the given input system. Must be called before any other methods are used.
|
|
*/
|
|
void Initialize(CInputSystem *system);
|
|
|
|
/*
|
|
* Returns the name of the group of controls that this input belongs to.
|
|
*/
|
|
const char* GetInputGroup();
|
|
|
|
/*
|
|
* Returns the current mapping(s) assigned to this input.
|
|
*/
|
|
const char* GetMapping();
|
|
|
|
/*
|
|
* Clears the current mapping(s) assigned to this input.
|
|
*/
|
|
void ClearMapping();
|
|
|
|
/*
|
|
* Sets the current mapping(s) assigned to this input.
|
|
* Multiple mapping assignments are comma-separated, eg KEY_RIGHT,JOY1_XAXIS_POS.
|
|
* Simultaneous assignments are joined with a plus, eg KEY_ALT+KEY_P.
|
|
*/
|
|
void SetMapping(const char *mapping);
|
|
|
|
/*
|
|
* Appends a mapping to this input to create a multiple mapping assignment.
|
|
*/
|
|
void AppendMapping(const char *mapping);
|
|
|
|
/*
|
|
* Resets the mapping(s) assigned to this input to the input's default.
|
|
*/
|
|
void ResetToDefaultMapping();
|
|
|
|
/*
|
|
* Loads the input's mapping(s) from the given config object, as well as any other settings.
|
|
*/
|
|
virtual void LoadFromConfig(const Util::Config::Node &config);
|
|
|
|
/*
|
|
* Stores the current input mapping(s) to the given config object, as well as any other settings.
|
|
*/
|
|
virtual void StoreToConfig(Util::Config::Node *config);
|
|
|
|
void InputSystemChanged();
|
|
|
|
/*
|
|
* Returns true if the input is a UI input.
|
|
*/
|
|
bool IsUIInput();
|
|
|
|
/*
|
|
* Returns true if the input is configurable and can be set by the user.
|
|
*/
|
|
bool IsConfigurable();
|
|
|
|
/*
|
|
* Returns true if the input is a virtual input, ie one which generates its value based on other inputs and so has no mapping.
|
|
*/
|
|
bool IsVirtual();
|
|
|
|
/*
|
|
* Configures the current mapping(s) assigned to this input by asking the user for input.
|
|
* If append is true, then the user's selected mapping is appended. Otherwise, it overwrites the existing mapping(s).
|
|
* escapeMapping holds the input mapping used to exit the configuration without applying the changes.
|
|
*/
|
|
bool Configure(bool append, const char *escapeMapping = "KEY_ESCAPE");
|
|
|
|
/*
|
|
* Polls (updates) this input, updating its value from the input source
|
|
*/
|
|
virtual void Poll() = 0;
|
|
|
|
/*
|
|
* Returns true if the value of this input changed during the last poll.
|
|
*/
|
|
bool Changed();
|
|
|
|
/*
|
|
* Sends a force feedback command to the input source of this input.
|
|
*/
|
|
bool SendForceFeedbackCmd(ForceFeedbackCmd ffCmd);
|
|
};
|
|
|
|
//
|
|
// Inlined methods
|
|
//
|
|
|
|
inline bool CInput::IsUIInput()
|
|
{
|
|
return gameFlags == Game::INPUT_UI;
|
|
}
|
|
|
|
inline bool CInput::IsConfigurable()
|
|
{
|
|
// All inputs except UI and virtual ones can be configured by the user
|
|
return (gameFlags != Game::INPUT_UI) && !(flags & INPUT_FLAGS_VIRTUAL);
|
|
}
|
|
|
|
inline bool CInput::IsVirtual()
|
|
{
|
|
return !!(flags & INPUT_FLAGS_VIRTUAL);
|
|
}
|
|
|
|
#endif // INCLUDED_INPUT_H
|