aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/mads/scene.cpp3
-rw-r--r--engines/mads/screen.cpp135
-rw-r--r--engines/mads/screen.h6
-rw-r--r--engines/mads/user_interface.cpp46
-rw-r--r--engines/mads/user_interface.h7
5 files changed, 185 insertions, 12 deletions
diff --git a/engines/mads/scene.cpp b/engines/mads/scene.cpp
index e01720f788..e357f8b1ad 100644
--- a/engines/mads/scene.cpp
+++ b/engines/mads/scene.cpp
@@ -337,7 +337,8 @@ void Scene::doFrame() {
CursorType cursorId = CURSOR_ARROW;
if (_action._v83338 == 1 && !_vm->_game->_screenObjects._v7FECA &&
_vm->_game->_screenObjects._category == CAT_HOTSPOT) {
- int idx = _vm->_game->_screenObjects._selectedObject - _vm->_game->_screenObjects._hotspotsIndex;
+ int idx = _vm->_game->_screenObjects._selectedObject -
+ _userInterface._categoryIndexes[CAT_HOTSPOT - 1];
assert(idx >= 0);
if (idx >= (int)_hotspots.size()) {
diff --git a/engines/mads/screen.cpp b/engines/mads/screen.cpp
index 3565c1ac79..dac61d5bf1 100644
--- a/engines/mads/screen.cpp
+++ b/engines/mads/screen.cpp
@@ -262,7 +262,6 @@ ScreenObjects::ScreenObjects(MADSEngine *vm) : _vm(vm) {
_newDescId = 0;
_released = false;
_uiCount = 0;
- _hotspotsIndex = 0;
_selectedObject = -1;
_scrollerY = -1;
_milliTime = 0;
@@ -302,7 +301,7 @@ void ScreenObjects::check(bool scanFlag) {
&& scene._userInterface._category != CAT_NONE) {
_released = true;
if (category >= CAT_ACTION && category <= CAT_TALK_ENTRY) {
- scene._userInterface.elementHighlighted();
+ elementHighlighted();
}
scene._action.checkActionAtMousePos();
@@ -314,7 +313,7 @@ void ScreenObjects::check(bool scanFlag) {
if (!_vm->_events->_mouseButtons || _vm->_easyMouse) {
if (category >= CAT_ACTION && category <= CAT_TALK_ENTRY) {
- scene._userInterface.elementHighlighted();
+ elementHighlighted();
}
}
@@ -448,6 +447,136 @@ void ScreenObjects::checkScroller() {
_objectY = userInterface._objectY;
}
+void ScreenObjects::elementHighlighted() {
+ Scene &scene = _vm->_game->_scene;
+ UserInterface &userInterface = scene._userInterface;
+ Common::Array<int> &invList = _vm->_game->_objects._inventoryList;
+ MADSAction &action = scene._action;
+ int varA;
+ int topIndex;
+ int *var6;
+ int var4;
+ int index, indexEnd;
+ int var8 = 0;
+ int uiCount;
+
+ switch (userInterface._category) {
+ case CAT_ACTION:
+ index = 10;
+ indexEnd = 9;
+ varA = 5;
+ topIndex = 0;
+ var6 = !_v7FECA ? &userInterface._v1A : &userInterface._selectedActionIndex;
+
+ if (_v7FECA && userInterface._selectedItemVocabIdx >= 0)
+ userInterface.drawInventory(3, -1, &userInterface._selectedItemVocabIdx);
+
+ var4 = _released && !_v7FECA ? 1 : 0;
+ break;
+
+ case CAT_INV_LIST:
+ userInterface.scrollInventory();
+
+ index = MIN((int)invList.size() - userInterface._inventoryTopIndex, 5);
+ indexEnd = invList.size() - 1;
+ varA = 0;
+ topIndex = userInterface._inventoryTopIndex;
+ var6 = &userInterface._v1C;
+ var4 = (!_released || (_vm->_events->_mouseButtons && action._v83338 == 1)) ? 0 : 1;
+ break;
+
+ case CAT_INV_VOCAB:
+ if (userInterface._selectedInvIndex >= 0) {
+ InventoryObject &invObject = _vm->_game->_objects.getItem(
+ userInterface._selectedInvIndex);
+ index = invObject._vocabCount;
+ indexEnd = index - 1;
+ } else {
+ index = 0;
+ }
+
+ varA = 0;
+ topIndex = 0;
+ var6 = _v7FECA ? &userInterface._selectedItemVocabIdx : &userInterface._v1E;
+
+ if (_v7FECA && userInterface._selectedActionIndex >= 0)
+ userInterface.drawInventory(1, -1, &userInterface._selectedActionIndex);
+
+ var4 = _released && !_v7FECA ? 1 : 0;
+ break;
+
+ case CAT_INV_ANIM:
+ index = 1;
+ indexEnd = invList.size() - 1;
+ varA = 0;
+ topIndex = userInterface._selectedInvIndex;
+ var6 = &var8;
+ var4 = -1;
+ break;
+
+ case CAT_TALK_ENTRY:
+ uiCount = size() - _uiCount;
+ index = scene._hotspots.size();
+ indexEnd = index - 1;
+ varA = 0;
+ topIndex = 0;
+ var6 = &var8;
+ var4 = -1;
+ break;
+
+ default:
+ index = 0;
+ for (int idx = 0; idx < 5; ++idx) {
+ if (!userInterface._talkStrings[idx].empty())
+ ++index;
+ }
+
+ indexEnd = index - 1;
+ varA = 0;
+ topIndex = 0;
+ var6 = &userInterface._v1A;
+ var4 = -1;
+ break;
+ }
+
+ int newIndex = -1;
+ int catIndex = userInterface._categoryIndexes[userInterface._category - 1];
+ int newY = 0;
+ int var1E = 0;
+
+ for (int idx = 0; idx < index & newIndex < 0; ++idx) {
+ warning("TODO");
+ }
+
+ if (newIndex == -1 && index > 0 && !var4) {
+ if (_vm->_events->currentPos().y <= newY) {
+ newIndex = 0;
+ if (varA && _vm->_events->currentPos().x >= var1E)
+ newIndex = varA;
+ } else {
+ newIndex = index - 1;
+ }
+ }
+
+ if (newIndex >= 0)
+ newIndex = MIN(newIndex + topIndex, indexEnd);
+
+ _vm->_game->_scene._highlightedHotspot = newIndex;
+
+ if (_category == CAT_INV_LIST || _category == CAT_INV_ANIM) {
+ if (action._v83338 == 1 && newIndex >= 0 && _released &&
+ (!_vm->_events->_mouseReleased || !_vm->_easyMouse))
+ newIndex = -1;
+ }
+
+ if (_released && !_vm->_game->_screenObjects._v7FECA &&
+ (_vm->_events->_mouseReleased || !_vm->_easyMouse))
+ newIndex = -1;
+
+ if (_category != CAT_HOTSPOT && _category != CAT_INV_ANIM)
+ userInterface.drawInventory(_category, newIndex, var6);
+}
+
/*------------------------------------------------------------------------*/
ScreenSurface::ScreenSurface() {
diff --git a/engines/mads/screen.h b/engines/mads/screen.h
index c8534a0906..1d1e6d34f0 100644
--- a/engines/mads/screen.h
+++ b/engines/mads/screen.h
@@ -158,7 +158,6 @@ public:
int _currentDescId;
bool _released;
int _uiCount;
- int _hotspotsIndex;
uint32 _milliTime;
bool _eventFlag;
@@ -175,6 +174,11 @@ public:
/**
*/
void check(bool scanFlag);
+
+ /**
+ * Handle element being highlighted on the screen
+ */
+ void elementHighlighted();
};
class ScreenSurface : public MSurface {
diff --git a/engines/mads/user_interface.cpp b/engines/mads/user_interface.cpp
index 4dba127d47..cae5c116d2 100644
--- a/engines/mads/user_interface.cpp
+++ b/engines/mads/user_interface.cpp
@@ -188,6 +188,8 @@ UserInterface::UserInterface(MADSEngine *vm) : _vm(vm), _dirtyAreas(vm),
_uiSlots(vm) {
_invSpritesIndex = -1;
_invFrameNumber = 1;
+ _scrollMilli = 0;
+ _scrollFlag = false;
_category = CAT_NONE;
_inventoryTopIndex = 0;
_objectY = 0;
@@ -200,6 +202,7 @@ UserInterface::UserInterface(MADSEngine *vm) : _vm(vm), _dirtyAreas(vm),
_v1E = -1;
_dirtyAreas.resize(50);
_inventoryChanged = false;
+ Common::fill(&_categoryIndexes[0], &_categoryIndexes[7], 0);
// Map the user interface to the bottom of the game's screen surface
byte *pData = _vm->_screen.getBasePtr(0, MADS_SCENE_HEIGHT);
@@ -272,10 +275,6 @@ void UserInterface::setup(int id) {
scene._dynamicHotspots.refresh();
}
-void UserInterface::elementHighlighted() {
- warning("TODO: UserInterface::elementHighlighted");
-}
-
void UserInterface::drawTextElements() {
if (_vm->_game->_screenObjects._v832EC) {
drawTalkList();
@@ -415,6 +414,7 @@ void UserInterface::loadElements() {
}
// Set up actions
+ _categoryIndexes[CAT_ACTION - 1] = _vm->_game->_screenObjects.size() + 1;
for (int idx = 0; idx < 10; ++idx) {
getBounds(CAT_ACTION, idx, bounds);
moveRect(bounds);
@@ -423,6 +423,7 @@ void UserInterface::loadElements() {
}
// Set up inventory list
+ _categoryIndexes[CAT_INV_LIST - 1] = _vm->_game->_screenObjects.size() + 1;
for (int idx = 0; idx < 5; ++idx) {
getBounds(CAT_INV_LIST, idx, bounds);
moveRect(bounds);
@@ -431,6 +432,7 @@ void UserInterface::loadElements() {
}
// Set up the inventory vocab list
+ _categoryIndexes[CAT_INV_VOCAB - 1] = _vm->_game->_screenObjects.size() + 1;
for (int idx = 0; idx < 5; ++idx) {
getBounds(CAT_INV_VOCAB, idx, bounds);
moveRect(bounds);
@@ -439,12 +441,13 @@ void UserInterface::loadElements() {
}
// Set up the inventory item picture
+ _categoryIndexes[CAT_INV_ANIM - 1] = _vm->_game->_screenObjects.size() + 1;
_vm->_game->_screenObjects.add(Common::Rect(160, 159, 231, 194), LAYER_GUI,
CAT_INV_ANIM, 0);
}
if (!_vm->_game->_screenObjects._v832EC || _vm->_game->_screenObjects._v832EC == 2) {
- _vm->_game->_screenObjects._hotspotsIndex = _vm->_game->_screenObjects.size();
+ _categoryIndexes[CAT_HOTSPOT - 1] = _vm->_game->_screenObjects.size();
for (int hotspotIdx = scene._hotspots.size() - 1; hotspotIdx >= 0; --hotspotIdx) {
Hotspot &hs = scene._hotspots[hotspotIdx];
_vm->_game->_screenObjects.add(hs._bounds, LAYER_GUI, CAT_HOTSPOT, hotspotIdx);
@@ -453,6 +456,7 @@ void UserInterface::loadElements() {
if (_vm->_game->_screenObjects._v832EC == 1) {
// setup areas for talk entries
+ _categoryIndexes[CAT_TALK_ENTRY - 1] = _vm->_game->_screenObjects.size() + 1;
for (int idx = 0; idx < 5; ++idx) {
getBounds(CAT_TALK_ENTRY, idx, bounds);
moveRect(bounds);
@@ -644,4 +648,36 @@ void UserInterface::scrollerChanged() {
warning("TODO: scrollerChanged");
}
+void UserInterface::scrollInventory() {
+ Common::Array<int> &invList = _vm->_game->_objects._inventoryList;
+
+ if (_vm->_events->_mouseButtons) {
+ int yp = _vm->_events->currentPos().y;
+ if (yp < MADS_SCENE_HEIGHT || yp == (MADS_SCREEN_HEIGHT - 1)) {
+ uint32 timeDiff = _scrollFlag ? 100 : 380;
+ uint32 currentMilli = g_system->getMillis();
+ _vm->_game->_screenObjects._v8332A = -1;
+
+ if (currentMilli >= (_scrollMilli + timeDiff)) {
+ _scrollMilli = currentMilli;
+ _scrollFlag = true;
+
+ if (yp == (MADS_SCREEN_HEIGHT - 1)) {
+ if (_inventoryTopIndex < (invList.size() - 1)) {
+ ++_inventoryTopIndex;
+ _inventoryChanged = true;
+ }
+ } else {
+ if (_inventoryTopIndex > 0) {
+ --_inventoryTopIndex;
+ _inventoryChanged = true;
+ }
+ }
+ }
+ }
+ }
+
+ _vm->_game->_screenObjects._v8332A = 0;
+}
+
} // End of namespace MADS
diff --git a/engines/mads/user_interface.h b/engines/mads/user_interface.h
index 06f1e70975..abb4619cf5 100644
--- a/engines/mads/user_interface.h
+++ b/engines/mads/user_interface.h
@@ -79,6 +79,8 @@ private:
MADSEngine *_vm;
int _invSpritesIndex;
int _invFrameNumber;
+ uint32 _scrollMilli;
+ bool _scrollFlag;
/**
* Loads the elements of the user interface
@@ -143,6 +145,7 @@ public:
int _v1C;
int _v1E;
bool _inventoryChanged;
+ int _categoryIndexes[8];
Common::StringArray _talkStrings;
Common::Array<int> _talkIds;
public:
@@ -161,8 +164,6 @@ public:
*/
void setup(int id);
- void elementHighlighted();
-
void drawTextElements();
void setBounds(const Common::Rect &r);
@@ -193,6 +194,8 @@ public:
void drawInventory(int v1, int v2, int *v3);
void scrollerChanged();
+
+ void scrollInventory();
};
} // End of namespace MADS