2018-10-16 04:47:27 +00:00
|
|
|
/* ScummVM - Graphic Adventure Engine
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
2021-12-26 17:47:58 +00:00
|
|
|
* 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 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
2018-10-16 04:47:27 +00:00
|
|
|
*
|
|
|
|
* 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
|
2021-12-26 17:47:58 +00:00
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2018-10-16 04:47:27 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2018-11-14 03:47:07 +00:00
|
|
|
#ifndef GLK_EVENTS_H
|
|
|
|
#define GLK_EVENTS_H
|
2018-10-16 04:47:27 +00:00
|
|
|
|
|
|
|
#include "common/events.h"
|
2018-11-06 06:13:14 +00:00
|
|
|
#include "graphics/surface.h"
|
2018-11-14 03:47:07 +00:00
|
|
|
#include "glk/utils.h"
|
2018-10-16 04:47:27 +00:00
|
|
|
|
2018-11-14 04:05:59 +00:00
|
|
|
namespace Glk {
|
2018-10-16 04:47:27 +00:00
|
|
|
|
2018-10-29 08:02:40 +00:00
|
|
|
#define GAME_FRAME_RATE 100
|
|
|
|
#define GAME_FRAME_TIME (1000 / GAME_FRAME_RATE)
|
|
|
|
|
2018-10-21 17:53:32 +00:00
|
|
|
class Window;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Event types
|
|
|
|
*/
|
|
|
|
enum EvType {
|
|
|
|
evtype_None = 0,
|
|
|
|
evtype_Timer = 1,
|
|
|
|
evtype_CharInput = 2,
|
|
|
|
evtype_LineInput = 3,
|
|
|
|
evtype_MouseInput = 4,
|
|
|
|
evtype_Arrange = 5,
|
|
|
|
evtype_Redraw = 6,
|
|
|
|
evtype_SoundNotify = 7,
|
|
|
|
evtype_Hyperlink = 8,
|
|
|
|
evtype_VolumeNotify = 9,
|
|
|
|
|
|
|
|
// ScummVM custom events
|
2018-11-10 05:42:22 +00:00
|
|
|
evtype_Quit = 99
|
2018-10-21 17:53:32 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Keycodes
|
|
|
|
*/
|
2022-11-26 15:02:00 +00:00
|
|
|
enum Keycode : uint {
|
2018-10-21 17:53:32 +00:00
|
|
|
keycode_Unknown = 0xffffffffU,
|
|
|
|
keycode_Left = 0xfffffffeU,
|
|
|
|
keycode_Right = 0xfffffffdU,
|
|
|
|
keycode_Up = 0xfffffffcU,
|
|
|
|
keycode_Down = 0xfffffffbU,
|
|
|
|
keycode_Return = 0xfffffffaU,
|
|
|
|
keycode_Delete = 0xfffffff9U,
|
|
|
|
keycode_Escape = 0xfffffff8U,
|
|
|
|
keycode_Tab = 0xfffffff7U,
|
|
|
|
keycode_PageUp = 0xfffffff6U,
|
|
|
|
keycode_PageDown = 0xfffffff5U,
|
|
|
|
keycode_Home = 0xfffffff4U,
|
|
|
|
keycode_End = 0xfffffff3U,
|
|
|
|
keycode_Func1 = 0xffffffefU,
|
|
|
|
keycode_Func2 = 0xffffffeeU,
|
|
|
|
keycode_Func3 = 0xffffffedU,
|
|
|
|
keycode_Func4 = 0xffffffecU,
|
|
|
|
keycode_Func5 = 0xffffffebU,
|
|
|
|
keycode_Func6 = 0xffffffeaU,
|
|
|
|
keycode_Func7 = 0xffffffe9U,
|
|
|
|
keycode_Func8 = 0xffffffe8U,
|
|
|
|
keycode_Func9 = 0xffffffe7U,
|
|
|
|
keycode_Func10 = 0xffffffe6U,
|
|
|
|
keycode_Func11 = 0xffffffe5U,
|
|
|
|
keycode_Func12 = 0xffffffe4U,
|
|
|
|
|
|
|
|
// non standard keycodes
|
|
|
|
keycode_Erase = 0xffffef7fU,
|
|
|
|
keycode_MouseWheelUp = 0xffffeffeU,
|
|
|
|
keycode_MouseWheelDown = 0xffffefffU,
|
|
|
|
keycode_SkipWordLeft = 0xfffff000U,
|
|
|
|
keycode_SkipWordRight = 0xfffff001U,
|
|
|
|
|
|
|
|
// The last keycode is always = 0x100000000 - keycode_MAXVAL)
|
|
|
|
keycode_MAXVAL = 28U
|
|
|
|
};
|
|
|
|
|
2018-11-07 03:43:16 +00:00
|
|
|
/**
|
|
|
|
* List of cursors
|
|
|
|
*/
|
2018-11-06 06:13:14 +00:00
|
|
|
enum CursorId {
|
|
|
|
CURSOR_NONE = 0,
|
|
|
|
CURSOR_ARROW = 1,
|
2018-11-07 03:43:16 +00:00
|
|
|
CURSOR_IBEAM = 2,
|
|
|
|
CURSOR_HAND = 3
|
2018-11-06 06:13:14 +00:00
|
|
|
};
|
|
|
|
|
2018-10-21 17:53:32 +00:00
|
|
|
/**
|
|
|
|
* Event structure
|
|
|
|
*/
|
|
|
|
struct Event {
|
2018-10-25 04:39:17 +00:00
|
|
|
EvType type;
|
|
|
|
Window *window;
|
2018-12-09 22:46:57 +00:00
|
|
|
uint val1, val2;
|
2018-10-21 17:53:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*/
|
2018-11-10 05:42:22 +00:00
|
|
|
Event() {
|
|
|
|
clear();
|
|
|
|
}
|
2018-10-27 22:08:25 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*/
|
2018-12-09 22:46:57 +00:00
|
|
|
Event(EvType evType, Window *evWindow, uint evVal1, uint evVal2) {
|
2018-10-27 22:08:25 +00:00
|
|
|
type = evType;
|
|
|
|
window = evWindow;
|
|
|
|
val1 = evVal1;
|
|
|
|
val2 = evVal2;
|
|
|
|
}
|
2018-10-26 02:03:40 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Clear
|
|
|
|
*/
|
|
|
|
void clear() {
|
|
|
|
type = evtype_None;
|
|
|
|
window = nullptr;
|
|
|
|
val1 = val2 = 0;
|
|
|
|
}
|
2018-10-27 22:08:25 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Boolean cast to allow checking whether event is filled out
|
|
|
|
*/
|
2018-11-10 05:42:22 +00:00
|
|
|
operator bool() const {
|
|
|
|
return type != evtype_None;
|
|
|
|
}
|
2018-10-21 17:53:32 +00:00
|
|
|
};
|
2018-10-25 04:39:17 +00:00
|
|
|
typedef Event event_t;
|
2018-10-21 17:53:32 +00:00
|
|
|
|
2018-10-27 22:08:25 +00:00
|
|
|
class EventQueue : public Common::Queue<Event> {
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Retrieve a pending event, if any
|
|
|
|
*/
|
|
|
|
Event retrieve() {
|
|
|
|
return empty() ? Event() : pop();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-10-28 01:44:32 +00:00
|
|
|
/**
|
|
|
|
* Events manager
|
|
|
|
*/
|
2018-10-16 04:47:27 +00:00
|
|
|
class Events {
|
2018-11-06 06:13:14 +00:00
|
|
|
struct Surface : public Graphics::Surface {
|
|
|
|
Common::Point _hotspot;
|
|
|
|
};
|
2018-10-27 22:08:25 +00:00
|
|
|
private:
|
2018-11-10 05:42:22 +00:00
|
|
|
EventQueue _eventsPolled; ///< User generated events
|
|
|
|
EventQueue _eventsLogged; ///< Custom events generated by game code
|
|
|
|
Event *_currentEvent; ///< Event pointer passed during event retrieval
|
|
|
|
uint32 _priorFrameTime; ///< Time of prior game frame
|
|
|
|
uint32 _frameCounter; ///< Frame counter
|
|
|
|
bool _redraw; ///< Screen needed redrawing
|
|
|
|
CursorId _cursorId; ///< Current cursor Id
|
|
|
|
Surface _cursors[4]; ///< Cursor pixel data
|
|
|
|
uint _timerMilli; ///< Time in milliseconds between timer events
|
|
|
|
uint _timerTimeExpiry; ///< When to trigger next timer event
|
2018-10-27 22:08:25 +00:00
|
|
|
private:
|
2018-11-06 06:13:14 +00:00
|
|
|
/**
|
|
|
|
* Initialize the cursor graphics
|
|
|
|
*/
|
|
|
|
void initializeCursors();
|
|
|
|
|
2018-10-29 08:02:40 +00:00
|
|
|
/**
|
|
|
|
* Checks for whether it's time for the next game frame
|
|
|
|
*/
|
2018-11-04 05:13:42 +00:00
|
|
|
void checkForNextFrameCounter();
|
2018-10-29 08:02:40 +00:00
|
|
|
|
2018-10-28 01:44:32 +00:00
|
|
|
/**
|
|
|
|
* Dispatches an event
|
|
|
|
*/
|
2018-10-27 22:08:25 +00:00
|
|
|
void dispatchEvent(Event &ev, bool polled);
|
2018-10-28 01:44:32 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Poll for user events
|
|
|
|
*/
|
|
|
|
void pollEvents();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle a key down event
|
|
|
|
*/
|
|
|
|
void handleKeyDown(const Common::KeyState &ks);
|
2018-10-28 02:03:11 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle scroll events
|
|
|
|
*/
|
|
|
|
void handleScroll(bool wheelUp);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle mouse move events
|
|
|
|
*/
|
2018-10-28 21:43:09 +00:00
|
|
|
void handleMouseMove(const Point &pos);
|
2018-10-28 02:03:11 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle mouse down events
|
|
|
|
*/
|
2018-10-28 21:43:09 +00:00
|
|
|
void handleButtonDown(bool isLeft, const Point &pos);
|
2018-10-28 02:03:11 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle mouse up events
|
|
|
|
*/
|
2018-10-28 21:43:09 +00:00
|
|
|
void handleButtonUp(bool isLeft, const Point &pos);
|
2019-03-02 03:34:40 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true if the passed keycode is for the Ctrl or Alt keys
|
|
|
|
*/
|
|
|
|
bool isModifierKey(const Common::KeyCode &keycode) const;
|
2018-10-21 17:53:32 +00:00
|
|
|
public:
|
|
|
|
bool _forceClick;
|
2018-10-16 04:47:27 +00:00
|
|
|
public:
|
2018-10-21 17:53:32 +00:00
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*/
|
2018-10-29 08:02:40 +00:00
|
|
|
Events();
|
2018-10-21 17:53:32 +00:00
|
|
|
|
2018-11-06 06:13:14 +00:00
|
|
|
/**
|
|
|
|
* Destructor
|
|
|
|
*/
|
|
|
|
~Events();
|
|
|
|
|
2018-10-16 04:47:27 +00:00
|
|
|
/**
|
2018-10-27 19:29:27 +00:00
|
|
|
* Get any pending event
|
|
|
|
*/
|
|
|
|
void getEvent(event_t *event, bool polled);
|
2018-10-22 05:53:35 +00:00
|
|
|
|
2018-10-27 19:29:27 +00:00
|
|
|
/**
|
|
|
|
* Store an event for retrieval
|
|
|
|
*/
|
2018-12-09 22:46:57 +00:00
|
|
|
void store(EvType type, Window *win, uint val1 = 0, uint val2 = 0);
|
2019-08-03 03:29:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Wait for a keypress
|
|
|
|
*/
|
|
|
|
uint getKeypress();
|
2018-11-03 03:13:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Wait for a keyboard or mouse press
|
|
|
|
*/
|
|
|
|
void waitForPress();
|
2018-11-04 01:46:44 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the total number of frames played
|
|
|
|
*/
|
2018-11-10 05:42:22 +00:00
|
|
|
uint32 getTotalPlayTicks() const {
|
|
|
|
return _frameCounter;
|
|
|
|
}
|
2018-11-04 01:46:44 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the total number of frames played
|
|
|
|
*/
|
2018-11-10 18:25:20 +00:00
|
|
|
void setTotalPlayTicks(uint frames) {
|
2018-11-10 05:42:22 +00:00
|
|
|
_frameCounter = frames;
|
|
|
|
}
|
2018-11-04 05:13:42 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Flags the screen for redrawing
|
|
|
|
*/
|
2018-11-10 05:42:22 +00:00
|
|
|
void redraw() {
|
|
|
|
_redraw = true;
|
|
|
|
}
|
2018-11-06 06:13:14 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the current cursor
|
|
|
|
*/
|
|
|
|
void setCursor(CursorId cursorId);
|
2018-11-10 04:27:14 +00:00
|
|
|
|
2019-01-20 03:28:37 +00:00
|
|
|
/**
|
|
|
|
* Sets whether the mouse cursor is visible
|
|
|
|
* @remarks Normally the cursor is visible for all games, even for those that didn't have mouse originally,
|
|
|
|
* so as to allow for common Glk functionality for selecting ranges of text
|
|
|
|
*/
|
|
|
|
void showMouseCursor(bool visible);
|
|
|
|
|
2018-11-10 04:27:14 +00:00
|
|
|
/**
|
|
|
|
* Set a timer interval
|
2018-11-10 05:42:22 +00:00
|
|
|
* @param milli Time in millieseconds for intervals, or 0 for off
|
2018-11-10 04:27:14 +00:00
|
|
|
*/
|
|
|
|
void setTimerInterval(uint milli);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true if it's time for a timer event
|
|
|
|
*/
|
|
|
|
bool isTimerExpired() const;
|
2018-10-16 04:47:27 +00:00
|
|
|
};
|
|
|
|
|
2018-11-14 04:05:59 +00:00
|
|
|
} // End of namespace Glk
|
2018-10-16 04:47:27 +00:00
|
|
|
|
|
|
|
#endif
|