/* ScummVM - Graphic Adventure Engine * * ScummVM is the legal property of its developers, whose names * are too numerous to list here. Please refer to the COPYRIGHT * file distributed with this source distribution. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . * */ #ifndef TWINE_RESOURCES_HQR_H #define TWINE_RESOURCES_HQR_H #include "common/scummsys.h" #include "common/stream.h" #include "graphics/palette.h" #include "twine/shared.h" namespace TwinE { class TwinEEngine; /** * High Quality Resource * * https://web.archive.org/web/20181218233826/http://lbafileinfo.kazekr.net/index.php?title=High_quality_resource */ namespace HQR { /** * Get a HQR entry pointer * @param ptr pointer to save the entry * @param filename HQR file name * @param index entry index to extract * @return entry real size */ int32 getEntry(uint8 *ptr, const char *filename, int32 index); inline int32 getEntry(uint8 *ptr, const TwineResource &resource) { return getEntry(ptr, resource.hqr, resource.index); } /** * Get a HQR entry pointer * @param filename HQR file name * @param index entry index to extract * @return entry real size */ int32 entrySize(const char *filename, int32 index); inline int32 entrySize(const TwineResource &resource) { return entrySize(resource.hqr, resource.index); } /** * Get a HQR total number of entries * @param filename HQR file name * @return total number of entries */ int32 numEntries(const char *filename); /** * Get a HQR entry pointer with memory allocation * @param ptr pointer to save the entry. This pointer is automatically freed and therefore must be initialized * to @c nullptr on the first run. * @param filename HQR file name * @param index entry index to extract * @return entry real size */ int32 getAllocEntry(uint8 **ptr, const char *filename, int32 index); inline int32 getAllocEntry(uint8 **ptr, const TwineResource &resource) { return getAllocEntry(ptr, resource.hqr, resource.index); } /** * @brief Helper method to dump the content of the given hqr index to a file */ bool dumpEntry(const char *filename, int32 index, const char *targetFileName); inline bool dumpEntry(const TwineResource &resource, const char *targetFileName) { return dumpEntry(resource.hqr, resource.index, targetFileName); } /** * Get a HQR entry pointer * @param ptr pointer to save the entry * @param filename HQR file name * @param index entry index to extract * @return entry real size */ int32 getVoxEntry(uint8 *ptr, const char *filename, int32 index, int32 hiddenIndex); /** * Get a HQR entry pointer with memory allocation * @param ptr pointer to save the entry. This pointer is automatically freed and therefore must be initialized * to @c nullptr on the first run. * @param filename HQR file name * @param index entry index to extract * @return entry real size */ int32 getAllocVoxEntry(uint8 **ptr, const char *filename, int32 index, int32 hiddenIndex); bool getPaletteEntry(Graphics::Palette &palette, const char *filename, int32 index); inline bool getPaletteEntry(Graphics::Palette &palette, const TwineResource &resource) { return getPaletteEntry(palette, resource.hqr, resource.index); } Common::SeekableReadStream *makeReadStream(const char *filename, int index); inline Common::SeekableReadStream *makeReadStream(const TwineResource &resource) { return makeReadStream(resource.hqr, resource.index); } } // namespace HQR } // namespace TwinE #endif