aboutsummaryrefslogtreecommitdiff
path: root/devtools/create_titanic
diff options
context:
space:
mode:
authorPaul Gilbert2016-07-22 21:44:50 -0400
committerPaul Gilbert2016-07-22 21:55:36 -0400
commit7f05cfad13fbce82326542d9bdd0dd0473565baf (patch)
tree46aab0af0c26e78710409ea1636871faec2818bb /devtools/create_titanic
parent4f08292c8c082361af7212e3951af4b1b6c45199 (diff)
downloadscummvm-rg350-7f05cfad13fbce82326542d9bdd0dd0473565baf.tar.gz
scummvm-rg350-7f05cfad13fbce82326542d9bdd0dd0473565baf.tar.bz2
scummvm-rg350-7f05cfad13fbce82326542d9bdd0dd0473565baf.zip
DEVTOOLS: Save create_titanic bitmap resources with correct bitmap headers
Diffstat (limited to 'devtools/create_titanic')
-rw-r--r--devtools/create_titanic/create_titanic_dat.cpp66
1 files changed, 51 insertions, 15 deletions
diff --git a/devtools/create_titanic/create_titanic_dat.cpp b/devtools/create_titanic/create_titanic_dat.cpp
index 2ea8f2a676..ed263d7b77 100644
--- a/devtools/create_titanic/create_titanic_dat.cpp
+++ b/devtools/create_titanic/create_titanic_dat.cpp
@@ -279,9 +279,9 @@ void writeResource(const char *name, Common::File *file) {
delete file;
}
-void writeResource(const char *sectionStr, const uint32 resId) {
+void writeResource(const char *sectionStr, uint32 resId) {
char nameBuffer[256];
- sprintf(nameBuffer, "%s/%d", sectionStr, resId);
+ sprintf(nameBuffer, "%s/%u", sectionStr, resId);
Common::File *file = res.getResource(getResId(sectionStr), resId);
assert(file);
@@ -298,6 +298,43 @@ void writeResource(const char *sectionStr, const char *resId) {
writeResource(nameBuffer, file);
}
+void writeBitmap(const char *name, Common::File *file) {
+ outputFile.seek(dataOffset);
+
+ // Write out the necessary bitmap header so that the ScummVM
+ // BMP decoder can properly handle decoding the bitmaps
+ outputFile.write("BM", 2);
+ outputFile.writeLong(file->size() + 14); // Filesize
+ outputFile.writeLong(0); // res1 & res2
+ outputFile.writeLong(0x436); // image offset
+
+ outputFile.write(*file, file->size() + 14);
+
+ writeEntryHeader(name, dataOffset, file->size() + 14);
+ dataOffset += file->size() + 14;
+ delete file;
+}
+
+void writeBitmap(const char *sectionStr, const char *resId) {
+ char nameBuffer[256];
+ sprintf(nameBuffer, "%s/%s", sectionStr, resId);
+
+ Common::File *file = res.getResource(getResId(sectionStr),
+ Common::WinResourceID(resId));
+ assert(file);
+ writeBitmap(nameBuffer, file);
+}
+
+void writeBitmap(const char *sectionStr, uint32 resId) {
+ char nameBuffer[256];
+ sprintf(nameBuffer, "%s/%u", sectionStr, resId);
+
+ Common::File *file = res.getResource(getResId(sectionStr),
+ Common::WinResourceID(resId));
+ assert(file);
+ writeBitmap(nameBuffer, file);
+}
+
void writeNumbers() {
outputFile.seek(dataOffset);
@@ -357,7 +394,6 @@ void writeResponseTree() {
dataOffset += size;
}
-
void writeSentenceEntries(const char *name, uint tableOffset) {
outputFile.seek(dataOffset);
@@ -462,18 +498,18 @@ void writeHeader() {
}
void writeData() {
- writeResource("Bitmap", "BACKDROP");
- writeResource("Bitmap", "EVILTWIN");
- writeResource("Bitmap", "RESTORED");
- writeResource("Bitmap", "RESTOREF");
- writeResource("Bitmap", "RESTOREU");
- writeResource("Bitmap", "STARTD");
- writeResource("Bitmap", "STARTF");
- writeResource("Bitmap", "STARTU");
- writeResource("Bitmap", "TITANIC");
- writeResource("Bitmap", 133);
- writeResource("Bitmap", 164);
- writeResource("Bitmap", 165);
+ writeBitmap("Bitmap", "BACKDROP");
+ writeBitmap("Bitmap", "EVILTWIN");
+ writeBitmap("Bitmap", "RESTORED");
+ writeBitmap("Bitmap", "RESTOREF");
+ writeBitmap("Bitmap", "RESTOREU");
+ writeBitmap("Bitmap", "STARTD");
+ writeBitmap("Bitmap", "STARTF");
+ writeBitmap("Bitmap", "STARTU");
+ writeBitmap("Bitmap", "TITANIC");
+ writeBitmap("Bitmap", 133);
+ writeBitmap("Bitmap", 164);
+ writeBitmap("Bitmap", 165);
writeResource("STFONT", 149);
writeResource("STFONT", 151);