From 087f84b38b94ee56e67c874cb281bec057f6cb80 Mon Sep 17 00:00:00 2001 From: Nipun Garg Date: Tue, 25 Jun 2019 00:50:51 +0530 Subject: HDB: Add aiOmniBotMissile functions --- engines/hdb/ai-bots.cpp | 40 ++++++++++++++++++++++++++++++++++++++++ engines/hdb/ai-player.cpp | 12 ------------ 2 files changed, 40 insertions(+), 12 deletions(-) diff --git a/engines/hdb/ai-bots.cpp b/engines/hdb/ai-bots.cpp index 25d734a720..24e9cfb116 100644 --- a/engines/hdb/ai-bots.cpp +++ b/engines/hdb/ai-bots.cpp @@ -129,4 +129,44 @@ void aiOmniBotAction(AIEntity *e) { e->sequence--; } +void aiOmniBotMissileInit(AIEntity *e) { + e->state = STATE_MOVEDOWN; + e->aiAction = aiOmniBotMissileAction; +} + +void aiOmniBotMissileInit2(AIEntity *e) { + for (int i = 0; i < e->movedownFrames;i++) + e->moveleftGfx[i] = e->moverightGfx[i] = e->moveupGfx[i] = e->movedownGfx[i]; + + e->moveleftFrames = e->moverightFrames = e->moveupFrames = e->movedownFrames; + e->draw = e->movedownGfx[0]; +} + +void aiOmniBotMissileAction(AIEntity *e) { + AIEntity *p = g_hdb->_ai->getPlayer(); + + g_hdb->_ai->animEntFrames(e); + e->x += e->xVel; + e->y += e->yVel; + e->tileX = e->x / kTileWidth; + e->tileY = e->y / kTileHeight; + + // Did we hit a solid wall? + int result; + AIEntity *hit = g_hdb->_ai->legalMoveOverWaterIgnore(e->tileX, e->tileY, e->level, &result, e); + + if (hit || !result) { + g_hdb->_ai->addAnimateTarget(e->x, e->y, 0, 3, ANIM_FAST, false, false, "steam_puff_sit"); + g_hdb->_ai->removeEntity(e); + } + + // On Even tiles, check for hitting player + if (onEvenTile(e->x, e->y)) + if (e->onScreen && (p->level == e->level) && g_hdb->_ai->checkPlayerCollision(e->x, e->y, 4) && !g_hdb->_ai->playerDead()) { + g_hdb->_ai->killPlayer(DEATH_NORMAL); + g_hdb->_ai->addAnimateTarget(e->x, e->y, 0, 3, ANIM_FAST, false, false, "steam_puff_sit"); + g_hdb->_ai->removeEntity(e); + } +} + } // End of Namespace diff --git a/engines/hdb/ai-player.cpp b/engines/hdb/ai-player.cpp index 940ddcb94c..32de22b2f2 100644 --- a/engines/hdb/ai-player.cpp +++ b/engines/hdb/ai-player.cpp @@ -380,18 +380,6 @@ void aiRailRiderOnAction(AIEntity *e) { warning("STUB: AI: aiRailRiderOnAction required"); } -void aiOmniBotMissileAction(AIEntity *e) { - warning("STUB: AI: aiOmniBotMissileAction required"); -} - -void aiOmniBotMissileInit(AIEntity *e) { - warning("STUB: AI: aiOmniBotMissileInit required"); -} - -void aiOmniBotMissileInit2(AIEntity *e) { - warning("STUB: AI: aiOmniBotMissileInit2 required"); -} - void aiSlugAttackAction(AIEntity *e) { warning("STUB: AI: aiSlugAttackAction required"); } -- cgit v1.2.3