aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/hdb/window.cpp78
-rw-r--r--engines/hdb/window.h9
2 files changed, 87 insertions, 0 deletions
diff --git a/engines/hdb/window.cpp b/engines/hdb/window.cpp
index eb3647358a..12810f8a87 100644
--- a/engines/hdb/window.cpp
+++ b/engines/hdb/window.cpp
@@ -303,4 +303,82 @@ void Window::setDialogDelay(int delay) {
_dialogDelay = g_system->getMillis() + 1000 * delay;
}
+void Window::drawInventory() {
+ int baseX, drawX, drawY;
+ static uint32 timer = g_hdb->getTimeSlice() + 300;
+ AIEntity *e, *sel;
+ char string[8];
+ int gems, mstones;
+
+ // INFOBAR blit - only once per frame
+ // note: if 2, don't draw ANY info at all
+ if (_infobarDimmed > 1)
+ return;
+
+ _gfxInfobar->draw(kScreenWidth - _gfxInfobar->_width, 0);
+
+ baseX = drawX = _invWinInfo.x;
+ drawY = _invWinInfo.y;
+
+ // Draw Inv Items
+ sel = NULL;
+ if (_invWinInfo.selection >= g_hdb->_ai->getInvAmount())
+ _invWinInfo.selection = g_hdb->_ai->getInvAmount();
+
+ for (int inv = 0; inv < g_hdb->_ai->getInvAmount(); inv++) {
+ e = g_hdb->_ai->getInvItem(inv);
+ if (inv == _invWinInfo.selection)
+ sel = e;
+
+ e->standdownGfx[0]->drawMasked(drawX, drawY);
+
+ drawX += kInvItemSpaceX;
+ if (drawX >= baseX + (kInvItemSpaceX * kInvItemPerLine)) {
+ drawX = baseX;
+ drawY += kInvItemSpaceY;
+ }
+ }
+
+ // Draw the Gem
+ drawY = _invWinInfo.y + kInvItemSpaceY * 4 - 8;
+ drawX = baseX - 8;
+ _gemGfx->drawMasked(drawX, drawY);
+
+ // Draw the Gem Amount
+ gems = g_hdb->_ai->getGemAmount();
+ sprintf(string, "%d", gems);
+ g_hdb->_drawMan->setCursor(drawX + 32, drawY + 8);
+ g_hdb->_drawMan->drawText(string);
+
+ // Draw the mini monkeystone
+ mstones = g_hdb->_ai->getMonkeystoneAmount();
+ if (mstones) {
+ drawX = baseX + kInvItemSpaceX * 2 - 8;
+ _mstoneGfx->drawMasked(drawX, drawY + 8);
+
+ // Draw the monkeystone amount
+ sprintf(string, "%d", mstones);
+ g_hdb->_drawMan->setCursor(drawX + 28, drawY + 8);
+ g_hdb->_drawMan->drawText(string);
+ }
+
+ // If you have an inventory, draw the selection cursor
+ if (g_hdb->_ai->getInvAmount()) {
+ if (_invWinInfo.selection < 0)
+ _invWinInfo.selection = 0;
+
+ // Draw the Inventory Select Cursor
+ drawX = baseX + (_invWinInfo.selection % kInvItemPerLine) * kInvItemSpaceX;
+ drawY = _invWinInfo.y + (_invWinInfo.selection / kInvItemPerLine) * kInvItemSpaceY;
+ _gfxInvSelect->drawMasked(drawX, drawY);
+
+ if (sel) {
+ int centerX = baseX - 4 + (kScreenWidth - baseX) / 2;
+ drawY = _invWinInfo.y + (kInvItemSpaceY * 4) + 16;
+ g_hdb->_drawMan->setCursor(centerX - g_hdb->_drawMan->stringLength(sel->printedName) / 2, drawY);
+ g_hdb->_drawMan->drawText(sel->printedName);
+ }
+ }
+}
+
} // End of Namespace
diff --git a/engines/hdb/window.h b/engines/hdb/window.h
index 8bfc38c067..32a41ae7fc 100644
--- a/engines/hdb/window.h
+++ b/engines/hdb/window.h
@@ -81,6 +81,15 @@ public:
return _dialogInfo.active;
}
+ // Inventory Functions
+ void drawInventory();
+ void setInvSelect(int status) {
+ _invWinInfo.selection = status;
+ }
+ int getInvSelect() {
+ return _invWinInfo.selection;
+ }
+
private:
DialogInfo _dialogInfo;