2013-05-18 13:13:48 +10: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.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "voyeur/events.h"
|
2013-05-25 09:58:03 -04:00
|
|
|
#include "voyeur/voyeur.h"
|
2013-12-25 14:08:37 +11:00
|
|
|
#include "voyeur/staticres.h"
|
2013-12-05 21:49:12 -05:00
|
|
|
#include "common/events.h"
|
2013-06-21 00:18:19 -04:00
|
|
|
#include "graphics/cursorman.h"
|
2013-06-05 21:28:51 -04:00
|
|
|
#include "graphics/palette.h"
|
2013-05-18 13:13:48 +10:00
|
|
|
|
|
|
|
namespace Voyeur {
|
|
|
|
|
2013-06-08 10:31:37 -04:00
|
|
|
IntNode::IntNode() {
|
|
|
|
_intFunc = NULL;
|
|
|
|
_curTime = 0;
|
|
|
|
_timeReset = 0;
|
|
|
|
_flags = 0;
|
|
|
|
}
|
|
|
|
|
2013-06-08 15:41:22 -04:00
|
|
|
IntNode::IntNode(uint16 curTime, uint16 timeReset, uint16 flags) {
|
|
|
|
_intFunc = NULL;
|
|
|
|
_curTime = curTime;
|
|
|
|
_timeReset = timeReset;
|
|
|
|
_flags = flags;
|
|
|
|
}
|
|
|
|
|
2013-06-08 10:31:37 -04:00
|
|
|
/*------------------------------------------------------------------------*/
|
|
|
|
|
2013-12-05 21:49:12 -05:00
|
|
|
IntData::IntData() {
|
|
|
|
_field9 = false;
|
|
|
|
_flipWait = false;
|
|
|
|
_hasPalette = false;
|
|
|
|
field16 = 0;
|
|
|
|
field1A = 0;
|
|
|
|
field1E = 0;
|
|
|
|
field22 = 0;
|
|
|
|
field24 = 0;
|
|
|
|
field26 = 0;
|
|
|
|
field2A = 0;
|
|
|
|
field38 = 0;
|
|
|
|
field3B = 0;
|
|
|
|
field3D = 0;
|
|
|
|
_palStartIndex = 0;
|
|
|
|
_palEndIndex = 0;
|
|
|
|
_palette = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*------------------------------------------------------------------------*/
|
2014-01-05 20:56:14 -05:00
|
|
|
|
|
|
|
void SVoy::addEvent(int hour, int minute, VoyeurEventType type, int videoId,
|
|
|
|
int on, int off, int dead) {
|
|
|
|
VoyeurEvent &e = _events[_eventCount++];
|
|
|
|
|
|
|
|
e._hour = hour;
|
|
|
|
e._minute = minute;
|
|
|
|
e._isAM = hour < 12;
|
|
|
|
e._videoId = videoId;
|
|
|
|
e._computerOn = on;
|
|
|
|
e._computerOff = off;
|
|
|
|
e._dead = dead;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*------------------------------------------------------------------------*/
|
2013-12-05 21:49:12 -05:00
|
|
|
|
2013-06-08 15:41:22 -04:00
|
|
|
EventsManager::EventsManager(): _intPtr(_gameData),
|
|
|
|
_fadeIntNode(0, 0, 3), _cycleIntNode(0, 0, 3) {
|
2013-05-27 23:01:15 -04:00
|
|
|
_cycleStatus = 0;
|
2013-06-01 22:14:59 -04:00
|
|
|
_mouseButton = 0;
|
2013-06-08 10:31:37 -04:00
|
|
|
_fadeStatus = 0;
|
2013-06-01 22:14:59 -04:00
|
|
|
_priorFrameTime = g_system->getMillis();
|
2013-12-09 22:22:32 -05:00
|
|
|
_joe = 0;
|
2013-06-01 22:14:59 -04:00
|
|
|
Common::fill(&_keyState[0], &_keyState[256], false);
|
2013-12-30 10:25:46 +11:00
|
|
|
Common::fill(&_cycleTime[0], &_cycleTime[4], 0);
|
2013-12-30 16:52:50 +11:00
|
|
|
Common::fill(&_cycleNext[0], &_cycleNext[4], (byte *)nullptr);
|
2013-12-30 10:25:46 +11:00
|
|
|
_cyclePtr = NULL;
|
2013-12-29 09:58:43 +11:00
|
|
|
|
|
|
|
_leftClick = _rightClick = false;
|
|
|
|
_mouseClicked = _mouseUnk = false;
|
|
|
|
_newLeftClick = _newRightClick = false;;
|
|
|
|
_newMouseClicked = _newMouseUnk = false;
|
2013-12-05 22:36:59 -05:00
|
|
|
|
2013-12-07 20:44:28 -05:00
|
|
|
_v2A0A2 = 0;
|
2013-12-05 22:36:59 -05:00
|
|
|
_videoDead = 0;
|
2013-05-27 23:01:15 -04:00
|
|
|
}
|
|
|
|
|
2013-05-25 09:58:03 -04:00
|
|
|
void EventsManager::resetMouse() {
|
|
|
|
// No implementation
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::startMainClockInt() {
|
2013-06-08 10:31:37 -04:00
|
|
|
_mainIntNode._intFunc = &EventsManager::mainVoyeurIntFunc;
|
2013-05-25 09:58:03 -04:00
|
|
|
_mainIntNode._flags = 0;
|
|
|
|
_mainIntNode._curTime = 0;
|
|
|
|
_mainIntNode._timeReset = _vm->_graphicsManager._palFlag ? 50 : 60;
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::mainVoyeurIntFunc() {
|
2013-12-24 07:38:39 +11:00
|
|
|
if (!(_vm->_voy._field478 & 1)) {
|
|
|
|
++_vm->_voy._switchBGNum;
|
2014-01-03 20:11:00 -10:00
|
|
|
|
|
|
|
if (_vm->_debugger._isTimeActive) {
|
|
|
|
// Increase camera discharge
|
|
|
|
++_vm->_voy._RTVNum;
|
|
|
|
|
|
|
|
if (_vm->_voy._RTVNum >= _vm->_voy._field4F2)
|
|
|
|
_vm->_voy._field4F0 = 1;
|
|
|
|
}
|
2013-12-24 07:38:39 +11:00
|
|
|
}
|
2013-05-18 13:13:48 +10:00
|
|
|
}
|
|
|
|
|
2013-05-31 22:13:28 -04:00
|
|
|
void EventsManager::sWaitFlip() {
|
2013-06-05 21:28:51 -04:00
|
|
|
Common::Array<ViewPortResource *> &viewPorts = _vm->_graphicsManager._viewPortListPtr->_entries;
|
2013-05-31 22:13:28 -04:00
|
|
|
for (uint idx = 0; idx < viewPorts.size(); ++idx) {
|
|
|
|
ViewPortResource &viewPort = *viewPorts[idx];
|
|
|
|
|
2013-06-17 22:41:58 -04:00
|
|
|
if (_vm->_graphicsManager._saveBack && (viewPort._flags & DISPFLAG_40)) {
|
2013-05-31 22:13:28 -04:00
|
|
|
Common::Rect *clipPtr = _vm->_graphicsManager._clipPtr;
|
|
|
|
_vm->_graphicsManager._clipPtr = &viewPort._clipRect;
|
|
|
|
|
|
|
|
if (viewPort._restoreFn)
|
|
|
|
(_vm->_graphicsManager.*viewPort._restoreFn)(&viewPort);
|
|
|
|
|
|
|
|
_vm->_graphicsManager._clipPtr = clipPtr;
|
2013-06-01 12:35:50 -04:00
|
|
|
viewPort._rectListCount[viewPort._pageIndex] = 0;
|
2013-06-16 21:20:42 -04:00
|
|
|
viewPort._rectListPtr[viewPort._pageIndex]->clear();
|
2013-06-17 22:41:58 -04:00
|
|
|
viewPort._flags &= ~DISPFLAG_40;
|
2013-05-31 22:13:28 -04:00
|
|
|
}
|
|
|
|
}
|
2013-12-29 09:58:43 +11:00
|
|
|
|
|
|
|
while (_gameData._flipWait && !_vm->shouldQuit()) {
|
|
|
|
pollEvents();
|
|
|
|
g_system->delayMillis(10);
|
|
|
|
}
|
2013-05-31 22:13:28 -04:00
|
|
|
}
|
|
|
|
|
2013-06-01 22:14:59 -04:00
|
|
|
void EventsManager::checkForNextFrameCounter() {
|
|
|
|
// Check for next game frame
|
|
|
|
uint32 milli = g_system->getMillis();
|
|
|
|
if ((milli - _priorFrameTime) >= GAME_FRAME_TIME) {
|
|
|
|
++_gameCounter;
|
|
|
|
_priorFrameTime = milli;
|
|
|
|
|
2013-06-05 21:28:51 -04:00
|
|
|
// Run the timer-based updates
|
2013-06-08 15:41:22 -04:00
|
|
|
voyeurTimer();
|
2013-06-05 21:28:51 -04:00
|
|
|
|
2013-12-24 07:38:39 +11:00
|
|
|
if ((_gameCounter % GAME_FRAME_RATE) == 0)
|
|
|
|
mainVoyeurIntFunc();
|
|
|
|
|
2014-01-03 20:11:00 -10:00
|
|
|
// Give time to the debugger
|
|
|
|
_vm->_debugger.onFrame();
|
|
|
|
|
2013-06-02 22:33:47 -04:00
|
|
|
// Display the frame
|
2013-11-30 20:44:23 -05:00
|
|
|
g_system->copyRectToScreen((byte *)_vm->_graphicsManager._screenSurface.getPixels(),
|
2013-06-02 22:33:47 -04:00
|
|
|
SCREEN_WIDTH, 0, 0, SCREEN_WIDTH, SCREEN_HEIGHT);
|
|
|
|
g_system->updateScreen();
|
|
|
|
|
2013-06-01 22:14:59 -04:00
|
|
|
// Signal the ScummVM debugger
|
|
|
|
_vm->_debugger.onFrame();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-06-08 15:41:22 -04:00
|
|
|
void EventsManager::voyeurTimer() {
|
|
|
|
_gameData.field22 += _gameData.field24;
|
|
|
|
_gameData.field1A += _gameData.field1E;
|
|
|
|
// _gameData.field1C += _gameData._timerFn; *** WHY INC field by a function pointer?!
|
|
|
|
|
|
|
|
_gameData.field16 = 0;
|
|
|
|
_gameData.field3D = 1;
|
|
|
|
|
|
|
|
if (--_gameData.field26 <= 0) {
|
|
|
|
if (_gameData._flipWait) {
|
|
|
|
_gameData.field38 = 1;
|
|
|
|
_gameData._flipWait = false;
|
|
|
|
_gameData.field3B = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
_gameData.field26 >>= 8;
|
|
|
|
}
|
|
|
|
|
|
|
|
videoTimer();
|
|
|
|
|
|
|
|
// Iterate through the list of registered nodes
|
|
|
|
Common::List<IntNode *>::iterator i;
|
|
|
|
for (i = _intNodes.begin(); i != _intNodes.end(); ++i) {
|
|
|
|
IntNode &node = **i;
|
|
|
|
|
|
|
|
if (node._flags & 1)
|
|
|
|
continue;
|
|
|
|
if (!(node._flags & 2)) {
|
|
|
|
if (--node._curTime != 0)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
node._curTime = node._timeReset;
|
|
|
|
}
|
|
|
|
|
|
|
|
(this->*node._intFunc)();
|
|
|
|
}
|
2013-12-24 07:38:39 +11:00
|
|
|
|
2013-06-08 15:41:22 -04:00
|
|
|
}
|
|
|
|
|
2013-06-05 21:28:51 -04:00
|
|
|
void EventsManager::videoTimer() {
|
2013-06-08 15:41:22 -04:00
|
|
|
if (_gameData._hasPalette) {
|
|
|
|
_gameData._hasPalette = false;
|
2013-06-05 21:28:51 -04:00
|
|
|
|
2013-12-18 08:53:44 -05:00
|
|
|
g_system->getPaletteManager()->setPalette(_gameData._palette +
|
|
|
|
_gameData._palStartIndex * 3, _gameData._palStartIndex,
|
2013-06-08 15:41:22 -04:00
|
|
|
_gameData._palEndIndex - _gameData._palStartIndex + 1);
|
2013-06-05 21:28:51 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::delay(int cycles) {
|
|
|
|
uint32 totalMilli = cycles * 1000 / GAME_FRAME_RATE;
|
2013-06-01 22:14:59 -04:00
|
|
|
uint32 delayEnd = g_system->getMillis() + totalMilli;
|
|
|
|
|
|
|
|
while (!_vm->shouldQuit() && g_system->getMillis() < delayEnd) {
|
|
|
|
g_system->delayMillis(10);
|
2013-06-02 22:33:47 -04:00
|
|
|
|
|
|
|
pollEvents();
|
2013-06-01 22:14:59 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-12-28 18:37:37 +11:00
|
|
|
void EventsManager::delayClick(int cycles) {
|
|
|
|
uint32 totalMilli = cycles * 1000 / GAME_FRAME_RATE;
|
|
|
|
uint32 delayEnd = g_system->getMillis() + totalMilli;
|
|
|
|
|
2013-12-28 20:32:17 +11:00
|
|
|
do {
|
2013-12-28 18:37:37 +11:00
|
|
|
g_system->delayMillis(10);
|
2013-12-28 20:32:17 +11:00
|
|
|
getMouseInfo();
|
|
|
|
} while (!_vm->shouldQuit() && g_system->getMillis() < delayEnd
|
2013-12-29 09:58:43 +11:00
|
|
|
&& !_vm->_eventsManager._mouseClicked);
|
2013-12-28 18:37:37 +11:00
|
|
|
}
|
|
|
|
|
2013-06-01 22:14:59 -04:00
|
|
|
void EventsManager::pollEvents() {
|
|
|
|
checkForNextFrameCounter();
|
|
|
|
|
|
|
|
Common::Event event;
|
|
|
|
while (g_system->getEventManager()->pollEvent(event)) {
|
|
|
|
// Handle keypress
|
|
|
|
switch (event.type) {
|
|
|
|
case Common::EVENT_QUIT:
|
|
|
|
case Common::EVENT_RTL:
|
|
|
|
return;
|
|
|
|
|
|
|
|
case Common::EVENT_KEYDOWN:
|
2014-01-03 20:11:00 -10:00
|
|
|
// Check for debugger
|
|
|
|
if (event.kbd.keycode == Common::KEYCODE_d && (event.kbd.flags & Common::KBD_CTRL)) {
|
|
|
|
// Attach to the debugger
|
|
|
|
_vm->_debugger.attach();
|
|
|
|
_vm->_debugger.onFrame();
|
|
|
|
} else {
|
|
|
|
_keyState[(byte)toupper(event.kbd.ascii)] = true;
|
|
|
|
}
|
2013-06-01 22:14:59 -04:00
|
|
|
return;
|
|
|
|
case Common::EVENT_KEYUP:
|
|
|
|
_keyState[(byte)toupper(event.kbd.ascii)] = false;
|
|
|
|
return;
|
|
|
|
case Common::EVENT_LBUTTONDOWN:
|
|
|
|
_mouseButton = 1;
|
2013-12-29 09:58:43 +11:00
|
|
|
_vm->_eventsManager._newLeftClick = true;
|
|
|
|
_vm->_eventsManager._newMouseClicked = true;
|
2013-06-01 22:14:59 -04:00
|
|
|
return;
|
|
|
|
case Common::EVENT_RBUTTONDOWN:
|
|
|
|
_mouseButton = 2;
|
2013-12-29 09:58:43 +11:00
|
|
|
_vm->_eventsManager._newRightClick = true;
|
|
|
|
_vm->_eventsManager._newMouseClicked = true;
|
2013-06-01 22:14:59 -04:00
|
|
|
return;
|
|
|
|
case Common::EVENT_LBUTTONUP:
|
|
|
|
case Common::EVENT_RBUTTONUP:
|
2013-12-29 09:58:43 +11:00
|
|
|
_vm->_eventsManager._newMouseClicked = false;
|
|
|
|
_vm->_eventsManager._newLeftClick = false;
|
|
|
|
_vm->_eventsManager._newRightClick = false;
|
2013-06-01 22:14:59 -04:00
|
|
|
_mouseButton = 0;
|
|
|
|
return;
|
2013-06-12 22:13:52 -04:00
|
|
|
case Common::EVENT_MOUSEMOVE:
|
|
|
|
_mousePos = event.mouse;
|
|
|
|
break;
|
2013-06-01 22:14:59 -04:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-06-05 21:28:51 -04:00
|
|
|
void EventsManager::startFade(CMapResource *cMap) {
|
|
|
|
_fadeIntNode._flags |= 1;
|
|
|
|
if (_cycleStatus & 1)
|
|
|
|
_cycleIntNode._flags |= 1;
|
|
|
|
|
|
|
|
_fadeFirstCol = cMap->_start;
|
|
|
|
_fadeLastCol = cMap->_end;
|
|
|
|
_fadeCount = cMap->_steps + 1;
|
|
|
|
|
|
|
|
if (cMap->_steps > 0) {
|
2013-06-10 23:24:02 -04:00
|
|
|
_fadeStatus = cMap->_fadeStatus | 1;
|
2013-06-05 21:28:51 -04:00
|
|
|
byte *vgaP = &_vm->_graphicsManager._VGAColors[_fadeFirstCol * 3];
|
|
|
|
int mapIndex = 0;
|
|
|
|
|
2013-06-10 23:24:02 -04:00
|
|
|
for (int idx = _fadeFirstCol; idx <= _fadeLastCol; ++idx, vgaP += 3) {
|
2013-06-07 22:07:57 -04:00
|
|
|
ViewPortPalEntry &palEntry = _vm->_graphicsManager._viewPortListPtr->_palette[idx];
|
|
|
|
palEntry._rEntry = vgaP[0] << 8;
|
2013-06-10 23:24:02 -04:00
|
|
|
int rDiff = (cMap->_entries[mapIndex * 3] << 8) - palEntry._rEntry;
|
|
|
|
palEntry._rChange = rDiff / cMap->_steps;
|
2013-06-07 22:07:57 -04:00
|
|
|
|
|
|
|
palEntry._gEntry = vgaP[1] << 8;
|
2013-06-10 23:24:02 -04:00
|
|
|
int gDiff = (cMap->_entries[mapIndex * 3 + 1] << 8) - palEntry._gEntry;
|
|
|
|
palEntry._gChange = gDiff / cMap->_steps;
|
2013-06-07 22:07:57 -04:00
|
|
|
|
|
|
|
palEntry._bEntry = vgaP[2] << 8;
|
2013-06-10 23:24:02 -04:00
|
|
|
int bDiff = (cMap->_entries[mapIndex * 3 + 2] << 8) - palEntry._bEntry;
|
|
|
|
palEntry._bChange = bDiff / cMap->_steps;
|
|
|
|
|
|
|
|
palEntry._palIndex = idx;
|
2013-06-05 21:28:51 -04:00
|
|
|
if (!(cMap->_fadeStatus & 1))
|
|
|
|
++mapIndex;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cMap->_fadeStatus & 2)
|
2013-06-08 15:41:22 -04:00
|
|
|
_intPtr.field3B = 1;
|
2013-06-05 21:28:51 -04:00
|
|
|
_fadeIntNode._flags &= ~1;
|
|
|
|
} else {
|
|
|
|
byte *vgaP = &_vm->_graphicsManager._VGAColors[_fadeFirstCol * 3];
|
|
|
|
int mapIndex = 0;
|
|
|
|
|
|
|
|
for (int idx = _fadeFirstCol; idx <= _fadeLastCol; ++idx, vgaP += 3) {
|
2013-06-17 22:59:26 -04:00
|
|
|
Common::copy(&cMap->_entries[mapIndex], &cMap->_entries[mapIndex + 3], vgaP);
|
2013-06-05 21:28:51 -04:00
|
|
|
|
|
|
|
if (!(cMap->_fadeStatus & 1))
|
|
|
|
mapIndex += 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (_intPtr._palStartIndex > _fadeFirstCol)
|
|
|
|
_intPtr._palStartIndex = _fadeFirstCol;
|
|
|
|
if (_intPtr._palEndIndex < _fadeLastCol)
|
|
|
|
_intPtr._palEndIndex = _fadeLastCol;
|
|
|
|
|
|
|
|
_intPtr._hasPalette = true;
|
|
|
|
if (!(cMap->_fadeStatus & 2))
|
2013-06-08 15:41:22 -04:00
|
|
|
_intPtr.field38 = 1;
|
2013-06-05 21:28:51 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
if (_cycleStatus & 1)
|
|
|
|
_cycleIntNode._flags &= ~1;
|
|
|
|
}
|
|
|
|
|
2013-06-08 10:31:37 -04:00
|
|
|
void EventsManager::addIntNode(IntNode *node) {
|
|
|
|
_intNodes.push_back(node);
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::addFadeInt() {
|
2013-06-08 15:41:22 -04:00
|
|
|
IntNode &node = _fade2IntNode;
|
2013-06-08 10:31:37 -04:00
|
|
|
node._intFunc = &EventsManager::fadeIntFunc;
|
|
|
|
node._flags = 0;
|
|
|
|
node._curTime = 0;
|
|
|
|
node._timeReset = 1;
|
|
|
|
|
|
|
|
addIntNode(&node);
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::vDoFadeInt() {
|
2013-06-08 15:41:22 -04:00
|
|
|
if (_intPtr.field3B & 1)
|
2013-06-08 10:31:37 -04:00
|
|
|
return;
|
|
|
|
if (--_fadeCount == 0) {
|
|
|
|
_fadeIntNode._flags |= 1;
|
|
|
|
_fadeStatus &= ~1;
|
2013-12-18 09:03:18 -05:00
|
|
|
return;
|
2013-06-08 10:31:37 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = _fadeFirstCol; i <= _fadeLastCol; ++i) {
|
|
|
|
ViewPortPalEntry &palEntry = _vm->_graphicsManager._viewPortListPtr->_palette[i];
|
|
|
|
byte *vgaP = &_vm->_graphicsManager._VGAColors[palEntry._palIndex * 3];
|
|
|
|
|
|
|
|
palEntry._rEntry += palEntry._rChange;
|
|
|
|
palEntry._gEntry += palEntry._gChange;
|
|
|
|
palEntry._bEntry += palEntry._bChange;
|
|
|
|
|
|
|
|
vgaP[0] = palEntry._rEntry >> 8;
|
|
|
|
vgaP[1] = palEntry._gEntry >> 8;
|
|
|
|
vgaP[2] = palEntry._bEntry >> 8;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (_intPtr._palStartIndex > _fadeFirstCol)
|
|
|
|
_intPtr._palStartIndex = _fadeFirstCol;
|
|
|
|
if (_intPtr._palEndIndex < _fadeLastCol)
|
|
|
|
_intPtr._palEndIndex = _fadeLastCol;
|
|
|
|
|
|
|
|
_intPtr._hasPalette = true;
|
2013-06-08 15:41:22 -04:00
|
|
|
_intPtr.field38 = 1;
|
2013-06-08 10:31:37 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::vDoCycleInt() {
|
2013-12-30 16:52:50 +11:00
|
|
|
for (int idx = 3; idx >= 0; --idx) {
|
2013-12-30 22:00:15 +11:00
|
|
|
if (_cyclePtr->_type[idx] && --_cycleTime[idx] <= 0) {
|
2013-12-30 16:52:50 +11:00
|
|
|
byte *pSrc = _cycleNext[idx];
|
|
|
|
byte *pPal = _vm->_graphicsManager._VGAColors;
|
|
|
|
|
2013-12-30 22:00:15 +11:00
|
|
|
if (_cyclePtr->_type[idx] != 1) {
|
|
|
|
// New palette data being specified - loop to set entries
|
2013-12-30 16:52:50 +11:00
|
|
|
do {
|
|
|
|
int palIndex = READ_LE_UINT16(pSrc);
|
|
|
|
pPal[palIndex * 3] = pSrc[3];
|
|
|
|
pPal[palIndex * 3 + 1] = pSrc[4];
|
|
|
|
pPal[palIndex * 3 + 1] = pSrc[5];
|
|
|
|
pSrc += 6;
|
|
|
|
|
|
|
|
if ((int16)READ_LE_UINT16(pSrc) >= 0) {
|
|
|
|
// Resetting back to start of cycle data
|
|
|
|
pSrc = _cycleNext[idx];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
} while (*(pSrc + 2) == 0);
|
|
|
|
|
|
|
|
_cycleNext[idx] = pSrc;
|
|
|
|
_cycleTime[idx] = pSrc[2];
|
|
|
|
} else {
|
2013-12-30 22:00:15 +11:00
|
|
|
// Palette rotation to be done
|
2013-12-30 16:52:50 +11:00
|
|
|
_cycleTime[idx] = pSrc[4];
|
|
|
|
|
|
|
|
if (pSrc[5] == 1) {
|
|
|
|
// Move palette entry to end of range
|
|
|
|
int start = READ_LE_UINT16(pSrc);
|
|
|
|
int end = READ_LE_UINT16(&pSrc[2]);
|
2013-12-31 18:39:38 +11:00
|
|
|
assert(start < 0x100 && end < 0x100);
|
2013-12-30 16:52:50 +11:00
|
|
|
|
|
|
|
// Store the RGB of the first entry to be moved
|
2013-12-30 22:00:15 +11:00
|
|
|
byte r = pPal[start * 3];
|
|
|
|
byte g = pPal[start * 3 + 1];
|
|
|
|
byte b = pPal[start * 3 + 2];
|
2013-12-30 16:52:50 +11:00
|
|
|
|
|
|
|
// Move the remainder of the range backwards one entry
|
|
|
|
// TODO: Is this allowing for overlap properly?
|
2013-12-30 22:00:15 +11:00
|
|
|
Common::copy(&pPal[start * 3 + 3], &pPal[end * 3 + 3], &pPal[start * 3]);
|
2013-12-30 16:52:50 +11:00
|
|
|
|
|
|
|
// Place the original saved entry at the end of the range
|
2013-12-30 22:00:15 +11:00
|
|
|
pPal[end * 3] = r;
|
|
|
|
pPal[end * 3 + 1] = g;
|
|
|
|
pPal[end * 3 + 2] = b;
|
2013-12-30 16:52:50 +11:00
|
|
|
|
|
|
|
if (_fadeStatus & 1) {
|
|
|
|
//dx = start, di = end
|
|
|
|
warning("TODO: Adjustment of ViewPortListResource");
|
|
|
|
}
|
|
|
|
} else {
|
2013-12-30 22:00:15 +11:00
|
|
|
// Move palette entry to start of range
|
2013-12-30 16:52:50 +11:00
|
|
|
int start = READ_LE_UINT16(pSrc);
|
|
|
|
int end = READ_LE_UINT16(&pSrc[2]);
|
2013-12-31 18:39:38 +11:00
|
|
|
assert(start < 0x100 && end < 0x100);
|
2013-12-30 16:52:50 +11:00
|
|
|
|
|
|
|
// Store the RGB of the entry to be moved
|
2013-12-30 22:00:15 +11:00
|
|
|
byte r = pPal[end * 3];
|
|
|
|
byte g = pPal[end * 3 + 1];
|
|
|
|
byte b = pPal[end * 3 + 2];
|
2013-12-30 16:52:50 +11:00
|
|
|
|
|
|
|
// Move the remainder of the range forwards one entry
|
|
|
|
// TODO: Does this allow for overlap range correctly?
|
2013-12-30 22:00:15 +11:00
|
|
|
Common::copy_backward(&pPal[start * 3], &pPal[end * 3], &pPal[end * 3 + 3]);
|
2013-12-30 16:52:50 +11:00
|
|
|
|
|
|
|
// Place the original saved entry at the end of the range
|
2013-12-30 22:00:15 +11:00
|
|
|
pPal[start * 3] = r;
|
|
|
|
pPal[start * 3 + 1] = g;
|
|
|
|
pPal[start * 3 + 2] = b;
|
2013-12-30 16:52:50 +11:00
|
|
|
|
|
|
|
if (_fadeStatus & 1) {
|
|
|
|
//dx = start, di = end
|
|
|
|
warning("TODO: Adjustment of ViewPortListResource");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2013-12-30 22:00:15 +11:00
|
|
|
|
|
|
|
_intPtr._hasPalette = true;
|
|
|
|
_intPtr.field38 = true;
|
2013-12-30 16:52:50 +11:00
|
|
|
}
|
|
|
|
}
|
2013-06-08 10:31:37 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void EventsManager::fadeIntFunc() {
|
2013-12-25 14:08:37 +11:00
|
|
|
warning("TODO");
|
2013-06-08 10:31:37 -04:00
|
|
|
}
|
|
|
|
|
2013-12-28 18:37:37 +11:00
|
|
|
void EventsManager::deleteIntNode(IntNode *node) {
|
|
|
|
_intNodes.remove(node);
|
|
|
|
}
|
|
|
|
|
2013-06-08 10:31:37 -04:00
|
|
|
void EventsManager::vInitColor() {
|
|
|
|
_fadeIntNode._intFunc = &EventsManager::vDoFadeInt;
|
|
|
|
_cycleIntNode._intFunc = &EventsManager::vDoCycleInt;
|
2013-06-08 15:41:22 -04:00
|
|
|
|
|
|
|
addIntNode(&_fadeIntNode);
|
|
|
|
addIntNode(&_cycleIntNode);
|
2013-06-08 10:31:37 -04:00
|
|
|
}
|
|
|
|
|
2013-06-21 00:18:19 -04:00
|
|
|
void EventsManager::setCursor(PictureResource *pic) {
|
|
|
|
PictureResource cursor;
|
|
|
|
cursor._bounds = pic->_bounds;
|
|
|
|
cursor._flags = DISPFLAG_CURSOR;
|
|
|
|
|
|
|
|
_vm->_graphicsManager.sDrawPic(pic, &cursor, Common::Point());
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::setCursor(byte *cursorData, int width, int height) {
|
2014-01-03 09:20:53 -10:00
|
|
|
CursorMan.replaceCursor(cursorData, width, height, width / 2, height / 2, 0);
|
2013-06-21 00:18:19 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::setCursorColor(int idx, int mode) {
|
2013-06-20 21:24:30 -04:00
|
|
|
switch (mode) {
|
2013-06-16 21:50:31 -04:00
|
|
|
case 0:
|
|
|
|
_vm->_graphicsManager.setColor(idx, 90, 90, 232);
|
|
|
|
break;
|
|
|
|
case 1:
|
|
|
|
_vm->_graphicsManager.setColor(idx, 232, 90, 90);
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
_vm->_graphicsManager.setColor(idx, 90, 232, 90);
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
_vm->_graphicsManager.setColor(idx, 90, 232, 232);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2013-06-12 22:13:52 -04:00
|
|
|
}
|
|
|
|
|
2013-12-28 20:53:33 +11:00
|
|
|
void EventsManager::showCursor() {
|
2013-06-21 00:18:19 -04:00
|
|
|
CursorMan.showMouse(true);
|
|
|
|
}
|
|
|
|
|
2013-12-20 22:51:31 -05:00
|
|
|
void EventsManager::hideCursor() {
|
2013-12-28 20:53:33 +11:00
|
|
|
CursorMan.showMouse(false);
|
2013-12-20 22:51:31 -05:00
|
|
|
}
|
|
|
|
|
2013-12-09 22:22:32 -05:00
|
|
|
void EventsManager::getMouseInfo() {
|
2013-12-24 07:38:39 +11:00
|
|
|
pollEvents();
|
|
|
|
|
2013-12-10 09:19:54 -05:00
|
|
|
if (_vm->_voy._field478 & 0x10) {
|
2013-12-09 22:22:32 -05:00
|
|
|
if ((_gameCounter - _joe) > 8) {
|
|
|
|
_joe = _gameCounter;
|
|
|
|
|
|
|
|
if (_vm->_bob) {
|
|
|
|
_vm->_bob = false;
|
2013-12-18 08:53:44 -05:00
|
|
|
_vm->_graphicsManager.setOneColor(128, 55, 5, 5);
|
2013-12-09 22:22:32 -05:00
|
|
|
_vm->_graphicsManager.setColor(128, 220, 20, 20);
|
|
|
|
} else {
|
|
|
|
_vm->_bob = true;
|
2013-12-18 08:53:44 -05:00
|
|
|
_vm->_graphicsManager.setOneColor(128, 55, 55, 55);
|
2013-12-09 22:22:32 -05:00
|
|
|
_vm->_graphicsManager.setColor(128, 220, 20, 20);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-12-29 09:58:43 +11:00
|
|
|
_vm->_eventsManager._mouseClicked = _vm->_eventsManager._newMouseClicked;
|
|
|
|
_vm->_eventsManager._leftClick = _vm->_eventsManager._newLeftClick;
|
|
|
|
_vm->_eventsManager._rightClick = _vm->_eventsManager._newRightClick;
|
|
|
|
_vm->_eventsManager._mouseUnk = _vm->_eventsManager._newMouseUnk;
|
2013-12-28 20:32:17 +11:00
|
|
|
|
2013-12-29 09:58:43 +11:00
|
|
|
_vm->_eventsManager._newMouseClicked = false;
|
|
|
|
_vm->_eventsManager._newLeftClick = false;
|
|
|
|
_vm->_eventsManager._newRightClick = false;
|
|
|
|
_vm->_eventsManager._mouseUnk = false;
|
2013-12-09 22:22:32 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::checkForKey() {
|
|
|
|
warning("TODO: checkForKey");
|
|
|
|
}
|
|
|
|
|
2013-12-10 09:19:54 -05:00
|
|
|
void EventsManager::startCursorBlink() {
|
2013-12-28 14:01:06 +11:00
|
|
|
if (_vm->_voy._field478 & 0x10) {
|
|
|
|
_vm->_graphicsManager.setOneColor(128, 55, 5, 5);
|
|
|
|
_vm->_graphicsManager.setColor(128, 220, 20, 20);
|
|
|
|
_intPtr.field38 = true;
|
|
|
|
_intPtr._hasPalette = true;
|
|
|
|
|
|
|
|
_vm->_graphicsManager.drawDot();
|
|
|
|
//copySection();
|
|
|
|
}
|
2013-12-10 09:19:54 -05:00
|
|
|
}
|
|
|
|
|
2013-12-10 20:47:05 -05:00
|
|
|
void EventsManager::incrementTime(int amt) {
|
2013-12-24 07:38:39 +11:00
|
|
|
for (int i = 0; i < amt; ++i)
|
|
|
|
mainVoyeurIntFunc();
|
2013-12-10 20:47:05 -05:00
|
|
|
}
|
|
|
|
|
2013-12-24 16:32:50 +11:00
|
|
|
void EventsManager::addVideoEventStart() {
|
|
|
|
VoyeurEvent &e = _vm->_voy._events[_vm->_voy._eventCount];
|
|
|
|
e._hour = _vm->_gameHour;
|
|
|
|
e._minute = _vm->_gameMinute;
|
|
|
|
e._isAM = _vm->_voy._isAM;
|
|
|
|
e._type = EVTYPE_VIDEO;
|
2014-01-03 11:00:12 -10:00
|
|
|
e._videoId = _vm->_videoId;
|
2013-12-24 16:32:50 +11:00
|
|
|
e._computerOn = _vm->_voy._vocSecondsOffset;
|
|
|
|
e._dead = _vm->_eventsManager._videoDead;
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::addVideoEventEnd() {
|
|
|
|
VoyeurEvent &e = _vm->_voy._events[_vm->_voy._eventCount];
|
|
|
|
e._computerOff = _vm->_voy._RTVNum - _vm->_voy._field468 - _vm->_voy._vocSecondsOffset;
|
|
|
|
if (_vm->_voy._eventCount < (TOTAL_EVENTS - 1))
|
|
|
|
++_vm->_voy._eventCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::addAudioEventStart() {
|
|
|
|
VoyeurEvent &e = _vm->_voy._events[_vm->_voy._eventCount];
|
|
|
|
e._hour = _vm->_gameHour;
|
|
|
|
e._minute = _vm->_gameMinute;
|
|
|
|
e._isAM = _vm->_voy._isAM;
|
|
|
|
e._type = EVTYPE_AUDIO;
|
2014-01-03 11:00:12 -10:00
|
|
|
e._videoId = _vm->_videoId;
|
2013-12-24 16:32:50 +11:00
|
|
|
e._computerOn = _vm->_voy._field47A;
|
|
|
|
e._dead = _vm->_eventsManager._videoDead;
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::addAudioEventEnd() {
|
|
|
|
VoyeurEvent &e = _vm->_voy._events[_vm->_voy._eventCount];
|
|
|
|
e._computerOff = _vm->_voy._RTVNum - _vm->_voy._field468 - _vm->_voy._vocSecondsOffset;
|
|
|
|
if (_vm->_voy._eventCount < (TOTAL_EVENTS - 1))
|
|
|
|
++_vm->_voy._eventCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::addEvidEventStart(int v) {
|
|
|
|
VoyeurEvent &e = _vm->_voy._events[_vm->_voy._eventCount];
|
|
|
|
e._hour = _vm->_gameHour;
|
|
|
|
e._minute = _vm->_gameMinute;
|
|
|
|
e._isAM = _vm->_voy._isAM;
|
|
|
|
e._type = EVTYPE_EVID;
|
2014-01-03 11:00:12 -10:00
|
|
|
e._videoId = _vm->_videoId;
|
2013-12-24 16:32:50 +11:00
|
|
|
e._computerOn = _vm->_voy._vocSecondsOffset;
|
|
|
|
e._dead = _vm->_eventsManager._videoDead;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::addEvidEventEnd(int dead) {
|
|
|
|
VoyeurEvent &e = _vm->_voy._events[_vm->_voy._eventCount];
|
|
|
|
e._dead = dead;
|
|
|
|
if (_vm->_voy._eventCount < (TOTAL_EVENTS - 1))
|
|
|
|
++_vm->_voy._eventCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::addComputerEventStart() {
|
|
|
|
VoyeurEvent &e = _vm->_voy._events[_vm->_voy._eventCount];
|
|
|
|
e._hour = _vm->_gameHour;
|
|
|
|
e._minute = _vm->_gameMinute;
|
|
|
|
e._isAM = _vm->_voy._isAM;
|
|
|
|
e._type = EVTYPE_COMPUTER;
|
2014-01-05 14:54:55 -05:00
|
|
|
e._videoId = _vm->_playStampGroupId;
|
2013-12-24 16:32:50 +11:00
|
|
|
e._computerOn = _vm->_voy._computerTextId;
|
|
|
|
}
|
|
|
|
|
|
|
|
void EventsManager::addComputerEventEnd(int v) {
|
|
|
|
VoyeurEvent &e = _vm->_voy._events[_vm->_voy._eventCount];
|
|
|
|
e._computerOff = v;
|
|
|
|
if (_vm->_voy._eventCount < (TOTAL_EVENTS - 1))
|
|
|
|
++_vm->_voy._eventCount;
|
|
|
|
}
|
|
|
|
|
2013-12-28 18:37:37 +11:00
|
|
|
void EventsManager::stopEvidDim() {
|
|
|
|
deleteIntNode(&_evIntNode);
|
|
|
|
}
|
|
|
|
|
2013-12-25 14:08:37 +11:00
|
|
|
Common::String EventsManager::getEvidString(int eventIndex) {
|
|
|
|
assert(eventIndex <= _vm->_voy._eventCount);
|
|
|
|
VoyeurEvent &e = _vm->_voy._events[eventIndex];
|
|
|
|
return Common::String::format("%03d %.2d:%.2d %s %s", eventIndex + 1,
|
|
|
|
e._hour, e._minute, e._isAM ? AM : PM, EVENT_TYPE_STRINGS[e._type - 1]);
|
|
|
|
}
|
|
|
|
|
2013-05-18 13:13:48 +10:00
|
|
|
} // End of namespace Voyeur
|