aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/dm/gfx.cpp2
-rw-r--r--engines/dm/gfx.h5
-rw-r--r--engines/dm/inventory.cpp79
-rw-r--r--engines/dm/inventory.h3
4 files changed, 85 insertions, 4 deletions
diff --git a/engines/dm/gfx.cpp b/engines/dm/gfx.cpp
index ea05f44b76..223257c220 100644
--- a/engines/dm/gfx.cpp
+++ b/engines/dm/gfx.cpp
@@ -1501,7 +1501,7 @@ byte* DisplayMan::getBitmap(uint16 index) {
return _bitmaps[index];
}
-void DisplayMan::clearScreenBox(Color color, Box &box) {
+void DisplayMan::clearScreenBox(Color color, Box &box, Viewport &viewport) {
uint16 width = box._x2 - box._x1;
for (int y = box._y1; y < box._y2; ++y)
memset(_vgaBuffer + y * _screenWidth + box._x1, color, sizeof(byte) * width);
diff --git a/engines/dm/gfx.h b/engines/dm/gfx.h
index 99d3f8f417..65322918cd 100644
--- a/engines/dm/gfx.h
+++ b/engines/dm/gfx.h
@@ -27,7 +27,8 @@ enum GraphicIndice {
kObjectIcons_096_TO_127 = 45, // @ C045_GRAPHIC_OBJECT_ICONS_096_TO_127
kObjectIcons_128_TO_159 = 46, // @ C046_GRAPHIC_OBJECT_ICONS_128_TO_159
kObjectIcons_160_TO_191 = 47, // @ C047_GRAPHIC_OBJECT_ICONS_160_TO_191
- kObjectIcons_192_TO_223 = 48 // @ C048_GRAPHIC_OBJECT_ICONS_192_TO_223
+ kObjectIcons_192_TO_223 = 48, // @ C048_GRAPHIC_OBJECT_ICONS_192_TO_223
+ kInventoryGraphicIndice = 17 // @ C017_GRAPHIC_INVENTORY
};
extern uint16 gPalSwoosh[16];
@@ -295,7 +296,7 @@ public:
void clearBitmap(byte *bitmap, uint16 width, uint16 height, Color color);
void clearScreen(Color color);
- void clearScreenBox(Color color, Box &box); // @ D24_FillScreenBox
+ void clearScreenBox(Color color, Box &box, Viewport &viewport = gDefultViewPort); // @ D24_FillScreenBox
void drawDungeon(direction dir, int16 posX, int16 posY); // @ F0128_DUNGEONVIEW_Draw_CPSF
void updateScreen();
byte* getBitmap(uint16 index);
diff --git a/engines/dm/inventory.cpp b/engines/dm/inventory.cpp
index 378d79839b..70359334b0 100644
--- a/engines/dm/inventory.cpp
+++ b/engines/dm/inventory.cpp
@@ -1,11 +1,88 @@
#include "inventory.h"
+#include "dungeonman.h"
+#include "eventman.h"
+#include "menus.h"
namespace DM {
-Viewport gViewportFloppyZzzCross = {174, 2}; // @ G0041_s_Graphic562_Box_ViewportFloppyZzzCross
+Box gBoxFloppyZzzCross = Box(174, 218, 2, 12); // @ G0041_s_Graphic562_Box_ViewportFloppyZzzCross
InventoryMan::InventoryMan(DMEngine *vm): _vm(vm) {}
+void InventoryMan::toggleInventory(ChampionIndex championIndex) {
+ ChampionMan &cm = *_vm->_championMan;
+ EventManager &em = *_vm->_eventMan;
+ DisplayMan &dm = *_vm->_displayMan;
+
+ if ((championIndex == kChmpionCloseInventory) && !cm._champions[championIndex]._currHealth)
+ return;
+ if (_vm->_pressingEye || _vm->_pressingMouth)
+ return;
+ _vm->_stopWaitingForPlayerInput = true;
+ int16 invChampOrdinal = _inventoryChampionOrdinal; // copy, as the original will be edited
+ if (indexToOrdinal(championIndex) == invChampOrdinal) {
+ championIndex = kChmpionCloseInventory;
+ }
+
+ Champion *champion;
+ if (invChampOrdinal) {
+ _inventoryChampionOrdinal = indexToOrdinal(kChampionNone);
+ warning("MISSING CODE: F0334_INVENTORY_CloseChest");
+ champion = &cm._champions[ordinalToIndex(kChampionNone)];
+ if (champion->_currHealth && !cm._candidateChampionOrdinal) {
+ champion->setAttributeFlag(kChampionAttributeStatusBox, true);
+ warning("MISSING CODE: F0292_CHAMPION_DrawState");
+ }
+ if (cm._partyIsSleeping) {
+ return;
+ }
+ if (championIndex == kChmpionCloseInventory) {
+ em._refreshMousePointerInMainLoop = true;
+ _vm->_menuMan->drawMovementArrows();
+ em._secondaryMouseInput = gSecondaryMouseInput_Movement;
+ warning("MISSING CODE: set G0444_ps_SecondaryKeyboardInput");
+ warning("MISSING CODE: F0357_COMMAND_DiscardAllInput");
+ return;
+ }
+ }
+
+ dm._useByteBoxCoordinates = false;
+ _inventoryChampionOrdinal = indexToOrdinal(championIndex);
+ if (!invChampOrdinal) {
+ warning("MISSING CODE: F0136_VIDEO_ShadeScreenBox");
+ }
+
+ champion = &cm._champions[championIndex];
+ int16 w = dm.getWidth(kInventoryGraphicIndice);
+ int16 h = dm.getHeight(kInventoryGraphicIndice);
+ dm.blitToScreen(dm.getBitmap(kInventoryGraphicIndice), w, 0, 0, 0, w, 0, h, kColorNoTransparency, gDungeonViewport);
+ if (cm._candidateChampionOrdinal) {
+ dm.clearScreenBox(kColorDarkestGray, gBoxFloppyZzzCross, gDungeonViewport);
+ } else {
+ static Box gBoxFloppy = Box(174, 182, 2, 12); // @ K0300_s_Box_ViewportFloppy
+ dm.clearScreenBox(kColorDarkestGray, gBoxFloppy, gDungeonViewport);
+ }
+ warning("MISSING CODE: F0052_TEXT_PrintToViewport -> HEALTH");
+ warning("MISSING CODE: F0052_TEXT_PrintToViewport -> STAMINA");
+ warning("MISSING CODE: F0052_TEXT_PrintToViewport -> MANA");
+
+ warning("MISSING CODE: F0291_CHAMPION_DrawSlot in LOOOOOOOOOOOOP");
+
+ champion->setAttributeFlag(kChampionAttributeViewport, true);
+ champion->setAttributeFlag(kChampionAttributeStatusBox, true);
+ champion->setAttributeFlag(kChampionAttributePanel, true);
+ champion->setAttributeFlag(kChampionAttributeLoad, true);
+ champion->setAttributeFlag(kChampionAttributeStatistics, true);
+ champion->setAttributeFlag(kChampionAttributeNameTitle, true);
+
+ warning("MISSING CODE: F0292_CHAMPION_DrawState");
+ em._mousePointerBitmapUpdated = true;
+ em._secondaryMouseInput = gSecondaryMouseInput_ChampionInventory;
+ warning("MISSING CODE: set G0444_ps_SecondaryKeyboardInput");
+ warning("MISSING CODE: F0357_COMMAND_DiscardAllInput");
+}
+
+
} \ No newline at end of file
diff --git a/engines/dm/inventory.h b/engines/dm/inventory.h
index 06488fe4d4..6579708293 100644
--- a/engines/dm/inventory.h
+++ b/engines/dm/inventory.h
@@ -1,5 +1,6 @@
#include "dm.h"
#include "gfx.h"
+#include "champion.h"
@@ -8,7 +9,9 @@ namespace DM {
class InventoryMan {
DMEngine *_vm;
public:
+ int16 _inventoryChampionOrdinal; // @ G0423_i_InventoryChampionOrdinal
InventoryMan(DMEngine *vm);
+ void toggleInventory(ChampionIndex championIndex); // @ F0355_INVENTORY_Toggle_CPSE
};
} \ No newline at end of file