From 989ba681bc06ecf0b7965916b36a0da7c99ee115 Mon Sep 17 00:00:00 2001 From: Paul Gilbert Date: Fri, 31 Jul 2015 21:43:35 -0400 Subject: SHERLOCK: RT: Mousing over an NPC overrides any bg object at the same place --- engines/sherlock/tattoo/tattoo_scene.cpp | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) (limited to 'engines/sherlock/tattoo') diff --git a/engines/sherlock/tattoo/tattoo_scene.cpp b/engines/sherlock/tattoo/tattoo_scene.cpp index 13206f0dac..2e837968e7 100644 --- a/engines/sherlock/tattoo/tattoo_scene.cpp +++ b/engines/sherlock/tattoo/tattoo_scene.cpp @@ -748,21 +748,21 @@ int TattooScene::findBgShape(const Common::Point &pt) { // New frame hasn't been drawn yet return -1; - - for (int idx = (int)_bgShapes.size() - 1; idx >= 0; --idx) { + int result = -1; + for (int idx = (int)_bgShapes.size() - 1; idx >= 0 && result == -1; --idx) { Object &o = _bgShapes[idx]; if (o._type != INVALID && o._type != NO_SHAPE && o._type != HIDDEN && (o._aType <= PERSON || (ui._menuMode == LAB_MODE && o._aType == SOLID))) { if (o.getNewBounds().contains(pt)) - return idx; + result = idx; } else if (o._type == NO_SHAPE) { if (o.getNoShapeBounds().contains(pt)) - return idx; + result = idx; } } - // If no shape found, so check whether a character is highlighted + // Now check for the mouse being over an NPC. If so, it overrides any found bg object for (int idx = 1; idx < MAX_CHARACTERS; ++idx) { Person &person = people[idx]; @@ -778,11 +778,11 @@ int TattooScene::findBgShape(const Common::Point &pt) { - charRect.height()); if (charRect.contains(pt)) - return 1000 + idx; + result = 1000 + idx; } } - return -1; + return result; } void TattooScene::synchronize(Serializer &s) { -- cgit v1.2.3