Skip to content

Latest commit

 

History

History
178 lines (126 loc) · 5.98 KB

README.md

File metadata and controls

178 lines (126 loc) · 5.98 KB

The Lost Vikings/Blackthorne Tools

This is a library and a set of tools based on a partial reverse engineering of the DOS games The Lost Vikings and Blackthorne. The Lost Vikings is copyright Silicon and Synapse (now Blizzard) and was published by Interplay in 1992. Blackthrone is copyright Blizzard and was published in 1994.

Both games are now freely available from Blizzard:

https://us.battle.net/account/download/?show=classic

License

These tools are public domain. The code may be freely incorporated into other projects, either source or binary.

Library

The library code is in liblv and provides APIs for handling the various data formats used by The Lost Vikings and Blackthorne. The compiler and disassembler are in the vm directory. These tools currently only support The Lost Vikings.

Tools

The tools are:

  • pack_tool: Tool for extracting, decompressing and repacking the DATA.DAT file.

  • sprite_view: A viewer for the various sprites formats used by the games.

  • tileset_view: A viewer for the 16x16 tilesets used by the games.

  • level_view: A very basic, incomplete level viewer.

  • vm/disasm.py: A decompiler for the virtual machine used by The Lost Vikings. This is not yet supported for Blackthorne.

  • vm/compiler.py: A compiler for the virtual machine used by The Lost Vikings. This is not yet supported for Blackthorne.

The tools have been tested with a version of The Lost Vikings with the following MD5 sums:

  • 8807a952565c13e428988d87021095c8 VIKINGS.EXE
  • d0f8a04202070a54d1909758ecd962b5 DATA.DAT

For Blackthorne:

  • 830ea49bd3995f557524ac45384ca9ca BTHORNE.EXE
  • d776516e6452cb7d6a3eb12a1876c49c DATA.DAT

Run each of the tools with --help to see the command line options. The source for the pack and sprite viewer tools also contain comments with some example usages.

When using the tools for Blackthorne the --blackthorne argument should be passed.

Level Viewer

Run the level viewer with the path to DATA.DAT and the level number (numbering starts at 1). For example to view the first level of The Lost Vikings:

./level_view /path/to/vikings/DATA.DAT 1

To view the practice stage of Blackthorne:

./level_view /path/to/blackthorne/DATA.DAT --blackthorne 2

Both games encode splash screens and cutscenes as levels. These can also be viewed with the level viewer (see liblv/lv_level.c for the level numbers).

The arrow keys move the view, and clicking a tile or object will show information about it. The following keys may also be used:

Key Effect
F Toggles drawing the foreground tiles
B Toggles drawing the background tiles
O Toggles drawing objects
G Toggles grid
R Toggles drawing object bounding boxes

Building

The level and sprite viewers require the SDL library. The tools have only been tested on Linux, but should require minimal porting effort to other operating systems. To build the library and the tools:

make

Documentation

The library is documented using Doxygen. To build and view the documentation:

make docs
google-chrome docs/html/index.html

Known Bugs/Missing Features

There are lots:

  • The source contains almost no error checking (I am lazy). The tools will generally crash if passed incorrect arguments or invalid data.

  • Some levels, notably most of the special levels, will crash the level viewer.

  • Many larger Blackthorne levels do not render correctly in the level view. It appears that parts of the map are "folded", while other parts render correctly. Some tiles are incorrect, for example some levels have tiles containing font characters.

  • Blackthorne has secondary tile maps that appear to be used for rendering the background or sky. This are not yet supported. Initial attempts result in obviously incorrect rendering.

  • Many sprites are either not rendered, or rendered incorrectly by the level viewer. This is due to the following problems:

    • Packed 32x32 object sprites are not drawn. I currently do not know how the game specifies which sprite set to draw for this format.

    • Many unpacked sprites are drawn with the wrong size, resulting in a corrupted image. Objects have a width and height which appears to be a bounding box (for example the two doors on level one, which are the same type, have different bounding boxes). The object database entry for the type (basically the object's class) also has a width and height, but these do not correspond directly to the sprite size.

    • Some objects, such as doors, are comprised of multiple sprites. The level viewer will only draw the first sprite in the set.

    • Some objects, such as collectibles, use a single sprite set for multiple different objects. The level viewer will only draw the first sprite from the set. It is not fully understood how the correct frame is chosen by the game.

    • The Vikings are not always drawn in their correct start positions.

    • Palette animations are not supported. The information about them is decoded, but not fully understood.

    • Sprites are not yet drawn for Blackthorne levels. The bounding boxes for objects are drawn.

  • The tileset viewer does not properly support palettes. Tilesets in Blackthorne may use multiple palettes which are encoded in the level header.

  • The object database contains programs for a virtual machine, which is used to control the behaviour of the game objects. It appears that it also dictates how to render the game objects. The rendering parts of the virtual machine have not yet been reversed.

  • I have not bothered to reverse the music or sound formats. The music format appears to be Extended Multiple Instrument Digital Interface (XMI).