Difference between revisions of "Myst WDIB resources"

From A look inside The Link @ wiki
Jump to: navigation, search
(adding the details of the Myst WDIB compression)
 
(the LZ decompression info has moved to the Mohawk Bitmaps page)
 
(5 intermediate revisions by 2 users not shown)
Line 1: Line 1:
 
{{Myst}}
 
{{Myst}}
This page documents the WDIB image format for all images in the original Windows version of Myst and the cursors in Myst Masterpiece Edition. It is similar to LZ77 with a 0x400 byte ring-buffer. Once uncompressed, it is a plain Windows BMP 8bpp and the bitmap is not compressed. It is in little endian form. Thanks to Petroff Heroj and Ron Hayter for working out the compression.
+
WDIB resources store compressed images in the original Windows version of Myst, some images in Myst Masterpiece Edition, and cursors.
  
 +
The data is laid out like this:
  
 
{| class="structure"
 
{| class="structure"
 
|-
 
|-
|unsigned short||uncompressed size
+
|unsigned long||uncompressed size
 
|-
 
|-
 
|variable||compressed data
 
|variable||compressed data
 
|}
 
|}
  
 +
For the compressed data, it uses the same [[Mohawk Bitmaps#LZ Compression|LZ Compression]] as some tBMP's!
  
Until the end of the resource, each run begins with a byte. Each bit (0-7) defines what to do next. A 1 is an absolute byte (which is directly read into the uncompressed buffer) and a 0 represents two bytes to be read in. The front 6 bits (2-7) represent the length of the run minus 3. The last 10 bits represent the offset in the ring-buffer minus 0x42. If the offset is over 0x400, make sure to subtract 0x400 after adding the 0x42 back into the offset.
+
Once decoded, a plain uncompressed [http://en.wikipedia.org/wiki/BMP_file_format Windows BMP] is recovered. All in the original Myst are 8bpp. However, some in Myst ME are 24bpp (like the images in Help.dat) but the cursors are still 8bpp.
 
+
The ring-buffer has a constant size of 0x400 bytes. Remember that once you have decoded 0x400 bytes, it loops around to the beginning, completing the loop.
+
 
+
For example:
+
<pre>
+
0xf7                    // decoder byte (11110111b)
+
0x87                    // absolute byte
+
0x73                    // absolute byte
+
0x27                    // absolute byte
+
0x27                    // absolute byte
+
0x0b                    // byte 1 of the run data: length = 2 + 3 = 5 (first 6 bits + 3)
+
0xa9                    // byte 2 of the run data: offset = 0x3a9 + 0x42 = 0x3eb
+
0x32                    // absolute byte
+
0x00                    // absolute byte
+
0x4e                    // absolute byte
+
</pre>
+
 
+
From there, see the wikipedia page on the [http://en.wikipedia.org/wiki/BMP_file_format Bitmap file format].
+

Latest revision as of 22:48, 17 August 2009

Myst
Mohawk Overview
CLRC EXIT HINT INIT
MJMP MSND PICT RLST
VIEW WDIB HELP RSFL
Scripts Variables

WDIB resources store compressed images in the original Windows version of Myst, some images in Myst Masterpiece Edition, and cursors.

The data is laid out like this:

unsigned long uncompressed size
variable compressed data

For the compressed data, it uses the same LZ Compression as some tBMP's!

Once decoded, a plain uncompressed Windows BMP is recovered. All in the original Myst are 8bpp. However, some in Myst ME are 24bpp (like the images in Help.dat) but the cursors are still 8bpp.