aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
authorPaul Gilbert2014-01-18 14:38:33 -0500
committerPaul Gilbert2014-01-18 14:38:33 -0500
commitf084539957e461cd74179008f81791fd29f0d311 (patch)
treef50f3d4127519e8234178a8461160f8a54fc9d13 /engines
parente387b016c02fcec0e5f4446f1a1064e6b0171e08 (diff)
downloadscummvm-rg350-f084539957e461cd74179008f81791fd29f0d311.tar.gz
scummvm-rg350-f084539957e461cd74179008f81791fd29f0d311.tar.bz2
scummvm-rg350-f084539957e461cd74179008f81791fd29f0d311.zip
VOYEUR: Converted drawText and textWidth to work on PictureResource
Diffstat (limited to 'engines')
-rw-r--r--engines/voyeur/files.cpp427
-rw-r--r--engines/voyeur/files.h16
-rw-r--r--engines/voyeur/graphics.cpp2
-rw-r--r--engines/voyeur/graphics.h1
4 files changed, 231 insertions, 215 deletions
diff --git a/engines/voyeur/files.cpp b/engines/voyeur/files.cpp
index b776483b36..3de0d88621 100644
--- a/engines/voyeur/files.cpp
+++ b/engines/voyeur/files.cpp
@@ -785,6 +785,221 @@ bool DisplayResource::clipRect(Common::Rect &rect) {
return true;
}
+int DisplayResource::drawText(const Common::String &msg) {
+ GraphicsManager &gfxManager = _vm->_graphicsManager;
+ assert(gfxManager._fontPtr);
+ assert(gfxManager._fontPtr->_curFont);
+ FontInfoResource &fontInfo = *gfxManager._fontPtr;
+ PictureResource &fontChar = *_vm->_graphicsManager._fontChar;
+ FontResource &fontData = *fontInfo._curFont;
+ int xShadows[9] = { 0, 1, 1, 1, 0, -1, -1, -1, 0 };
+ int yShadows[9] = { 0, 1, 0, -1, -1, -1, 0, 1, 1 };
+
+ Common::Rect *clipPtr = gfxManager._clipPtr;
+ if (!(fontInfo._picFlags & DISPFLAG_1))
+ gfxManager._clipPtr = NULL;
+
+ int minChar = fontData._minChar;
+ int padding = fontData._padding;
+ int fontHeight = fontData._fontHeight;
+ int totalChars = fontData._maxChar - fontData._minChar;
+ int msgWidth = 0;
+ int xp = 0, yp = 0;
+
+ Common::Point pos = Common::Point(fontInfo._pos.x, fontInfo._pos.y + fontData._topPadding);
+
+ fontChar._flags = fontInfo._picFlags | DISPFLAG_2;
+ fontChar._select = fontInfo._picSelect;
+ fontChar._bounds.setHeight(fontHeight);
+
+ ViewPortResource *viewPort = !(_flags & DISPFLAG_VIEWPORT) ? NULL :
+ (ViewPortResource *)this;
+
+ if (gfxManager._drawTextPermFlag || (fontInfo._fontFlags & DISPFLAG_1) || fontInfo._justify ||
+ (gfxManager._saveBack && fontInfo._fontSaveBack && (_flags & DISPFLAG_VIEWPORT))) {
+ msgWidth = viewPort->textWidth(msg);
+ yp = pos.y;
+ xp = pos.x;
+
+ switch (fontInfo._justify) {
+ case 1:
+ xp = pos.x + (fontInfo._justifyWidth / 2) - (msgWidth / 2);
+ break;
+ case 2:
+ xp = pos.x + fontInfo._justifyWidth - msgWidth;
+ break;
+ default:
+ break;
+ }
+
+ if (!(fontInfo._fontFlags & 3)) {
+ viewPort->_fontRect.left = xp;
+ viewPort->_fontRect.top = yp;
+ viewPort->_fontRect.setWidth(msgWidth);
+ viewPort->_fontRect.setHeight(fontHeight);
+ } else {
+ viewPort->_fontRect.left = pos.x;
+ viewPort->_fontRect.top = pos.y;
+ viewPort->_fontRect.setWidth(fontInfo._justifyWidth);
+ viewPort->_fontRect.setHeight(fontInfo._justifyHeight);
+ }
+
+ pos.x = xp;
+ pos.y = yp;
+
+ if (fontInfo._fontFlags & 4) {
+ if (fontInfo._shadow.x <= 0) {
+ viewPort->_fontRect.left += fontInfo._shadow.x;
+ viewPort->_fontRect.right -= fontInfo._shadow.x * 2;
+ } else {
+ viewPort->_fontRect.right += fontInfo._shadow.x;
+ }
+
+ if (fontInfo._shadow.y <= 0) {
+ viewPort->_fontRect.top += fontInfo._shadow.y;
+ viewPort->_fontRect.bottom -= fontInfo._shadow.y * 2;
+ } else {
+ viewPort->_fontRect.bottom += fontInfo._shadow.y;
+ }
+ } else if (fontInfo._fontFlags & 8) {
+ if (fontInfo._shadow.x <= 0) {
+ viewPort->_fontRect.left += fontInfo._shadow.x;
+ viewPort->_fontRect.right -= fontInfo._shadow.x * 3;
+ } else {
+ viewPort->_fontRect.right += fontInfo._shadow.x * 3;
+ viewPort->_fontRect.left -= fontInfo._shadow.x;
+ }
+
+ if (fontInfo._shadow.y <= 0) {
+ viewPort->_fontRect.top += fontInfo._shadow.y;
+ viewPort->_fontRect.bottom -= fontInfo._shadow.y * 3;
+ } else {
+ viewPort->_fontRect.bottom += fontInfo._shadow.y * 3;
+ viewPort->_fontRect.top -= fontInfo._shadow.y;
+ }
+ }
+ }
+
+ if (gfxManager._saveBack && fontInfo._fontSaveBack && (_flags & DISPFLAG_VIEWPORT)) {
+ viewPort->addSaveRect(viewPort->_pageIndex, viewPort->_fontRect);
+ }
+
+ if (fontInfo._fontFlags & DISPFLAG_1) {
+ gfxManager._drawPtr->_pos = Common::Point(viewPort->_fontRect.left, viewPort->_fontRect.top);
+ gfxManager._drawPtr->_penColor = fontInfo._backColor;
+ sFillBox(viewPort->_fontRect.width(), viewPort->_fontRect.height());
+ }
+
+ bool saveBack = gfxManager._saveBack;
+ gfxManager._saveBack = false;
+
+ int count = 0;
+ if (fontInfo._fontFlags & DISPFLAG_4)
+ count = 1;
+ else if (fontInfo._fontFlags & DISPFLAG_8)
+ count = 8;
+
+ for (int i = count; i >= 0; --i) {
+ xp = pos.x;
+ yp = pos.y;
+
+ switch (xShadows[i]) {
+ case -1:
+ xp -= fontInfo._shadow.x;
+ break;
+ case 1:
+ xp += fontInfo._shadow.x;
+ break;
+ default:
+ break;
+ }
+
+ switch (yShadows[i]) {
+ case -1:
+ yp -= fontInfo._shadow.y;
+ break;
+ case 1:
+ yp += fontInfo._shadow.y;
+ break;
+ default:
+ break;
+ }
+
+ if (i != 0) {
+ fontChar._pick = 0;
+ fontChar._onOff = fontInfo._shadowColor;
+ } else if (fontData.field2 == 1 || (fontInfo._fontFlags & 0x10)) {
+ fontChar._pick = 0;
+ fontChar._onOff = fontInfo._foreColor;
+ } else {
+ fontChar._pick = fontInfo._picPick;
+ fontChar._onOff = fontInfo._picOnOff;
+ fontChar._depth = fontData.field2;
+ }
+
+ // Loop to draw each character in turn
+ msgWidth = -padding;
+ const char *msgP = msg.c_str();
+ char ch;
+
+ while ((ch = *msgP++) != '\0') {
+ int charValue = (int)ch - minChar;
+ if (charValue < 0 || charValue >= totalChars || fontData._charWidth[charValue] == 0)
+ charValue = fontData._maxChar - minChar;
+
+ int charWidth = fontData._charWidth[charValue];
+ fontChar._bounds.setWidth(charWidth);
+
+ uint16 offset = READ_LE_UINT16(fontData._charOffsets + charValue * 2);
+ fontChar._imgData = fontData._charImages + offset * 2;
+
+ gfxManager.sDrawPic(&fontChar, this, Common::Point(xp, yp));
+
+ fontChar._imgData = NULL;
+ xp += charWidth + padding;
+ msgWidth += charWidth + padding;
+ }
+ }
+
+ msgWidth = MAX(msgWidth, 0);
+ if (fontInfo._justify == ALIGN_LEFT)
+ fontInfo._pos.x = xp;
+
+ gfxManager._saveBack = saveBack;
+ gfxManager._clipPtr = clipPtr;
+
+ return msgWidth;
+}
+
+int DisplayResource::textWidth(const Common::String &msg) {
+ if (msg.size() == 0)
+ return 0;
+
+ const char *msgP = msg.c_str();
+ FontResource &fontData = *_vm->_graphicsManager._fontPtr->_curFont;
+ int minChar = fontData._minChar;
+ int maxChar = fontData._maxChar;
+ int padding = fontData._padding;
+ int totalWidth = -padding;
+ char ch;
+
+ // Loop through the characters
+ while ((ch = *msgP++) != '\0') {
+ int charValue = (int)ch;
+ if (charValue < minChar || charValue > maxChar)
+ charValue = maxChar;
+
+ if (!fontData._charWidth[charValue - minChar])
+ charValue = maxChar;
+
+ totalWidth += fontData._charWidth[charValue - minChar] + padding;
+ }
+
+ if (totalWidth < 0)
+ totalWidth = 0;
+ return totalWidth;
+}
+
/*------------------------------------------------------------------------*/
PictureResource::PictureResource(BoltFilesState &state, const byte *src):
@@ -979,7 +1194,6 @@ void PictureResource::flipVertical(const byte *data) {
/*------------------------------------------------------------------------*/
ViewPortResource::ViewPortResource(BoltFilesState &state, const byte *src):
- _fontChar(0, 0xff, 0xff, 0, 0, Common::Rect(), 0, NULL, 0),
_state(state), DisplayResource(state._vm) {
_flags = READ_LE_UINT16(src);
_parent = NULL;
@@ -1123,217 +1337,6 @@ void ViewPortResource::setupViewPort(PictureResource *pic, Common::Rect *clipRec
&GraphicsManager::restoreMCGASaveRect);
}
-int ViewPortResource::drawText(const Common::String &msg) {
- GraphicsManager &gfxManager = _state._vm->_graphicsManager;
- assert(gfxManager._fontPtr);
- assert(gfxManager._fontPtr->_curFont);
- FontInfoResource &fontInfo = *gfxManager._fontPtr;
- FontResource &fontData = *fontInfo._curFont;
- int xShadows[9] = { 0, 1, 1, 1, 0, -1, -1, -1, 0 };
- int yShadows[9] = { 0, 1, 0, -1, -1, -1, 0, 1, 1 };
-
- Common::Rect *clipPtr = gfxManager._clipPtr;
- if (!(fontInfo._picFlags & DISPFLAG_1))
- gfxManager._clipPtr = NULL;
-
- int minChar = fontData._minChar;
- int padding = fontData._padding;
- int fontHeight = fontData._fontHeight;
- int totalChars = fontData._maxChar - fontData._minChar;
- int msgWidth = 0;
- int xp = 0, yp = 0;
-
- Common::Point pos = Common::Point(fontInfo._pos.x, fontInfo._pos.y + fontData._topPadding);
-
- _fontChar._flags = fontInfo._picFlags | DISPFLAG_2;
- _fontChar._select = fontInfo._picSelect;
- _fontChar._bounds.setHeight(fontHeight);
-
- if (gfxManager._drawTextPermFlag || (fontInfo._fontFlags & DISPFLAG_1) || fontInfo._justify ||
- (gfxManager._saveBack && fontInfo._fontSaveBack && (_flags & DISPFLAG_VIEWPORT))) {
- msgWidth = textWidth(msg);
- yp = pos.y;
- xp = pos.x;
-
- switch (fontInfo._justify) {
- case 1:
- xp = pos.x + (fontInfo._justifyWidth / 2) - (msgWidth / 2);
- break;
- case 2:
- xp = pos.x + fontInfo._justifyWidth - msgWidth;
- break;
- default:
- break;
- }
-
- if (!(fontInfo._fontFlags & 3)) {
- _fontRect.left = xp;
- _fontRect.top = yp;
- _fontRect.setWidth(msgWidth);
- _fontRect.setHeight(fontHeight);
- } else {
- _fontRect.left = pos.x;
- _fontRect.top = pos.y;
- _fontRect.setWidth(fontInfo._justifyWidth);
- _fontRect.setHeight(fontInfo._justifyHeight);
- }
-
- pos.x = xp;
- pos.y = yp;
-
- if (fontInfo._fontFlags & 4) {
- if (fontInfo._shadow.x <= 0) {
- _fontRect.left += fontInfo._shadow.x;
- _fontRect.right -= fontInfo._shadow.x * 2;
- } else {
- _fontRect.right += fontInfo._shadow.x;
- }
-
- if (fontInfo._shadow.y <= 0) {
- _fontRect.top += fontInfo._shadow.y;
- _fontRect.bottom -= fontInfo._shadow.y * 2;
- } else {
- _fontRect.bottom += fontInfo._shadow.y;
- }
- } else if (fontInfo._fontFlags & 8) {
- if (fontInfo._shadow.x <= 0) {
- _fontRect.left += fontInfo._shadow.x;
- _fontRect.right -= fontInfo._shadow.x * 3;
- } else {
- _fontRect.right += fontInfo._shadow.x * 3;
- _fontRect.left -= fontInfo._shadow.x;
- }
-
- if (fontInfo._shadow.y <= 0) {
- _fontRect.top += fontInfo._shadow.y;
- _fontRect.bottom -= fontInfo._shadow.y * 3;
- } else {
- _fontRect.bottom += fontInfo._shadow.y * 3;
- _fontRect.top -= fontInfo._shadow.y;
- }
- }
- }
-
- if (gfxManager._saveBack && fontInfo._fontSaveBack && (_flags & DISPFLAG_VIEWPORT)) {
- addSaveRect(_pageIndex, _fontRect);
- }
-
- if (fontInfo._fontFlags & DISPFLAG_1) {
- gfxManager._drawPtr->_pos = Common::Point(_fontRect.left, _fontRect.top);
- gfxManager._drawPtr->_penColor = fontInfo._backColor;
- sFillBox(_fontRect.width(), _fontRect.height());
- }
-
- bool saveBack = gfxManager._saveBack;
- gfxManager._saveBack = false;
-
- int count = 0;
- if (fontInfo._fontFlags & DISPFLAG_4)
- count = 1;
- else if (fontInfo._fontFlags & DISPFLAG_8)
- count = 8;
-
- for (int i = count; i >= 0; --i) {
- xp = pos.x;
- yp = pos.y;
-
- switch (xShadows[i]) {
- case -1:
- xp -= fontInfo._shadow.x;
- break;
- case 1:
- xp += fontInfo._shadow.x;
- break;
- default:
- break;
- }
-
- switch (yShadows[i]) {
- case -1:
- yp -= fontInfo._shadow.y;
- break;
- case 1:
- yp += fontInfo._shadow.y;
- break;
- default:
- break;
- }
-
- if (i != 0) {
- _fontChar._pick = 0;
- _fontChar._onOff = fontInfo._shadowColor;
- } else if (fontData.field2 == 1 || (fontInfo._fontFlags & 0x10)) {
- _fontChar._pick = 0;
- _fontChar._onOff = fontInfo._foreColor;
- } else {
- _fontChar._pick = fontInfo._picPick;
- _fontChar._onOff = fontInfo._picOnOff;
- _fontChar._depth = fontData.field2;
- }
-
- // Loop to draw each character in turn
- msgWidth = -padding;
- const char *msgP = msg.c_str();
- char ch;
-
- while ((ch = *msgP++) != '\0') {
- int charValue = (int)ch - minChar;
- if (charValue < 0 || charValue >= totalChars || fontData._charWidth[charValue] == 0)
- charValue = fontData._maxChar - minChar;
-
- int charWidth = fontData._charWidth[charValue];
- _fontChar._bounds.setWidth(charWidth);
-
- uint16 offset = READ_LE_UINT16(fontData._charOffsets + charValue * 2);
- _fontChar._imgData = fontData._charImages + offset * 2;
-
- gfxManager.sDrawPic(&_fontChar, this, Common::Point(xp, yp));
-
- _fontChar._imgData = NULL;
- xp += charWidth + padding;
- msgWidth += charWidth + padding;
- }
- }
-
- msgWidth = MAX(msgWidth, 0);
- if (fontInfo._justify == ALIGN_LEFT)
- fontInfo._pos.x = xp;
-
- gfxManager._saveBack = saveBack;
- gfxManager._clipPtr = clipPtr;
-
- return msgWidth;
-}
-
-int ViewPortResource::textWidth(const Common::String &msg) {
- if (msg.size() == 0)
- return 0;
-
- const char *msgP = msg.c_str();
- FontResource &fontData = *_state._vm->_graphicsManager._fontPtr->_curFont;
- int minChar = fontData._minChar;
- int maxChar = fontData._maxChar;
- int padding = fontData._padding;
- int totalWidth = -padding;
- char ch;
-
- // Loop through the characters
- while ((ch = *msgP++) != '\0') {
- int charValue = (int)ch;
- if (charValue < minChar || charValue > maxChar)
- charValue = maxChar;
-
- if (!fontData._charWidth[charValue - minChar])
- charValue = maxChar;
-
- totalWidth += fontData._charWidth[charValue - minChar] + padding;
- }
-
- if (totalWidth < 0)
- totalWidth = 0;
- return totalWidth;
-}
-
void ViewPortResource::addSaveRect(int pageIndex, const Common::Rect &r) {
// TODO
Common::Rect rect = r;
diff --git a/engines/voyeur/files.h b/engines/voyeur/files.h
index b22aae4980..6cc747d9a1 100644
--- a/engines/voyeur/files.h
+++ b/engines/voyeur/files.h
@@ -261,6 +261,19 @@ public:
*/
void sFillBox(int width, int height);
+ /**
+ * Draw text at the current pen position
+ */
+ int drawText(const Common::String &msg);
+
+ /**
+ * Return the width of a given text in the current font
+ */
+ int textWidth(const Common::String &msg);
+
+ /**
+ * Clip the given rectangle by the currently viewable area
+ */
bool clipRect(Common::Rect &rect);
};
@@ -339,7 +352,6 @@ public:
ViewPortSetupPtr _setupFn;
ViewPortAddPtr _addFn;
ViewPortRestorePtr _restoreFn;
- PictureResource _fontChar;
Common::Rect _fontRect;
public:
ViewPortResource(BoltFilesState &state, const byte *src);
@@ -347,8 +359,6 @@ public:
void setupViewPort();
void setupViewPort(PictureResource *pic, Common::Rect *clipRect = NULL);
- int drawText(const Common::String &msg);
- int textWidth(const Common::String &msg);
void addSaveRect(int pageIndex, const Common::Rect &r);
void fillPic(byte onOff = 0);
void drawIfaceTime();
diff --git a/engines/voyeur/graphics.cpp b/engines/voyeur/graphics.cpp
index 6c62c6f041..4dd4c67b0f 100644
--- a/engines/voyeur/graphics.cpp
+++ b/engines/voyeur/graphics.cpp
@@ -58,6 +58,7 @@ GraphicsManager::GraphicsManager():
_vPort = NULL;
_fontPtr = NULL;
Common::fill(&_VGAColors[0], &_VGAColors[PALETTE_SIZE], 0);
+ _fontChar = new PictureResource(0, 0xff, 0xff, 0, 0, Common::Rect(), 0, NULL, 0);
}
void GraphicsManager::sInitGraphics() {
@@ -70,6 +71,7 @@ void GraphicsManager::sInitGraphics() {
GraphicsManager::~GraphicsManager() {
_screenSurface.free();
+ delete _fontChar;
}
void GraphicsManager::setupMCGASaveRect(ViewPortResource *viewPort) {
diff --git a/engines/voyeur/graphics.h b/engines/voyeur/graphics.h
index ccc20e5df9..6205499ea7 100644
--- a/engines/voyeur/graphics.h
+++ b/engines/voyeur/graphics.h
@@ -81,6 +81,7 @@ public:
Graphics::Surface _screenSurface;
CMapResource *_backColors;
FontInfoResource *_fontPtr;
+ PictureResource *_fontChar;
DrawInfo *_drawPtr;
DrawInfo _defaultDrawInfo;
bool _drawTextPermFlag;