aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--scumm/akos.cpp60
-rw-r--r--scumm/costume.cpp40
2 files changed, 48 insertions, 52 deletions
diff --git a/scumm/akos.cpp b/scumm/akos.cpp
index b2f579b879..d5f7eb683a 100644
--- a/scumm/akos.cpp
+++ b/scumm/akos.cpp
@@ -604,16 +604,15 @@ const byte defaultScaleTable[768] = {
#endif
byte AkosRenderer::codec1(int xmoveCur, int ymoveCur) {
- int num_colors, value;
+ int num_colors;
bool use_scaling;
int i, j;
int skip = 0, startScaleIndexX, startScaleIndexY;
Common::Rect rect;
- int cur_x, cur_y;
int step;
byte drawFlag = 1;
- value = (_vm->_features & GF_HUMONGOUS) ? 0x80 : 0x180;
+ const int scaletableSize = (_vm->_features & GF_HUMONGOUS) ? 128 : 384;
/* implement custom scale table */
v1.scaletable = (_vm->_features & GF_HUMONGOUS) ? oldScaleTable : defaultScaleTable;
@@ -636,8 +635,8 @@ byte AkosRenderer::codec1(int xmoveCur, int ymoveCur) {
use_scaling = (_scaleX != 0xFF) || (_scaleY != 0xFF);
- cur_x = _actorX;
- cur_y = _actorY;
+ v1.x = _actorX;
+ v1.y = _actorY;
if (use_scaling) {
@@ -650,13 +649,13 @@ byte AkosRenderer::codec1(int xmoveCur, int ymoveCur) {
if (_mirror) {
/* Adjust X position */
- startScaleIndexX = j = value - xmoveCur;
+ startScaleIndexX = j = scaletableSize - xmoveCur;
for (i = 0; i < xmoveCur; i++) {
if (v1.scaletable[j++] < _scaleX)
- cur_x -= v1.scaleXstep;
+ v1.x -= v1.scaleXstep;
}
- rect.left = rect.right = cur_x;
+ rect.left = rect.right = v1.x;
j = startScaleIndexX;
for (i = 0, skip = 0; i < _width; i++) {
@@ -670,13 +669,13 @@ byte AkosRenderer::codec1(int xmoveCur, int ymoveCur) {
} else {
/* No mirror */
/* Adjust X position */
- startScaleIndexX = j = value + xmoveCur;
+ startScaleIndexX = j = scaletableSize + xmoveCur;
for (i = 0; i < xmoveCur; i++) {
if (v1.scaletable[j--] < _scaleX)
- cur_x += v1.scaleXstep;
+ v1.x += v1.scaleXstep;
}
- rect.left = rect.right = cur_x;
+ rect.left = rect.right = v1.x;
j = startScaleIndexX;
for (i = 0; i < _width; i++) {
@@ -699,40 +698,40 @@ byte AkosRenderer::codec1(int xmoveCur, int ymoveCur) {
step = -step;
}
- startScaleIndexY = value - ymoveCur;
+ startScaleIndexY = scaletableSize - ymoveCur;
for (i = 0; i < ymoveCur; i++) {
if (v1.scaletable[startScaleIndexY++] < _scaleY)
- cur_y -= step;
+ v1.y -= step;
}
- rect.top = rect.bottom = cur_y;
- startScaleIndexY = value - ymoveCur;
+ rect.top = rect.bottom = v1.y;
+ startScaleIndexY = scaletableSize - ymoveCur;
for (i = 0; i < _height; i++) {
if (v1.scaletable[startScaleIndexY++] < _scaleY)
rect.bottom++;
}
- startScaleIndexY = value - ymoveCur;
+ startScaleIndexY = scaletableSize - ymoveCur;
} else {
if (!_mirror)
xmoveCur = -xmoveCur;
- cur_x += xmoveCur;
- cur_y += ymoveCur;
+ v1.x += xmoveCur;
+ v1.y += ymoveCur;
if (_mirror) {
- rect.left = cur_x;
- rect.right = cur_x + _width;
+ rect.left = v1.x;
+ rect.right = v1.x + _width;
} else {
- rect.right = cur_x;
- rect.left = cur_x - _width;
+ rect.left = v1.x - _width;
+ rect.right = v1.x;
}
- rect.top = cur_y;
- rect.bottom = cur_y + _height;
+ rect.top = v1.y;
+ rect.bottom = rect.top + _height;
- startScaleIndexX = value;
- startScaleIndexY = value;
+ startScaleIndexX = scaletableSize;
+ startScaleIndexY = scaletableSize;
}
v1.scaleXindex = startScaleIndexX;
@@ -756,11 +755,11 @@ byte AkosRenderer::codec1(int xmoveCur, int ymoveCur) {
if (_mirror) {
if (!use_scaling)
- skip = -cur_x;
+ skip = -v1.x;
if (skip > 0) {
v1.skip_width -= skip;
codec1_ignorePakCols(skip);
- cur_x = 0;
+ v1.x = 0;
} else {
skip = rect.right - _outwidth;
if (skip <= 0) {
@@ -775,7 +774,7 @@ byte AkosRenderer::codec1(int xmoveCur, int ymoveCur) {
if (skip > 0) {
v1.skip_width -= skip;
codec1_ignorePakCols(skip);
- cur_x = _outwidth - 1;
+ v1.x = _outwidth - 1;
} else {
skip = -1 - rect.left;
if (skip <= 0)
@@ -785,9 +784,6 @@ byte AkosRenderer::codec1(int xmoveCur, int ymoveCur) {
}
}
- v1.x = cur_x;
- v1.y = cur_y;
-
if (v1.skip_width <= 0 || _height <= 0)
return 0;
diff --git a/scumm/costume.cpp b/scumm/costume.cpp
index 127787fd4f..7b9f4282ff 100644
--- a/scumm/costume.cpp
+++ b/scumm/costume.cpp
@@ -74,12 +74,12 @@ byte CostumeRenderer::mainRoutine(int xmoveCur, int ymoveCur) {
byte drawFlag = 1;
bool use_scaling;
byte startScaleIndexX;
- byte newAmiCost;
int ex1, ex2;
Common::Rect rect;
int step;
- newAmiCost = (_vm->_version == 5) && (_vm->_features & GF_AMIGA);
+ const int scaletableSize = 128;
+ const bool newAmiCost = (_vm->_version == 5) && (_vm->_features & GF_AMIGA);
CHECK_HEAP
@@ -89,7 +89,7 @@ byte CostumeRenderer::mainRoutine(int xmoveCur, int ymoveCur) {
v1.mask = 7;
v1.shr = 3;
} else {
- v1.mask = 0xF;
+ v1.mask = 15;
v1.shr = 4;
}
@@ -106,11 +106,11 @@ byte CostumeRenderer::mainRoutine(int xmoveCur, int ymoveCur) {
}
}
+ use_scaling = (_scaleX != 0xFF) || (_scaleY != 0xFF);
+
v1.x = _actorX;
v1.y = _actorY;
- use_scaling = (_scaleX != 0xFF) || (_scaleY != 0xFF);
-
if (use_scaling) {
/* Scale direction */
@@ -122,13 +122,13 @@ byte CostumeRenderer::mainRoutine(int xmoveCur, int ymoveCur) {
if (_mirror) {
/* Adjust X position */
- startScaleIndexX = _scaleIndexX = 128 - xmoveCur;
+ startScaleIndexX = _scaleIndexX = scaletableSize - xmoveCur;
for (i = 0; i < xmoveCur; i++) {
- if (cost_scaleTable[_scaleIndexX++] < _scaleX)
+ if (v1.scaletable[_scaleIndexX++] < _scaleX)
v1.x -= v1.scaleXstep;
}
- rect.right = rect.left = v1.x;
+ rect.left = rect.right = v1.x;
_scaleIndexX = startScaleIndexX;
for (i = 0; i < _width; i++) {
@@ -136,19 +136,19 @@ byte CostumeRenderer::mainRoutine(int xmoveCur, int ymoveCur) {
skip++;
startScaleIndexX = _scaleIndexX;
}
- if (cost_scaleTable[_scaleIndexX++] < _scaleX)
+ if (v1.scaletable[_scaleIndexX++] < _scaleX)
rect.right++;
}
} else {
/* No mirror */
/* Adjust X position */
- startScaleIndexX = _scaleIndexX = xmoveCur + 128;
+ startScaleIndexX = _scaleIndexX = xmoveCur + scaletableSize;
for (i = 0; i < xmoveCur; i++) {
- if (cost_scaleTable[_scaleIndexX--] < _scaleX)
+ if (v1.scaletable[_scaleIndexX--] < _scaleX)
v1.x += v1.scaleXstep;
}
- rect.right = rect.left = v1.x;
+ rect.left = rect.right = v1.x;
_scaleIndexX = startScaleIndexX;
for (i = 0; i < _width; i++) {
@@ -156,7 +156,7 @@ byte CostumeRenderer::mainRoutine(int xmoveCur, int ymoveCur) {
startScaleIndexX = _scaleIndexX;
skip++;
}
- if (cost_scaleTable[_scaleIndexX--] < _scaleX)
+ if (v1.scaletable[_scaleIndexX--] < _scaleX)
rect.left--;
}
}
@@ -171,20 +171,20 @@ byte CostumeRenderer::mainRoutine(int xmoveCur, int ymoveCur) {
step = 1;
}
- _scaleIndexY = 128 - ymoveCur;
+ _scaleIndexY = scaletableSize - ymoveCur;
for (i = 0; i < ymoveCur; i++) {
- if (cost_scaleTable[_scaleIndexY++] < _scaleY)
+ if (v1.scaletable[_scaleIndexY++] < _scaleY)
v1.y -= step;
}
rect.top = rect.bottom = v1.y;
- _scaleIndexY = 128 - ymoveCur;
+ _scaleIndexY = scaletableSize - ymoveCur;
for (i = 0; i < _height; i++) {
- if (cost_scaleTable[_scaleIndexY++] < _scaleY)
+ if (v1.scaletable[_scaleIndexY++] < _scaleY)
rect.bottom++;
}
- _scaleIndexY = 128 - ymoveCur;
+ _scaleIndexY = scaletableSize - ymoveCur;
} else {
if (!_mirror)
xmoveCur = -xmoveCur;
@@ -498,14 +498,14 @@ void CostumeRenderer::proc3_ami() {
if (!len)
len = *src++;
do {
- if (_scaleY == 255 || cost_scaleTable[_scaleIndexY] < _scaleY) {
+ if (_scaleY == 255 || v1.scaletable[_scaleIndexY] < _scaleY) {
masked = (y < 0 || y >= _outheight) || (v1.mask_ptr && (mask[0] & maskbit));
if (color && v1.x >= 0 && v1.x < _outwidth && !masked) {
*dst = _palette[color];
}
- if (_scaleX == 255 || cost_scaleTable[_scaleIndexX] < _scaleX) {
+ if (_scaleX == 255 || v1.scaletable[_scaleIndexX] < _scaleX) {
v1.x += v1.scaleXstep;
dst += v1.scaleXstep;
maskbit = revBitMask[v1.x & 7];