aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
authorTorbjörn Andersson2006-02-26 13:02:25 +0000
committerTorbjörn Andersson2006-02-26 13:02:25 +0000
commit686d463defce92fafd8eb80c1230da5dd90d48f7 (patch)
tree51b53bb09fe5a381d58d8d85a5f7e4efb3dd6df2 /engines
parent0a898d14331b7c896f4fc43d54942e21e388db59 (diff)
downloadscummvm-rg350-686d463defce92fafd8eb80c1230da5dd90d48f7.tar.gz
scummvm-rg350-686d463defce92fafd8eb80c1230da5dd90d48f7.tar.bz2
scummvm-rg350-686d463defce92fafd8eb80c1230da5dd90d48f7.zip
Added delays to the waitForRelease() and waitForPress() busy-wait loops.
svn-id: r20912
Diffstat (limited to 'engines')
-rw-r--r--engines/lure/events.cpp6
-rw-r--r--engines/lure/events.h6
-rw-r--r--engines/lure/lure.cpp4
3 files changed, 10 insertions, 6 deletions
diff --git a/engines/lure/events.cpp b/engines/lure/events.cpp
index 1a27848d9f..185884d755 100644
--- a/engines/lure/events.cpp
+++ b/engines/lure/events.cpp
@@ -32,7 +32,7 @@ Mouse &Mouse::getReference() {
return *int_mouse;
}
-Mouse::Mouse() {
+Mouse::Mouse(OSystem &system) : _system(system) {
int_mouse = this;
_lButton = false;
@@ -103,6 +103,7 @@ void Mouse::waitForRelease() {
do {
e.pollEvent();
+ _system.delayMillis(20);
} while (!e.quitFlag && (lButton() || rButton()));
}
@@ -110,7 +111,7 @@ void Mouse::waitForRelease() {
static Events *int_events = NULL;
-Events::Events() {
+Events::Events(OSystem &system) : _system(system) {
int_events = this;
quitFlag = false;
}
@@ -158,6 +159,7 @@ void Events::waitForPress() {
Mouse::getReference().waitForRelease();
}
}
+ _system.delayMillis(20);
}
}
diff --git a/engines/lure/events.h b/engines/lure/events.h
index 0287b6de19..547fa1826f 100644
--- a/engines/lure/events.h
+++ b/engines/lure/events.h
@@ -32,11 +32,12 @@ namespace Lure {
class Mouse {
private:
+ OSystem &_system;
uint8 _cursorNum;
int16 _x, _y;
bool _lButton, _rButton;
public:
- Mouse();
+ Mouse(OSystem &system);
~Mouse();
static Mouse &getReference();
void handleEvent(OSystem::Event event);
@@ -56,11 +57,12 @@ public:
class Events {
private:
+ OSystem &_system;
OSystem::Event _event;
public:
bool quitFlag;
- Events();
+ Events(OSystem &system);
static Events &getReference();
bool pollEvent();
diff --git a/engines/lure/lure.cpp b/engines/lure/lure.cpp
index 2fc47f7d62..c72b1a6ae3 100644
--- a/engines/lure/lure.cpp
+++ b/engines/lure/lure.cpp
@@ -251,8 +251,8 @@ int LureEngine::init(GameDetector &detector) {
_resources = new Resources();
_strings = new StringData();
_screen = new Screen(*_system);
- _mouse = new Mouse();
- _events = new Events();
+ _mouse = new Mouse(*_system);
+ _events = new Events(*_system);
_menu = new Menu();
Surface::initialise();
_room = new Room();