2008-07-30 13:47:54 +00:00
|
|
|
/* ScummVM - Graphic Adventure Engine
|
2014-02-18 01:34:21 +00:00
|
|
|
*
|
|
|
|
* ScummVM is the legal property of its developers, whose names
|
|
|
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
|
|
* file distributed with this source distribution.
|
|
|
|
*
|
|
|
|
* This program 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 2
|
|
|
|
* 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*
|
|
|
|
*/
|
2008-07-30 13:47:54 +00:00
|
|
|
|
2008-09-30 13:51:01 +00:00
|
|
|
#ifndef COMMON_KEYMAPPER_H
|
|
|
|
#define COMMON_KEYMAPPER_H
|
|
|
|
|
|
|
|
#include "common/scummsys.h"
|
|
|
|
|
2008-08-07 16:38:39 +00:00
|
|
|
#include "backends/keymapper/keymap.h"
|
2008-07-24 10:00:56 +00:00
|
|
|
|
2017-08-13 15:04:45 +00:00
|
|
|
#include "common/array.h"
|
|
|
|
#include "common/config-manager.h"
|
|
|
|
#include "common/events.h"
|
|
|
|
|
2008-07-19 00:57:37 +00:00
|
|
|
namespace Common {
|
|
|
|
|
2011-10-22 03:54:33 +00:00
|
|
|
const char *const kGuiKeymapName = "gui";
|
2012-01-08 03:20:29 +00:00
|
|
|
const char *const kGlobalKeymapName = "global";
|
2011-10-22 03:54:33 +00:00
|
|
|
|
2020-01-29 15:48:06 +00:00
|
|
|
struct Action;
|
2017-08-14 16:22:50 +00:00
|
|
|
class DelayedEventSource;
|
2020-01-27 00:33:39 +00:00
|
|
|
struct HardwareInput;
|
2017-08-13 15:04:45 +00:00
|
|
|
class HardwareInputSet;
|
2020-01-22 10:18:55 +00:00
|
|
|
class KeymapperDefaultBindings;
|
2017-08-11 11:57:28 +00:00
|
|
|
|
2017-08-14 16:22:50 +00:00
|
|
|
class Keymapper : public Common::EventMapper {
|
2008-07-19 00:57:37 +00:00
|
|
|
public:
|
2009-05-24 15:17:42 +00:00
|
|
|
|
2008-07-21 00:11:25 +00:00
|
|
|
Keymapper(EventManager *eventMan);
|
2008-08-06 14:21:05 +00:00
|
|
|
~Keymapper();
|
2008-07-19 00:57:37 +00:00
|
|
|
|
2012-02-17 23:08:58 +00:00
|
|
|
// EventMapper interface
|
2020-01-24 08:25:16 +00:00
|
|
|
virtual List<Event> mapEvent(const Event &ev);
|
2012-02-17 23:08:58 +00:00
|
|
|
|
2008-07-23 08:45:12 +00:00
|
|
|
/**
|
2020-03-11 19:42:59 +00:00
|
|
|
* Registers a HardwareInputSet and platform-specific default mappings with the Keymapper
|
2020-01-28 17:44:09 +00:00
|
|
|
*
|
|
|
|
* Transfers ownership to the Keymapper
|
2008-07-23 08:45:12 +00:00
|
|
|
*/
|
2020-03-11 19:42:59 +00:00
|
|
|
void registerHardwareInputSet(HardwareInputSet *inputs, KeymapperDefaultBindings *backendDefaultBindings);
|
2020-01-22 10:18:55 +00:00
|
|
|
|
2008-07-23 08:45:12 +00:00
|
|
|
/**
|
2008-08-08 14:23:59 +00:00
|
|
|
* Add a keymap to the global domain.
|
2008-07-23 08:45:12 +00:00
|
|
|
* If a saved key setup exists for it in the ini file it will be used.
|
|
|
|
* Else, the key setup will be automatically mapped.
|
2017-08-15 06:47:57 +00:00
|
|
|
*
|
|
|
|
* Transfers ownership of the keymap to the Keymapper
|
2008-07-23 08:45:12 +00:00
|
|
|
*/
|
2008-08-08 14:23:59 +00:00
|
|
|
void addGlobalKeymap(Keymap *keymap);
|
2008-07-21 15:55:25 +00:00
|
|
|
|
2008-07-23 08:45:12 +00:00
|
|
|
/**
|
2008-08-14 01:42:02 +00:00
|
|
|
* Add a keymap to the game domain.
|
2017-08-15 06:47:57 +00:00
|
|
|
*
|
|
|
|
* Transfers ownership of the keymap to the Keymapper
|
|
|
|
*
|
2008-08-14 01:42:02 +00:00
|
|
|
* @see addGlobalKeyMap
|
|
|
|
* @note initGame() should be called before any game keymaps are added.
|
|
|
|
*/
|
2008-08-08 14:23:59 +00:00
|
|
|
void addGameKeymap(Keymap *keymap);
|
2008-08-06 14:21:05 +00:00
|
|
|
|
2008-08-14 01:42:02 +00:00
|
|
|
/**
|
|
|
|
* Should be called at end of game to tell Keymapper to deactivate and free
|
|
|
|
* any game keymaps that are loaded.
|
|
|
|
*/
|
|
|
|
void cleanupGameKeymaps();
|
2008-08-18 14:45:42 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Obtain a keymap of the given name from the keymapper.
|
|
|
|
* Game keymaps have priority over global keymaps
|
2020-01-28 17:44:08 +00:00
|
|
|
* @param id name of the keymap to return
|
2008-08-18 14:45:42 +00:00
|
|
|
*/
|
2020-01-28 17:44:08 +00:00
|
|
|
Keymap *getKeymap(const String &id) const;
|
2017-08-13 14:35:58 +00:00
|
|
|
|
2008-08-06 14:21:05 +00:00
|
|
|
/**
|
2017-08-13 15:04:45 +00:00
|
|
|
* Obtain a list of all the keymaps registered with the keymapper
|
2008-07-23 08:45:12 +00:00
|
|
|
*/
|
2020-01-23 09:50:52 +00:00
|
|
|
const KeymapArray &getKeymaps() const { return _keymaps; }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* reload the mappings for all the keymaps from the configuration manager
|
|
|
|
*/
|
|
|
|
void reloadAllMappings();
|
2008-08-06 14:21:05 +00:00
|
|
|
|
|
|
|
/**
|
2017-08-13 15:04:45 +00:00
|
|
|
* Set which kind of keymap is currently used to map events
|
|
|
|
*
|
|
|
|
* Keymaps with the global type are always enabled
|
2008-08-06 14:21:05 +00:00
|
|
|
*/
|
2017-08-13 15:04:45 +00:00
|
|
|
void setEnabledKeymapType(Keymap::KeymapType type);
|
2020-09-15 20:42:34 +00:00
|
|
|
Keymap::KeymapType enabledKeymapType() const { return _enabledKeymapType; }
|
2008-07-19 00:57:37 +00:00
|
|
|
|
2008-08-18 14:45:42 +00:00
|
|
|
/**
|
|
|
|
* Enable/disable the keymapper
|
|
|
|
*/
|
2008-08-08 14:23:59 +00:00
|
|
|
void setEnabled(bool enabled) { _enabled = enabled; }
|
|
|
|
|
2020-02-09 06:18:13 +00:00
|
|
|
/**
|
|
|
|
* Clear all the keymaps and hardware input sets
|
|
|
|
*/
|
|
|
|
void clear();
|
|
|
|
|
2008-08-18 14:45:42 +00:00
|
|
|
/**
|
2017-08-13 13:00:14 +00:00
|
|
|
* Return a HardwareInput pointer for the given event
|
2012-02-24 19:55:48 +00:00
|
|
|
*/
|
2020-01-26 11:18:52 +00:00
|
|
|
HardwareInput findHardwareInput(const Event &event);
|
2012-02-24 19:55:48 +00:00
|
|
|
|
2020-01-23 09:50:52 +00:00
|
|
|
void initKeymap(Keymap *keymap, ConfigManager::Domain *domain);
|
2020-03-11 19:42:59 +00:00
|
|
|
void reloadKeymapMappings(Keymap *keymap);
|
2020-01-23 09:50:52 +00:00
|
|
|
|
2008-07-19 00:57:37 +00:00
|
|
|
private:
|
2017-08-14 16:22:50 +00:00
|
|
|
EventManager *_eventMan;
|
|
|
|
HardwareInputSet *_hardwareInputs;
|
2020-01-28 17:44:09 +00:00
|
|
|
KeymapperDefaultBindings *_backendDefaultBindings;
|
2017-08-14 16:22:50 +00:00
|
|
|
DelayedEventSource *_delayedEventSource;
|
2008-07-19 00:57:37 +00:00
|
|
|
|
2012-02-23 00:30:47 +00:00
|
|
|
enum IncomingEventType {
|
2020-02-08 10:19:16 +00:00
|
|
|
kIncomingEventIgnored,
|
2020-01-24 13:08:16 +00:00
|
|
|
kIncomingEventStart,
|
|
|
|
kIncomingEventEnd,
|
|
|
|
kIncomingEventInstant
|
2012-02-23 00:30:47 +00:00
|
|
|
};
|
|
|
|
|
2020-02-08 10:19:16 +00:00
|
|
|
enum {
|
|
|
|
kJoyAxisPressedTreshold = Common::JOYAXIS_MAX / 2,
|
|
|
|
kJoyAxisUnpressedTreshold = Common::JOYAXIS_MAX / 4
|
|
|
|
};
|
|
|
|
|
2017-08-14 16:22:50 +00:00
|
|
|
bool _enabled;
|
|
|
|
Keymap::KeymapType _enabledKeymapType;
|
|
|
|
|
|
|
|
KeymapArray _keymaps;
|
2008-08-18 14:45:42 +00:00
|
|
|
|
2020-02-08 10:19:16 +00:00
|
|
|
bool _joystickAxisPreviouslyPressed[6];
|
|
|
|
|
2020-05-27 03:00:49 +00:00
|
|
|
Keymap::KeymapMatch getMappedActions(const Event &event, Keymap::ActionArray &actions, Keymap::KeymapType keymapType) const;
|
2020-02-01 08:36:09 +00:00
|
|
|
Event executeAction(const Action *act, const Event &incomingEvent);
|
2020-01-24 13:08:16 +00:00
|
|
|
EventType convertStartToEnd(EventType eventType);
|
2017-08-13 13:00:14 +00:00
|
|
|
IncomingEventType convertToIncomingEventType(const Event &ev) const;
|
2008-08-06 14:21:05 +00:00
|
|
|
|
2017-08-14 16:22:50 +00:00
|
|
|
void hardcodedEventMapping(Event ev);
|
2020-02-08 10:19:16 +00:00
|
|
|
void resetInputState();
|
2017-08-14 16:22:50 +00:00
|
|
|
};
|
2008-07-21 00:11:25 +00:00
|
|
|
|
2020-09-15 20:42:34 +00:00
|
|
|
/**
|
|
|
|
* RAII helper to temporarily enable a keymap type
|
|
|
|
*/
|
|
|
|
class KeymapTypeEnabler {
|
|
|
|
public:
|
|
|
|
KeymapTypeEnabler(Keymapper *keymapper, Keymap::KeymapType keymapType) :
|
|
|
|
_keymapper(keymapper) {
|
|
|
|
assert(keymapper);
|
|
|
|
_previousKeymapType = keymapper->enabledKeymapType();
|
|
|
|
keymapper->setEnabledKeymapType(keymapType);
|
|
|
|
}
|
|
|
|
|
|
|
|
~KeymapTypeEnabler() {
|
|
|
|
_keymapper->setEnabledKeymapType(_previousKeymapType);
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
Keymapper *_keymapper;
|
|
|
|
Keymap::KeymapType _previousKeymapType;
|
|
|
|
};
|
|
|
|
|
2017-08-14 16:22:50 +00:00
|
|
|
class DelayedEventSource : public EventSource {
|
|
|
|
public:
|
|
|
|
// EventSource API
|
|
|
|
bool pollEvent(Event &event) override;
|
|
|
|
bool allowMapping() const override;
|
2008-07-21 15:55:25 +00:00
|
|
|
|
2017-08-14 16:22:50 +00:00
|
|
|
/**
|
|
|
|
* Schedule an event to be produced after the specified delay
|
|
|
|
*/
|
|
|
|
void scheduleEvent(const Event &ev, uint32 delayMillis);
|
|
|
|
|
|
|
|
private:
|
|
|
|
struct DelayedEventsEntry {
|
|
|
|
const uint32 timerOffset;
|
|
|
|
const Event event;
|
|
|
|
DelayedEventsEntry(const uint32 offset, const Event ev) : timerOffset(offset), event(ev) { }
|
|
|
|
};
|
2017-08-13 14:35:58 +00:00
|
|
|
|
2017-08-14 16:22:50 +00:00
|
|
|
Queue<DelayedEventsEntry> _delayedEvents;
|
|
|
|
uint32 _delayedEffectiveTime;
|
2008-07-19 00:57:37 +00:00
|
|
|
};
|
|
|
|
|
2009-10-04 21:26:33 +00:00
|
|
|
} // End of namespace Common
|
2008-07-19 19:12:49 +00:00
|
|
|
|
2008-09-30 13:51:01 +00:00
|
|
|
#endif // #ifndef COMMON_KEYMAPPER_H
|