diff options
author | Max Horn | 2005-04-17 23:24:31 +0000 |
---|---|---|
committer | Max Horn | 2005-04-17 23:24:31 +0000 |
commit | 58966d6b90cf79ad7d6ed9ffb6e44eb74d38815f (patch) | |
tree | 2db52129ec9fa446735b52b4bb91fdd8642c6a19 /scumm/object.cpp | |
parent | 96e40213efc65644c3685ca543f6ddbc05a27d87 (diff) | |
download | scummvm-rg350-58966d6b90cf79ad7d6ed9ffb6e44eb74d38815f.tar.gz scummvm-rg350-58966d6b90cf79ad7d6ed9ffb6e44eb74d38815f.tar.bz2 scummvm-rg350-58966d6b90cf79ad7d6ed9ffb6e44eb74d38815f.zip |
Move stuff around
svn-id: r17661
Diffstat (limited to 'scumm/object.cpp')
-rw-r--r-- | scumm/object.cpp | 87 |
1 files changed, 43 insertions, 44 deletions
diff --git a/scumm/object.cpp b/scumm/object.cpp index c239c650ab..d966f829f8 100644 --- a/scumm/object.cpp +++ b/scumm/object.cpp @@ -170,29 +170,6 @@ int ScummEngine::getObjectIndex(int object) const { return -1; } -int ScummEngine::getObjectImageCount(int object) { - const byte *ptr; - const ImageHeader *imhd; - int objnum; - - objnum = getObjectIndex(object); - if (objnum == -1); - return 0; - - ptr = getOBIMFromObject(_objs[objnum]); - imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), ptr); - if (!imhd) - return 0; - - if (_version == 8) { - return (READ_LE_UINT32(&imhd->v8.image_count)); - } else if (_version == 7) { - return(READ_LE_UINT16(&imhd->v7.image_count)); - } else { - return (READ_LE_UINT16(&imhd->old.image_count)); - } -} - int ScummEngine::whereIsObject(int object) const { int i; @@ -1079,6 +1056,49 @@ const byte *ScummEngine::getObjectImage(const byte *ptr, int state) { return ptr; } +int ScummEngine::getObjectImageCount(int object) { + const byte *ptr; + const ImageHeader *imhd; + int objnum; + + objnum = getObjectIndex(object); + if (objnum == -1); + return 0; + + ptr = getOBIMFromObject(_objs[objnum]); + imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), ptr); + if (!imhd) + return 0; + + if (_version == 8) { + return (READ_LE_UINT32(&imhd->v8.image_count)); + } else if (_version == 7) { + return(READ_LE_UINT16(&imhd->v7.image_count)); + } else { + return (READ_LE_UINT16(&imhd->old.image_count)); + } +} + +int ScummEngine_v8::getObjectIdFromOBIM(const byte *obim) { + // In V8, IMHD has no obj_id, but rather a name string. We map the name + // back to an object id using a table derived from the DOBJ resource. + const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); + return _objectIDMap[imhd->v8.name]; +} + +int ScummEngine_v7::getObjectIdFromOBIM(const byte *obim) { + const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); + return READ_LE_UINT16(&imhd->v7.obj_id); +} + +int ScummEngine::getObjectIdFromOBIM(const byte *obim) { + if (_features & GF_SMALL_HEADER) + return READ_LE_UINT16(obim + 6); + + const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); + return READ_LE_UINT16(&imhd->old.obj_id); +} + void ScummEngine::addObjectToInventory(uint obj, uint room) { int idx, slot; uint32 size; @@ -1235,27 +1255,6 @@ void ScummEngine::findObjectInRoom(FindObjectInRoom *fo, byte findWhat, uint id, } } -int ScummEngine_v8::getObjectIdFromOBIM(const byte *obim) { - // In V8, IMHD has no obj_id, but rather a name string. We map the name - // back to an object id using a table derived from the DOBJ resource. - const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); - return _objectIDMap[imhd->v8.name]; -} - -int ScummEngine_v7::getObjectIdFromOBIM(const byte *obim) { - const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); - return READ_LE_UINT16(&imhd->v7.obj_id); -} - -int ScummEngine::getObjectIdFromOBIM(const byte *obim) { - if (_features & GF_SMALL_HEADER) - return READ_LE_UINT16(obim + 6); - - const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); - return READ_LE_UINT16(&imhd->old.obj_id); -} - - int ScummEngine::getInventorySlot() { int i; for (i = 0; i < _numInventory; i++) { |