From 605b6fd885f0adbec016bcecac6d557b45873647 Mon Sep 17 00:00:00 2001 From: Vladimir Menshakov Date: Sat, 26 Sep 2009 15:04:09 +0000 Subject: removed packed structs/direct read/writes, so the game should work on big-endian archs. svn-id: r44377 --- engines/teenagent/teenagent.cpp | 56 ++++++++++++++++++++++------------------- 1 file changed, 30 insertions(+), 26 deletions(-) (limited to 'engines/teenagent/teenagent.cpp') diff --git a/engines/teenagent/teenagent.cpp b/engines/teenagent/teenagent.cpp index c6a2fdf123..53d214950e 100644 --- a/engines/teenagent/teenagent.cpp +++ b/engines/teenagent/teenagent.cpp @@ -52,7 +52,7 @@ void TeenAgentEngine::processObject() { dcall += 2 * dst_object->id - 2; uint16 callback = READ_LE_UINT16(dcall); if (callback == 0 || !processCallback(callback)) { - Common::String desc = dst_object->description(); + Common::String desc = dst_object->description; scene->displayMessage(desc); //debug(0, "%s[%u]: description: %s", current_object->name, current_object->id, desc.c_str()); } @@ -61,14 +61,14 @@ void TeenAgentEngine::processObject() { case kActionUse: { InventoryObject *inv = inventory->selectedObject(); if (inv != NULL) { - byte *dcall = res->dseg.ptr(0xbb87); - dcall = res->dseg.ptr(READ_LE_UINT16(dcall + scene->getId() * 2 - 2)); - for (UseObject *obj = (UseObject *)dcall; obj->inventory_id != 0; ++obj) { - if (obj->inventory_id == inv->id && dst_object->id == obj->object_id) { - debug(0, "combine! %u,%u", obj->x, obj->y); + const Common::Array &hotspots = use_hotspots[scene->getId() - 1]; + for (uint i = 0; i < hotspots.size(); ++i) { + const UseHotspot &spot = hotspots[i]; + if (spot.inventory_id == inv->id && dst_object->id == spot.object_id) { + debug(0, "combine! pos?: %u,%u", spot.x, spot.y); //moveTo(Common::Point(obj->x, obj->y), NULL, Examine); inventory->resetSelectedObject(); - if (!processCallback(TO_LE_16(obj->callback))) + if (!processCallback(TO_LE_16(spot.callback))) debug(0, "fixme! display proper description"); return; } @@ -85,7 +85,7 @@ void TeenAgentEngine::processObject() { dcall += 2 * dst_object->id - 2; uint16 callback = READ_LE_UINT16(dcall); if (!processCallback(callback)) - scene->displayMessage(dst_object->description()); + scene->displayMessage(dst_object->description); } } break; @@ -130,6 +130,24 @@ void TeenAgentEngine::examine(const Common::Point &point, Object *object) { } } +void TeenAgentEngine::init() { + Resources * res = Resources::instance(); + use_hotspots.resize(42); + byte *scene_hotspots = res->dseg.ptr(0xbb87); + for(byte i = 0; i < 42; ++i) { + Common::Array & hotspots = use_hotspots[i]; + byte * hotspots_ptr = res->dseg.ptr(READ_LE_UINT16(scene_hotspots + i * 2)); + while(*hotspots_ptr) { + UseHotspot h; + h.load(hotspots_ptr); + hotspots_ptr += 9; + hotspots.push_back(h); + } + } +} + + + void TeenAgentEngine::deinit() { _mixer->stopAll(); delete scene; @@ -138,6 +156,7 @@ void TeenAgentEngine::deinit() { inventory = NULL; //delete music; //music = NULL; + use_hotspots.clear(); Resources::instance()->deinit(); } @@ -207,6 +226,8 @@ Common::Error TeenAgentEngine::run() { scene->init(this, _system); inventory->init(this); + + init(); _system->setMouseCursor(res->dseg.ptr(0x00da), 8, 12, 0, 0, 1); @@ -236,7 +257,7 @@ Common::Error TeenAgentEngine::run() { do { _system->showMouse(true); uint32 t0 = _system->getMillis(); - Object *current_object = findObject(scene->getId(), mouse); + Object *current_object = scene->findObject(mouse); while (_event->pollEvent(event)) { if (event.type == Common::EVENT_RTL) { @@ -314,23 +335,6 @@ Common::Error TeenAgentEngine::run() { return Common::kNoError; } -Object *TeenAgentEngine::findObject(int id, const Common::Point &point) { - Resources *res = Resources::instance(); - uint16 addr = res->dseg.get_word(0x7254 + (id - 1) * 2); - //debug(0, "object base: %04x, x: %d, %d", addr, point.x, point.y); - uint16 object; - for (; (object = res->dseg.get_word(addr)) != 0; addr += 2) { - if (object == 0) - return NULL; - - Object *obj = (Object *)res->dseg.ptr(object); - //obj->dump(); - if (obj->enabled != 0 && obj->rect.in(point)) - return obj; - } - return NULL; -} - void TeenAgentEngine::displayMessage(const Common::String &str, byte color) { if (str.empty()) { return; -- cgit v1.2.3