aboutsummaryrefslogtreecommitdiff
path: root/engines/titanic/game/gondolier
diff options
context:
space:
mode:
authorPaul Gilbert2016-08-21 23:07:20 -0400
committerPaul Gilbert2016-08-21 23:07:20 -0400
commit3f32c4a4b9ef1ed6d151da1dbf3c299cc6f533b1 (patch)
tree902e5f7388c7a5e44e5d6a2bdf98f34664e0848d /engines/titanic/game/gondolier
parente7d0047b5334bef6688a5f81c200630a58ff89c4 (diff)
downloadscummvm-rg350-3f32c4a4b9ef1ed6d151da1dbf3c299cc6f533b1.tar.gz
scummvm-rg350-3f32c4a4b9ef1ed6d151da1dbf3c299cc6f533b1.tar.bz2
scummvm-rg350-3f32c4a4b9ef1ed6d151da1dbf3c299cc6f533b1.zip
TITANIC: Implemented CGondolierSlider class
Diffstat (limited to 'engines/titanic/game/gondolier')
-rw-r--r--engines/titanic/game/gondolier/gondolier_slider.cpp199
-rw-r--r--engines/titanic/game/gondolier/gondolier_slider.h25
2 files changed, 193 insertions, 31 deletions
diff --git a/engines/titanic/game/gondolier/gondolier_slider.cpp b/engines/titanic/game/gondolier/gondolier_slider.cpp
index eb6b1a9ad8..e7a46eb33d 100644
--- a/engines/titanic/game/gondolier/gondolier_slider.cpp
+++ b/engines/titanic/game/gondolier/gondolier_slider.cpp
@@ -24,11 +24,24 @@
namespace Titanic {
+static const int ARRAY[11] = { 0, 0, 1, 4, 9, 15, 21, 27, 32, 35, 36 };
+
+BEGIN_MESSAGE_MAP(CGondolierSlider, CGondolierBase)
+ ON_MESSAGE(MouseButtonDownMsg)
+ ON_MESSAGE(MouseDragMoveMsg)
+ ON_MESSAGE(EnterViewMsg)
+ ON_MESSAGE(MouseDragStartMsg)
+ ON_MESSAGE(StatusChangeMsg)
+ ON_MESSAGE(MouseDragEndMsg)
+ ON_MESSAGE(IsHookedOnMsg)
+ ON_MESSAGE(FrameMsg)
+ ON_MESSAGE(SignalObject)
+ ON_MESSAGE(ActMsg)
+END_MESSAGE_MAP()
+
CGondolierSlider::CGondolierSlider() : CGondolierBase(),
_fieldBC(0), _fieldC0(0), _fieldC4(0), _fieldC8(0),
- _fieldCC(0), _fieldD0(0), _fieldD4(0), _fieldD8(0),
- _fieldDC(0), _fieldE0(0), _fieldE4(0), _fieldE8(0),
- _fieldEC(0), _string1("NULL"), _fieldFC(0), _field118(0) {
+ _arrayIndex(0), _string1("NULL"), _fieldFC(0), _field118(0) {
}
void CGondolierSlider::save(SimpleFile *file, int indent) {
@@ -37,15 +50,15 @@ void CGondolierSlider::save(SimpleFile *file, int indent) {
file->writeNumberLine(_fieldC0, indent);
file->writeNumberLine(_fieldC4, indent);
file->writeNumberLine(_fieldC8, indent);
- file->writeNumberLine(_fieldCC, indent);
- file->writeNumberLine(_fieldD0, indent);
- file->writeNumberLine(_fieldD4, indent);
- file->writeNumberLine(_fieldD8, indent);
- file->writeNumberLine(_fieldDC, indent);
- file->writeNumberLine(_fieldE0, indent);
- file->writeNumberLine(_fieldE4, indent);
- file->writeNumberLine(_fieldE8, indent);
- file->writeNumberLine(_fieldCC, indent);
+ file->writeNumberLine(_sliderRect1.left, indent);
+ file->writeNumberLine(_sliderRect1.top, indent);
+ file->writeNumberLine(_sliderRect1.right, indent);
+ file->writeNumberLine(_sliderRect1.bottom, indent);
+ file->writeNumberLine(_sliderRect2.left, indent);
+ file->writeNumberLine(_sliderRect2.top, indent);
+ file->writeNumberLine(_sliderRect2.right, indent);
+ file->writeNumberLine(_sliderRect2.bottom, indent);
+ file->writeNumberLine(_sliderRect1.left, indent);
file->writeQuotedLine(_string1, indent);
file->writeNumberLine(_fieldFC, indent);
file->writeQuotedLine(_string2, indent);
@@ -61,15 +74,15 @@ void CGondolierSlider::load(SimpleFile *file) {
_fieldC0 = file->readNumber();
_fieldC4 = file->readNumber();
_fieldC8 = file->readNumber();
- _fieldCC = file->readNumber();
- _fieldD0 = file->readNumber();
- _fieldD4 = file->readNumber();
- _fieldD8 = file->readNumber();
- _fieldDC = file->readNumber();
- _fieldE0 = file->readNumber();
- _fieldE4 = file->readNumber();
- _fieldE8 = file->readNumber();
- _fieldEC = file->readNumber();
+ _sliderRect1.left = file->readNumber();
+ _sliderRect1.top = file->readNumber();
+ _sliderRect1.right = file->readNumber();
+ _sliderRect1.bottom = file->readNumber();
+ _sliderRect2.left = file->readNumber();
+ _sliderRect2.top = file->readNumber();
+ _sliderRect2.right = file->readNumber();
+ _sliderRect2.bottom = file->readNumber();
+ _arrayIndex = file->readNumber();
_string1 = file->readString();
_fieldFC = file->readNumber();
_string2 = file->readString();
@@ -79,4 +92,148 @@ void CGondolierSlider::load(SimpleFile *file) {
CGondolierBase::load(file);
}
+bool CGondolierSlider::MouseButtonDownMsg(CMouseButtonDownMsg *msg) {
+ if (!_v1)
+ return false;
+ if (_fieldFC ? _v5 : _v8)
+ return false;
+
+ return _sliderRect1.contains(msg->_mousePos);
+}
+
+bool CGondolierSlider::MouseDragMoveMsg(CMouseDragMoveMsg *msg) {
+ if (!(_fieldFC ? _v5 : _v8)) {
+ int minVal = 0x7FFFFFFF;
+ int foundIndex = -1;
+ int yp = (_sliderRect2.top + _sliderRect2.bottom) / 2
+ + _bounds.top - msg->_mousePos.y;
+
+ for (int idx = 0; idx < 11; ++idx) {
+ int yv = yp + ARRAY[idx];
+ if (yv < 0)
+ yv = -yv;
+ if (yv < minVal) {
+ minVal = yv;
+ foundIndex = idx;
+ }
+ }
+
+ if (foundIndex >= 0) {
+ _arrayIndex = foundIndex;
+ CSignalObject signalMsg;
+ signalMsg.execute(this);
+ }
+ }
+
+ return true;
+}
+
+bool CGondolierSlider::EnterViewMsg(CEnterViewMsg *msg) {
+ CSignalObject signalMsg;
+ signalMsg.execute(this);
+ return true;
+}
+
+bool CGondolierSlider::MouseDragStartMsg(CMouseDragStartMsg *msg) {
+ if (!_v1)
+ return false;
+ if (_fieldFC ? _v5 : _v8)
+ return false;
+
+ _field118 = checkStartDragging(msg);
+ return _field118;
+}
+
+bool CGondolierSlider::StatusChangeMsg(CStatusChangeMsg *msg) {
+ _arrayIndex = CLIP(10 - msg->_newStatus, 0, 10);
+ _sliderRect1 = _sliderRect2;
+ _sliderRect1.translate(_bounds.left, _bounds.top);
+ _sliderRect1.translate(0, ARRAY[_arrayIndex]);
+
+ loadFrame(_arrayIndex);
+ return true;
+}
+
+bool CGondolierSlider::MouseDragEndMsg(CMouseDragEndMsg *msg) {
+ _field118 = false;
+ return true;
+}
+
+bool CGondolierSlider::IsHookedOnMsg(CIsHookedOnMsg *msg) {
+ if (_fieldFC ? _v5 : _v8)
+ return false;
+
+ if (!_sliderRect1.intersects(msg->_rect)) {
+ _string2 = CString();
+ msg->_result = false;
+ } else {
+ _string2 = _string1;
+ if (_fieldFC) {
+ _v5 = _v9 = 1;
+ } else {
+ _v8 = _v10 = 1;
+ }
+
+ msg->_result = true;
+ }
+
+ return true;
+}
+
+bool CGondolierSlider::FrameMsg(CFrameMsg *msg) {
+ if (_fieldFC ? _v5 : _v8) {
+ if (_arrayIndex < 10) {
+ ++_arrayIndex;
+ CSignalObject signalMsg;
+ signalMsg.execute(this);
+
+ int yp = 0;
+ if (_arrayIndex > 0)
+ yp = ARRAY[_arrayIndex] - ARRAY[_arrayIndex - 1];
+
+ if (!_string2.empty()) {
+ CTranslateObjectMsg transMsg;
+ transMsg._delta = Point(0, yp);
+ transMsg.execute(_string2);
+ }
+ }
+ } else if (_fieldFC ? _v10 : _v9) {
+ if (!_field118 && !_puzzleSolved && _arrayIndex > 0) {
+ CSignalObject signalMsg;
+ signalMsg.execute(this);
+ }
+ }
+
+ return true;
+}
+
+bool CGondolierSlider::SignalObject(CSignalObject *msg) {
+ _arrayIndex = CLIP(_arrayIndex, 0, 10);
+ _sliderRect1 = _sliderRect2;
+ _sliderRect1.translate(_bounds.left, _bounds.top);
+ _sliderRect1.translate(0, ARRAY[_arrayIndex]);
+ loadFrame(_arrayIndex);
+
+ CSignalObject signalMsg;
+ signalMsg._numValue = 10 - _arrayIndex;
+ signalMsg._strValue = _fieldFC ? "Fly" : "Tos";
+ signalMsg.execute(_string3);
+
+ return true;
+}
+
+bool CGondolierSlider::ActMsg(CActMsg *msg) {
+ if (msg->_action == "Unhook") {
+ if (_fieldFC) {
+ _v5 = _v9 = 0;
+ _v10 = _v8;
+ } else {
+ _v8 = _v10 = 0;
+ _v9 = _v5;
+ }
+ }
+
+ return true;
+}
+
} // End of namespace Titanic
diff --git a/engines/titanic/game/gondolier/gondolier_slider.h b/engines/titanic/game/gondolier/gondolier_slider.h
index 0ae14a91a0..d1562f5b2d 100644
--- a/engines/titanic/game/gondolier/gondolier_slider.h
+++ b/engines/titanic/game/gondolier/gondolier_slider.h
@@ -28,25 +28,30 @@
namespace Titanic {
class CGondolierSlider : public CGondolierBase {
+ DECLARE_MESSAGE_MAP;
+ bool MouseButtonDownMsg(CMouseButtonDownMsg *msg);
+ bool MouseDragMoveMsg(CMouseDragMoveMsg *msg);
+ bool EnterViewMsg(CEnterViewMsg *msg);
+ bool MouseDragStartMsg(CMouseDragStartMsg *msg);
+ bool StatusChangeMsg(CStatusChangeMsg *msg);
+ bool MouseDragEndMsg(CMouseDragEndMsg *msg);
+ bool IsHookedOnMsg(CIsHookedOnMsg *msg);
+ bool FrameMsg(CFrameMsg *msg);
+ bool SignalObject(CSignalObject *msg);
+ bool ActMsg(CActMsg *msg);
private:
int _fieldBC;
int _fieldC0;
int _fieldC4;
int _fieldC8;
- int _fieldCC;
- int _fieldD0;
- int _fieldD4;
- int _fieldD8;
- int _fieldDC;
- int _fieldE0;
- int _fieldE4;
- int _fieldE8;
- int _fieldEC;
+ Rect _sliderRect1;
+ Rect _sliderRect2;
+ int _arrayIndex;
CString _string1;
int _fieldFC;
CString _string2;
CString _string3;
- int _field118;
+ bool _field118;
public:
CLASSDEF;
CGondolierSlider();