1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121
|
/* 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 3 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, see <http://www.gnu.org/licenses/>.
*
*/
#include "asylum/puzzles/puzzle.h"
#include "asylum/resources/polygons.h"
#include "asylum/resources/worldstats.h"
#include "asylum/system/cursor.h"
#include "asylum/system/graphics.h"
#include "asylum/system/screen.h"
#include "asylum/views/scene.h"
#include "asylum/asylum.h"
namespace Asylum {
Puzzle::Puzzle(AsylumEngine *engine): _vm(engine) {
}
void Puzzle::saveLoadWithSerializer(Common::Serializer &) {
// By default, we do not save any data
}
//////////////////////////////////////////////////////////////////////////
// Event Handling
//////////////////////////////////////////////////////////////////////////
bool Puzzle::handleEvent(const AsylumEvent &evt) {
switch ((int32)evt.type) {
default:
break;
case EVENT_ASYLUM_INIT:
return init(evt);
case EVENT_ASYLUM_ACTIVATE:
return activate(evt);
case EVENT_ASYLUM_UPDATE:
return update(evt);
case Common::EVENT_LBUTTONDOWN:
return mouseLeftDown(evt);
case Common::EVENT_LBUTTONUP:
return mouseLeftUp(evt);
case Common::EVENT_RBUTTONDOWN:
case Common::EVENT_CUSTOM_ENGINE_ACTION_START:
return exitPuzzle();
}
return false;
}
bool Puzzle::update(const AsylumEvent &evt) {
uint32 ticks = _vm->getTick();
updateCursor();
if (!getSharedData()->getFlag(kFlagRedraw)) {
updateScreen();
getSharedData()->setFlag(kFlagRedraw, true);
}
if (ticks > getSharedData()->getNextScreenUpdate()) {
if (getSharedData()->getFlag(kFlagRedraw)) {
if (!getScreen()->isGraphicQueueEmpty())
getScreen()->drawGraphicsInQueue();
getScreen()->copyBackBufferToScreen();
getSharedData()->setEventUpdate(getSharedData()->getEventUpdate() ^ 1);
getSharedData()->setFlag(kFlagRedraw, false);
getSharedData()->setNextScreenUpdate(ticks + 40);
}
}
return true;
}
//////////////////////////////////////////////////////////////////////////
// Hit test functions
//////////////////////////////////////////////////////////////////////////
bool Puzzle::hitTest(const int16 (*polygonPoint)[2], const Common::Point &point, uint32 index) const {
Common::Point p1(polygonPoint[index + 0][0], polygonPoint[index + 0][1]),
p2(polygonPoint[index + 1][0], polygonPoint[index + 1][1]),
p3(polygonPoint[index + 2][0], polygonPoint[index + 2][1]),
p4(polygonPoint[index + 3][0], polygonPoint[index + 3][1]);
Polygon polygon(p1, p2, p3, p4);
return polygon.contains(point);
}
bool Puzzle::hitTest(const int16 (*polygonPoint)[2], const Common::Point &point) const {
return hitTest(polygonPoint, point, 0);
}
} // end of namespace Asylum
|