aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/dm/text.cpp52
1 files changed, 23 insertions, 29 deletions
diff --git a/engines/dm/text.cpp b/engines/dm/text.cpp
index 00049bb878..b92b43477d 100644
--- a/engines/dm/text.cpp
+++ b/engines/dm/text.cpp
@@ -190,43 +190,37 @@ void TextMan::moveCursor(int16 column, int16 row) {
}
void TextMan::clearExpiredRows() {
- uint16 L0026_ui_RowIndex;
- int32 L0027_l_ExpirationTime;
- Box L0028_s_Box;
-
_vm->_displayMan->_useByteBoxCoordinates = false;
- L0028_s_Box._x1 = 0;
- L0028_s_Box._x2 = 319;
- for (L0026_ui_RowIndex = 0; L0026_ui_RowIndex < 4; L0026_ui_RowIndex++) {
- L0027_l_ExpirationTime = _messageAreaRowExpirationTime[L0026_ui_RowIndex];
- if ((L0027_l_ExpirationTime == -1) || (L0027_l_ExpirationTime > _vm->_gameTime) || _isScrolling)
+ Box displayBox;
+ displayBox._x1 = 0;
+ displayBox._x2 = 319;
+ for (uint16 rowIndex = 0; rowIndex < 4; rowIndex++) {
+ int32 expirationTime = _messageAreaRowExpirationTime[rowIndex];
+ if ((expirationTime == -1) || (expirationTime > _vm->_gameTime) || _isScrolling)
continue;
- L0028_s_Box._y2 = (L0028_s_Box._y1 = 172 + (L0026_ui_RowIndex * 7)) + 6;
+ displayBox._y2 = (displayBox._y1 = 172 + (rowIndex * 7)) + 6;
isTextScrolling(&_textScroller, true);
- _vm->_displayMan->fillBoxBitmap(_vm->_displayMan->_bitmapScreen, L0028_s_Box, k0_ColorBlack, k160_byteWidthScreen, k200_heightScreen);
- _messageAreaRowExpirationTime[L0026_ui_RowIndex] = -1;
+ _vm->_displayMan->fillBoxBitmap(_vm->_displayMan->_bitmapScreen, displayBox, k0_ColorBlack, k160_byteWidthScreen, k200_heightScreen);
+ _messageAreaRowExpirationTime[rowIndex] = -1;
}
}
void TextMan::printEndGameString(int16 x, int16 y, Color textColor, char* text) {
- char* L1407_pc_Character;
- char L1408_ac_ModifiedString[50];
-
- L1407_pc_Character = L1408_ac_ModifiedString;
- *L1407_pc_Character = *text++;
- while (*L1407_pc_Character) {
- if ((*L1407_pc_Character >= 'A') && (*L1407_pc_Character <= 'Z')) {
- *L1407_pc_Character -= 64; /* Use the same font as the one used for scrolls */
- }
- L1407_pc_Character++;
- *L1407_pc_Character = *text++;
+ char modifiedString[50];
+
+ char *wrkStringPtr = modifiedString;
+ *wrkStringPtr = *text++;
+ while (*wrkStringPtr) {
+ if ((*wrkStringPtr >= 'A') && (*wrkStringPtr <= 'Z'))
+ *wrkStringPtr -= 64; /* Use the same font as the one used for scrolls */
+
+ wrkStringPtr++;
+ *wrkStringPtr = *text++;
}
- printToLogicalScreen(x, y, textColor, k12_ColorDarkestGray, L1408_ac_ModifiedString);
+ printToLogicalScreen(x, y, textColor, k12_ColorDarkestGray, modifiedString);
}
void TextMan::clearAllRows() {
- int16 L0023_i_RowIndex;
-
isTextScrolling(&_textScroller, true);
Box tmpBox(0, 319, 169, 199);
@@ -234,9 +228,8 @@ void TextMan::clearAllRows() {
_messageAreaCursorRow = 3;
_messageAreaCursorColumn = 0;
- for (L0023_i_RowIndex = 0; L0023_i_RowIndex < 4; L0023_i_RowIndex++) {
- _messageAreaRowExpirationTime[L0023_i_RowIndex] = -1;
- }
+ for (int16 rowIndex = 0; rowIndex < 4; rowIndex++)
+ _messageAreaRowExpirationTime[rowIndex] = -1;
}
void TextMan::updateMessageArea() {
@@ -245,6 +238,7 @@ void TextMan::updateMessageArea() {
_startedScrollingAt = g_system->getMillis();
memcpy(_messageAreaCopy, _vm->_displayMan->_bitmapScreen + (200 - 7 * 4) * 320, 320 * 7 * 4);
}
+
int linesToCopy = (g_system->getMillis() - _startedScrollingAt) / 50;
if (linesToCopy >= 7) {
linesToCopy = 7;