mirror of
https://github.com/libretro/scummvm.git
synced 2025-01-05 09:10:29 +00:00
MORTEVIELLE: Expand on the mouse/keyboard handling code
This commit is contained in:
parent
3caa20a618
commit
5c628fedd2
@ -40,6 +40,7 @@ MortevielleEngine::MortevielleEngine(OSystem *system, const ADGameDescription *g
|
||||
Engine(system), _gameDescription(gameDesc) {
|
||||
g_vm = this;
|
||||
_lastGameFrame = 0;
|
||||
_mouseButtons = 0;
|
||||
}
|
||||
|
||||
MortevielleEngine::~MortevielleEngine() {
|
||||
@ -164,11 +165,19 @@ bool MortevielleEngine::handleEvents() {
|
||||
case Common::EVENT_LBUTTONUP:
|
||||
case Common::EVENT_RBUTTONDOWN:
|
||||
case Common::EVENT_RBUTTONUP:
|
||||
case Common::EVENT_MBUTTONDOWN:
|
||||
case Common::EVENT_MBUTTONUP:
|
||||
case Common::EVENT_MOUSEMOVE:
|
||||
_mousePos = event.mouse;
|
||||
x_s = event.mouse.x;
|
||||
y_s = event.mouse.y;
|
||||
|
||||
if (event.type == Common::EVENT_LBUTTONDOWN)
|
||||
_mouseButtons |= 1;
|
||||
else if (event.type == Common::EVENT_LBUTTONUP)
|
||||
_mouseButtons &= ~1;
|
||||
else if (event.type == Common::EVENT_RBUTTONDOWN)
|
||||
_mouseButtons |= 2;
|
||||
else if (event.type == Common::EVENT_RBUTTONUP)
|
||||
_mouseButtons &= ~2;
|
||||
break;
|
||||
|
||||
case Common::EVENT_KEYDOWN:
|
||||
@ -182,20 +191,57 @@ bool MortevielleEngine::handleEvents() {
|
||||
}
|
||||
|
||||
/**
|
||||
* Add the specified key to the event queue
|
||||
* Add the specified key to the pending keypress stack
|
||||
*/
|
||||
void MortevielleEngine::addKeypress(Common::Event &evt) {
|
||||
// Check for control keypresses
|
||||
if (evt.kbd.hasFlags(Common::KBD_CTRL) && (evt.kbd.keycode >= Common::KEYCODE_a) &&
|
||||
(evt.kbd.keycode <= Common::KEYCODE_z)) {
|
||||
_keypresses.push(evt.kbd.keycode - Common::KEYCODE_a + 1);
|
||||
return;
|
||||
// Character to add
|
||||
char ch = evt.kbd.ascii;
|
||||
|
||||
// Handle alphabetic keys
|
||||
if ((evt.kbd.keycode >= Common::KEYCODE_a) && (evt.kbd.keycode <= Common::KEYCODE_z)) {
|
||||
if (evt.kbd.hasFlags(Common::KBD_CTRL))
|
||||
ch = evt.kbd.keycode - Common::KEYCODE_a + 1;
|
||||
else
|
||||
ch = evt.kbd.keycode - Common::KEYCODE_a + 'A';
|
||||
} else if ((evt.kbd.keycode >= Common::KEYCODE_F1) && (evt.kbd.keycode <= Common::KEYCODE_F12)) {
|
||||
// Handle function keys
|
||||
ch = 59 + evt.kbd.keycode - Common::KEYCODE_F1;
|
||||
} else {
|
||||
// Series of special cases
|
||||
switch (evt.kbd.keycode) {
|
||||
case Common::KEYCODE_KP4:
|
||||
case Common::KEYCODE_LEFT:
|
||||
ch = '4';
|
||||
case Common::KEYCODE_KP2:
|
||||
case Common::KEYCODE_DOWN:
|
||||
ch = '2';
|
||||
case Common::KEYCODE_KP6:
|
||||
case Common::KEYCODE_RIGHT:
|
||||
ch = '6';
|
||||
case Common::KEYCODE_KP8:
|
||||
case Common::KEYCODE_UP:
|
||||
ch = '8';
|
||||
case Common::KEYCODE_KP7:
|
||||
ch = '7';
|
||||
case Common::KEYCODE_KP1:
|
||||
ch = '1';
|
||||
case Common::KEYCODE_KP9:
|
||||
ch = '9';
|
||||
case Common::KEYCODE_KP3:
|
||||
ch = '3';
|
||||
case Common::KEYCODE_KP5:
|
||||
ch = '5';
|
||||
case Common::KEYCODE_RETURN:
|
||||
ch = '\13';
|
||||
case Common::KEYCODE_ESCAPE:
|
||||
ch = '\33';
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Handle function keys
|
||||
if ((evt.kbd.keycode >= Common::KEYCODE_F1) && (evt.kbd.keycode <= Common::KEYCODE_F12)) {
|
||||
_keypresses.push(59 + evt.kbd.keycode - Common::KEYCODE_F1);
|
||||
}
|
||||
if (ch != 0)
|
||||
_keypresses.push(ch);
|
||||
}
|
||||
|
||||
static byte CURSOR_ARROW_DATA[16 * 16] = {
|
||||
@ -225,6 +271,10 @@ void MortevielleEngine::initMouse() {
|
||||
CursorMan.showMouse(true);
|
||||
}
|
||||
|
||||
void MortevielleEngine::setMousePos(const Common::Point &pt) {
|
||||
_mousePos = pt;
|
||||
}
|
||||
|
||||
/*-------------------------------------------------------------------------*/
|
||||
|
||||
Common::Error MortevielleEngine::run() {
|
||||
|
@ -51,6 +51,8 @@ private:
|
||||
const ADGameDescription *_gameDescription;
|
||||
Common::Stack<int> _keypresses;
|
||||
uint32 _lastGameFrame;
|
||||
int _mouseButtons;
|
||||
Common::Point _mousePos;
|
||||
|
||||
Common::ErrorCode initialise();
|
||||
Common::ErrorCode loadMortDat();
|
||||
@ -70,6 +72,9 @@ public:
|
||||
|
||||
bool keyPressed();
|
||||
int getChar();
|
||||
Common::Point getMousePos() const { return _mousePos; }
|
||||
void setMousePos(const Common::Point &pt);
|
||||
int getMouseButtons() const { return _mouseButtons; }
|
||||
};
|
||||
|
||||
extern MortevielleEngine *g_vm;
|
||||
|
@ -28,6 +28,7 @@
|
||||
#include "common/endian.h"
|
||||
#include "common/rect.h"
|
||||
#include "mortevielle/mouse.h"
|
||||
#include "mortevielle/mortevielle.h"
|
||||
#include "mortevielle/var_mor.h"
|
||||
|
||||
namespace Mortevielle {
|
||||
@ -271,67 +272,28 @@ void pos_mouse(int x, int y) {
|
||||
if (y > 199) y = 199;
|
||||
else if (y < 0) y = 0;
|
||||
if ((x == x_s) && (y == y_s)) return;
|
||||
if (int_m) {
|
||||
{
|
||||
reg.ax = 4;
|
||||
reg.cx = x;
|
||||
reg.dx = y;
|
||||
}
|
||||
intr(0x33, reg);
|
||||
}
|
||||
hide_mouse();
|
||||
x_s = x;
|
||||
y_s = y;
|
||||
switch (gd) {
|
||||
case ams : {
|
||||
p_o_s = ((uint)y_s >> 1) * 80 + ((uint)x_s >> 3) + (y_s & 1) * 0x2000;
|
||||
}
|
||||
break;
|
||||
/*cga : begin
|
||||
P_O_S:=(Y_S shr 1)*80+X_S shr 2+(Y_S and 1)*$2000;
|
||||
end;*/
|
||||
case ega : {
|
||||
p_o_s = y_s * 80 + ((uint)x_s >> 3);
|
||||
}
|
||||
break;
|
||||
} /* case Gd */
|
||||
show_mouse();
|
||||
|
||||
// Set the new position
|
||||
g_vm->setMousePos(Common::Point(x, y));
|
||||
}
|
||||
|
||||
void read_pos_mouse(int &x, int &y, int &c) {
|
||||
registres reg;
|
||||
|
||||
if (int_m) {
|
||||
reg.ax = 3;
|
||||
intr(0x33, reg);
|
||||
x = reg.cx;
|
||||
y = reg.dx;
|
||||
c = reg.bx;
|
||||
} else {
|
||||
c = 0;
|
||||
x = x_s;
|
||||
y = y_s;
|
||||
}
|
||||
x = g_vm->getMousePos().x;
|
||||
y = g_vm->getMousePos().y;
|
||||
c = g_vm->getMouseButtons();
|
||||
}
|
||||
|
||||
void mov_mouse(bool &funct, char &key) {
|
||||
bool p_key;
|
||||
char in1, in2;
|
||||
int x, y, cx, cy, cd;
|
||||
registres reg;
|
||||
|
||||
if (int_m) {
|
||||
reg.ax = 3;
|
||||
intr(0x33, reg);
|
||||
x = reg.cx;
|
||||
y = reg.dx;
|
||||
cd = reg.bx;
|
||||
pos_mouse(x, y);
|
||||
if (cd != 0) {
|
||||
// If mouse button clicked, return it
|
||||
if (g_vm->getMouseButtons() != 0) {
|
||||
clic = true;
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
funct = false;
|
||||
key = '\377';
|
||||
p_key = keypressed();
|
||||
|
Loading…
Reference in New Issue
Block a user