aboutsummaryrefslogtreecommitdiff
path: root/object.cpp
diff options
context:
space:
mode:
authorVincent Hamm2002-04-21 21:20:32 +0000
committerVincent Hamm2002-04-21 21:20:32 +0000
commit7c95649ba565bce18496f5c0f54145bda9f09940 (patch)
tree7f49494c401eeb206fd7406a74f6e4d1bc4699b7 /object.cpp
parent1b1d5795a88cd00ac06c335fab34598a9aad2674 (diff)
downloadscummvm-rg350-7c95649ba565bce18496f5c0f54145bda9f09940.tar.gz
scummvm-rg350-7c95649ba565bce18496f5c0f54145bda9f09940.tar.bz2
scummvm-rg350-7c95649ba565bce18496f5c0f54145bda9f09940.zip
Some code cleanup in the blast object code for implementation of futur features
svn-id: r4039
Diffstat (limited to 'object.cpp')
-rw-r--r--object.cpp45
1 files changed, 23 insertions, 22 deletions
diff --git a/object.cpp b/object.cpp
index c389cfaacf..172d9a30a6 100644
--- a/object.cpp
+++ b/object.cpp
@@ -1151,54 +1151,55 @@ void Scumm::nukeFlObjects(int min, int max)
}
}
-void Scumm::enqueueObject(int a, int b, int c, int d, int e, int f, int g,
- int h, int mode)
+void Scumm::enqueueObject(int objectNumber, int objectX, int objectY, int objectWidth, int objectHeight, int f, int g,
+ int image, int mode)
{
- EnqueuedObject *eo;
+ BlastObject *eo;
ObjectData *od;
if (_enqueuePos == sizeof(_enqueuedObjects) / sizeof(_enqueuedObjects[0]))
error("enqueueObject: overflow");
eo = &_enqueuedObjects[_enqueuePos++];
- eo->a = a;
+ eo->a = objectNumber;
eo->b = _enqueue_b;
eo->c = _enqueue_c;
eo->d = _enqueue_d;
eo->e = _enqueue_e;
- eo->x = b;
- eo->y = c;
- if (d == 0) {
- od = &_objs[getObjectIndex(a)];
+ eo->x = objectX;
+ eo->y = objectY;
+ if (objectWidth == 0) {
+ od = &_objs[getObjectIndex(objectNumber)];
eo->width = od->width;
} else {
- eo->width = d;
+ eo->width = objectWidth;
}
- if (e == 0) {
- od = &_objs[getObjectIndex(a)];
+ if (objectHeight == 0) {
+ od = &_objs[getObjectIndex(objectNumber)];
eo->height = od->height;
} else {
- eo->height = e;
+ eo->height = objectHeight;
}
eo->j = f;
eo->k = g;
- eo->l = h;
+ eo->l = image;
+ eo->mode = mode;
}
-void Scumm::drawEnqueuedObjects()
+void Scumm::drawBlastObjects()
{
- EnqueuedObject *eo;
+ BlastObject *eo;
int i;
eo = _enqueuedObjects;
for (i = 0; i < _enqueuePos; i++, eo++) {
- drawEnqueuedObject(eo);
+ drawBlastObject(eo);
}
}
-void Scumm::drawEnqueuedObject(EnqueuedObject * eo)
+void Scumm::drawBlastObject(BlastObject * eo)
{
VirtScreen *vs;
byte *roomptr, *bomp;
@@ -1232,7 +1233,7 @@ void Scumm::drawEnqueuedObject(EnqueuedObject * eo)
assert(ptr);
ptr = findResource(IMxx_tags[eo->l], ptr);
-// assert(ptr);
+
if (!ptr) /* FIXME: Sam and Max highway subgame */
return;
bomp = findResourceData(MKID('BOMP'), ptr);
@@ -1257,20 +1258,20 @@ void Scumm::drawEnqueuedObject(EnqueuedObject * eo)
}
}
-void Scumm::removeEnqueuedObjects()
+void Scumm::removeBlastObjects()
{
- EnqueuedObject *eo;
+ BlastObject *eo;
int i;
eo = _enqueuedObjects;
for (i = 0; i < _enqueuePos; i++, eo++) {
- removeEnqueuedObject(eo);
+ removeBlastObject(eo);
}
clearEnqueue();
}
-void Scumm::removeEnqueuedObject(EnqueuedObject * eo)
+void Scumm::removeBlastObject(BlastObject * eo)
{
restoreBG(eo->x, eo->y, eo->x + eo->width, eo->y + eo->height);
}