aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
authorMatthew Hoops2011-09-17 12:03:48 -0400
committerMatthew Hoops2011-09-17 12:04:21 -0400
commit544224b43aa0f7d74e40fc11c18dbbb8bb7dfd81 (patch)
treeabcb9fbeb40016e8aac36c214d94147a0532ce06 /engines
parent3b9ab4f5cf6a868300e49067ec116ca8b15903c8 (diff)
downloadscummvm-rg350-544224b43aa0f7d74e40fc11c18dbbb8bb7dfd81.tar.gz
scummvm-rg350-544224b43aa0f7d74e40fc11c18dbbb8bb7dfd81.tar.bz2
scummvm-rg350-544224b43aa0f7d74e40fc11c18dbbb8bb7dfd81.zip
PEGASUS: Add transition classes
Diffstat (limited to 'engines')
-rw-r--r--engines/pegasus/module.mk1
-rwxr-xr-xengines/pegasus/transition.cpp150
-rwxr-xr-xengines/pegasus/transition.h105
-rwxr-xr-xengines/pegasus/util.h2
4 files changed, 258 insertions, 0 deletions
diff --git a/engines/pegasus/module.mk b/engines/pegasus/module.mk
index ca262cbc98..01c069e1ee 100644
--- a/engines/pegasus/module.mk
+++ b/engines/pegasus/module.mk
@@ -17,6 +17,7 @@ MODULE_OBJS = \
pegasus.o \
sound.o \
timers.o \
+ transition.o \
util.o \
video.o \
items/inventory.o \
diff --git a/engines/pegasus/transition.cpp b/engines/pegasus/transition.cpp
new file mode 100755
index 0000000000..20b9959358
--- /dev/null
+++ b/engines/pegasus/transition.cpp
@@ -0,0 +1,150 @@
+/* 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.
+ *
+ * Additional copyright for this file:
+ * Copyright (C) 1995-1997 Presto Studios, Inc.
+ *
+ * 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 "common/system.h"
+
+#include "pegasus/transition.h"
+
+namespace Pegasus {
+
+ScreenFader::ScreenFader() {
+ _fadeTarget = getBlack();
+ // Initially, assume screens are on at full brightness.
+ Fader::setFaderValue(100);
+}
+
+void ScreenFader::doFadeOutSync(const TimeValue duration, const TimeValue scale, const uint32 fadeTarget) {
+ _fadeTarget = fadeTarget;
+
+ FaderMoveSpec spec;
+ spec.makeTwoKnotFaderSpec(scale, 0, getFaderValue(), duration, 0);
+ startFaderSync(spec);
+}
+
+void ScreenFader::doFadeInSync(const TimeValue duration, const TimeValue scale, const uint32 fadeTarget) {
+ _fadeTarget = fadeTarget;
+
+ FaderMoveSpec spec;
+ spec.makeTwoKnotFaderSpec(scale, 0, getFaderValue(), duration, 100);
+ startFaderSync(spec);
+}
+
+void ScreenFader::setFaderValue(const uint32 value) {
+ if (value != getFaderValue()) {
+ Fader::setFaderValue(value);
+
+ // TODO: Gamma fading
+ }
+}
+
+uint32 ScreenFader::getBlack() {
+ return g_system->getScreenFormat().RGBToColor(0, 0, 0);
+}
+
+Transition::Transition(const tDisplayElementID id) : FaderAnimation(id) {
+ _outPicture = 0;
+ _inPicture = 0;
+}
+
+void Transition::setBounds(const Common::Rect &r) {
+ FaderAnimation::setBounds(r);
+ _boundsWidth = _bounds.width();
+ _boundsHeight = _bounds.height();
+}
+
+void Transition::setInAndOutElements(DisplayElement *inElement, DisplayElement *outElement) {
+ _inPicture = inElement;
+ _outPicture = outElement;
+
+ Common::Rect r;
+
+ if (_outPicture)
+ _outPicture->getBounds(r);
+ else if (_inPicture)
+ _inPicture->getBounds(r);
+
+ setBounds(r);
+}
+
+void Slide::draw(const Common::Rect &r) {
+ Common::Rect oldBounds, newBounds;
+
+ adjustSlideRects(oldBounds, newBounds);
+ drawElements(r, oldBounds, newBounds);
+}
+
+void Slide::adjustSlideRects(Common::Rect &oldBounds, Common::Rect &newBounds) {
+ oldBounds = _bounds;
+ newBounds = _bounds;
+}
+
+void Slide::drawElements(const Common::Rect &drawRect, const Common::Rect &oldBounds, const Common::Rect &newBounds) {
+ drawSlideElement(drawRect, oldBounds, _outPicture);
+ drawSlideElement(drawRect, newBounds, _inPicture);
+}
+
+void Slide::drawSlideElement(const Common::Rect &drawRect, const Common::Rect &oldBounds, DisplayElement *picture) {
+ if (picture && drawRect.intersects(oldBounds)) {
+ picture->moveElementTo(oldBounds.left, oldBounds.top);
+ picture->draw(drawRect.findIntersectingRect(oldBounds));
+ }
+}
+
+void Push::adjustSlideRects(Common::Rect &oldBounds, Common::Rect &newBounds) {
+ switch (_direction & kSlideHorizMask) {
+ case kSlideLeftMask:
+ newBounds.left = oldBounds.right = _bounds.right - pegasusRound(getFaderValue() * _boundsWidth, kTransitionRange);
+ newBounds.right = newBounds.left + _boundsWidth;
+ oldBounds.left = oldBounds.right - _boundsWidth;
+ break;
+ case kSlideRightMask:
+ oldBounds.left = newBounds.right = _bounds.left + pegasusRound(getFaderValue() * _boundsWidth, kTransitionRange);
+ oldBounds.right = oldBounds.left + _boundsWidth;
+ newBounds.left = newBounds.right - _boundsWidth;
+ break;
+ default:
+ newBounds.left = oldBounds.left = _bounds.left;
+ newBounds.right = oldBounds.right = _bounds.right;
+ break;
+ }
+ switch (_direction & kSlideVertMask) {
+ case kSlideDownMask:
+ oldBounds.top = newBounds.bottom = _bounds.top + pegasusRound(getFaderValue() * _boundsHeight, kTransitionRange);
+ oldBounds.bottom = oldBounds.top + _boundsHeight;
+ newBounds.top = newBounds.bottom - _boundsHeight;
+ break;
+ case kSlideUpMask:
+ newBounds.top = oldBounds.bottom = _bounds.bottom - pegasusRound(getFaderValue() * _boundsHeight, kTransitionRange);
+ newBounds.bottom = newBounds.top + _boundsHeight;
+ oldBounds.top = oldBounds.bottom - _boundsHeight;
+ break;
+ default:
+ newBounds.top = oldBounds.top = _bounds.top;
+ newBounds.bottom = oldBounds.bottom = _bounds.bottom;
+ break;
+ }
+}
+
+} // End of namespace Pegasus
diff --git a/engines/pegasus/transition.h b/engines/pegasus/transition.h
new file mode 100755
index 0000000000..d34f3184d4
--- /dev/null
+++ b/engines/pegasus/transition.h
@@ -0,0 +1,105 @@
+/* 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.
+ *
+ * Additional copyright for this file:
+ * Copyright (C) 1995-1997 Presto Studios, Inc.
+ *
+ * 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.
+ *
+ */
+
+#ifndef PEGASUS_TRANSITION_H
+#define PEGASUS_TRANSITION_H
+
+#include "pegasus/fader.h"
+
+namespace Pegasus {
+
+class ScreenFader : public Fader {
+public:
+ ScreenFader();
+ virtual ~ScreenFader() {}
+
+ void doFadeOutSync(const TimeValue = kOneSecondPerThirtyTicks, const TimeScale = kThirtyTicksPerSecond, const uint32 = getBlack());
+ void doFadeInSync(const TimeValue = kHalfSecondPerThirtyTicks, const TimeScale = kThirtyTicksPerSecond, const uint32 = getBlack());
+
+ void setFaderValue(const uint32);
+
+protected:
+ uint32 _fadeTarget;
+
+private:
+ static uint32 getBlack();
+};
+
+// Transitions are faders that range over [0,1000], which makes their
+// "resolution" one tenth of a percent
+
+const long kTransitionBottom = 0;
+const long kTransitionTop = 1000;
+
+const long kTransitionRange = kTransitionTop - kTransitionBottom;
+
+class Transition : public FaderAnimation {
+public:
+ Transition(const tDisplayElementID id);
+ virtual ~Transition() {}
+
+ virtual void setBounds(const Common::Rect &);
+
+ virtual void setInAndOutElements(DisplayElement *, DisplayElement *);
+ DisplayElement *getInElement() { return _inPicture; }
+ DisplayElement *getOutElement() { return _outPicture; }
+
+protected:
+ DisplayElement *_outPicture;
+ DisplayElement *_inPicture;
+
+ tCoordType _boundsWidth, _boundsHeight;
+};
+
+class Slide : public Transition {
+public:
+ Slide(const tDisplayElementID id) : Transition(id) {}
+ virtual ~Slide() {}
+
+ virtual void setSlideDirection(tSlideDirection dir) { _direction = dir; }
+ virtual void draw(const Common::Rect &);
+
+ virtual void setDirection(const tSlideDirection dir) { _direction = dir; }
+
+protected:
+ virtual void adjustSlideRects(Common::Rect &, Common::Rect &);
+ virtual void drawElements(const Common::Rect &, const Common::Rect &, const Common::Rect &);
+ virtual void drawSlideElement(const Common::Rect &, const Common::Rect &, DisplayElement *);
+
+ tSlideDirection _direction;
+};
+
+class Push : public Slide {
+public:
+ Push(const tDisplayElementID id) : Slide(id) {}
+ virtual ~Push() {}
+
+protected:
+ virtual void adjustSlideRects(Common::Rect &, Common::Rect &);
+};
+
+} // End of namespace Pegasus
+
+#endif \ No newline at end of file
diff --git a/engines/pegasus/util.h b/engines/pegasus/util.h
index 83c0c33324..459c1380cb 100755
--- a/engines/pegasus/util.h
+++ b/engines/pegasus/util.h
@@ -67,6 +67,8 @@ int32 linearInterp(const int32 start1, const int32 stop1, const int32 current1,
void shuffleArray(int32 *arr, int32 count, Common::RandomSource &random);
+int32 pegasusRound(const int32 a, const int32 b);
+
} // End of namespace Pegasus
#endif