aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/hdb/map.cpp43
-rw-r--r--engines/hdb/map.h2
2 files changed, 15 insertions, 30 deletions
diff --git a/engines/hdb/map.cpp b/engines/hdb/map.cpp
index 7f0c418331..6fcb582388 100644
--- a/engines/hdb/map.cpp
+++ b/engines/hdb/map.cpp
@@ -28,24 +28,9 @@ Map::Map() {
_mapLoaded = false;
_animCycle = 0;
-
- for (int i = 0; i < kMaxGratings; i++) {
- _gratings[i] = new Foreground;
- }
-
- for (int i = 0; i < kMaxForegrounds; i++) {
- _foregrounds[i] = new Foreground;
- }
}
Map::~Map() {
- for (int i = 0; i < kMaxGratings; i++) {
- delete _gratings[i];
- }
-
- for (int i = 0; i < kMaxForegrounds; i++) {
- delete _foregrounds[i];
- }
}
void Map::save(Common::OutSaveFile *out) {
@@ -66,9 +51,9 @@ void Map::save(Common::OutSaveFile *out) {
out->writeSint32LE(_numGratings);
for (i = 0; i < _numGratings; i++) {
- out->writeUint16LE(_gratings[i]->x);
- out->writeUint16LE(_gratings[i]->y);
- out->writeUint16LE(_gratings[i]->tile);
+ out->writeUint16LE(_gratings[i].x);
+ out->writeUint16LE(_gratings[i].y);
+ out->writeUint16LE(_gratings[i].tile);
}
out->writeSint32LE(_animCycle);
@@ -138,9 +123,9 @@ void Map::loadSaveFile(Common::InSaveFile *in) {
_numGratings = in->readSint32LE();
for (i = 0; i < _numGratings; i++) {
- _gratings[i]->x = in->readUint16LE();
- _gratings[i]->y = in->readUint16LE();
- _gratings[i]->tile = in->readUint16LE();
+ _gratings[i].x = in->readUint16LE();
+ _gratings[i].y = in->readUint16LE();
+ _gratings[i].tile = in->readUint16LE();
}
_animCycle = in->readSint32LE();
@@ -830,16 +815,16 @@ void Map::draw() {
if ((fTile->_flags & kFlagGrating) && (_numGratings < kMaxGratings)) {
// Check for Gratings Flag
- _gratings[_numGratings]->x = screenX;
- _gratings[_numGratings]->y = screenY;
- _gratings[_numGratings]->tile = tileIndex;
+ _gratings[_numGratings].x = screenX;
+ _gratings[_numGratings].y = screenY;
+ _gratings[_numGratings].tile = tileIndex;
if (_numGratings < kMaxGratings)
_numGratings++;
} else if ((fTile->_flags & kFlagForeground)) {
// Check for Foregrounds Flag
- _foregrounds[_numForegrounds]->x = screenX;
- _foregrounds[_numForegrounds]->y = screenY;
- _foregrounds[_numForegrounds]->tile = tileIndex;
+ _foregrounds[_numForegrounds].x = screenX;
+ _foregrounds[_numForegrounds].y = screenY;
+ _foregrounds[_numForegrounds].tile = tileIndex;
if (_numForegrounds < kMaxForegrounds)
_numForegrounds++;
} else {
@@ -900,7 +885,7 @@ void Map::drawEnts() {
void Map::drawGratings() {
for (int i = 0; i < _numGratings; i++) {
- g_hdb->_gfx->getTile(_gratings[i]->tile)->drawMasked(_gratings[i]->x, _gratings[i]->y);
+ g_hdb->_gfx->getTile(_gratings[i].tile)->drawMasked(_gratings[i].x, _gratings[i].y);
}
debug(8, "Gratings Count: %d", _numGratings);
@@ -908,7 +893,7 @@ void Map::drawGratings() {
void Map::drawForegrounds() {
for (int i = 0; i < _numForegrounds; i++) {
- g_hdb->_gfx->getTile(_foregrounds[i]->tile)->drawMasked(_foregrounds[i]->x, _foregrounds[i]->y);
+ g_hdb->_gfx->getTile(_foregrounds[i].tile)->drawMasked(_foregrounds[i].x, _foregrounds[i].y);
}
debug(8, "Foregrounds Count: %d", _numForegrounds);
diff --git a/engines/hdb/map.h b/engines/hdb/map.h
index d6b0bdac26..40191f7f4d 100644
--- a/engines/hdb/map.h
+++ b/engines/hdb/map.h
@@ -145,7 +145,7 @@ public:
int _mapTileX, _mapTileY; // Tile Coordinates of Map
int _mapTileXOff, _mapTileYOff; // Tile Coordinates Offset (0-31)
- Foreground *_gratings[kMaxGratings], *_foregrounds[kMaxForegrounds];
+ Foreground _gratings[kMaxGratings], _foregrounds[kMaxForegrounds];
int _numGratings, _numForegrounds;
int _animCycle; // Tile Animation Counter