Difference between revisions of "Freescape"
Neuromancer (talk | contribs) |
Neuromancer (talk | contribs) |
||
Line 80: | Line 80: | ||
* Chris Allen for providing valuable information and code for reproducing sound effects. He also provided high-definition recorded versions of emulated Driller sounds which are used by this engine. | * Chris Allen for providing valuable information and code for reproducing sound effects. He also provided high-definition recorded versions of emulated Driller sounds which are used by this engine. | ||
* Santiago Ontañón for | * Franck "hitchhikr" Charlet for disassembling and documenting Driller for Amiga: https://github.com/hitchhikr/driller (2020) | ||
* Santiago Ontañón for disassembling, investigate and annotate "Castle Master II: The Crypt" for ZX Spectrum: https://github.com/santiontanon/castlemaster2-disassembly (2023) | |||
==Bugs== | ==Bugs== |
Revision as of 19:03, 24 July 2023
Freescape | ||
---|---|---|
Engine developer | neuromancer | |
Companies that used it | Incentive Software | |
Games that use it | 3D Construction Kit, 3D Construction Kit 2.0, Castle Master, Castle Master II: The Crypt, Dark Side, Driller, Total Eclipse, Total Eclipse II: The Sphinx Jinx | |
Date added to ScummVM | 2022-11-10 | |
First release containing it | 2.7.0 |
About
The original Freescape was one of the first 3D game engines, developed by Incentive Software for the game Driller in 1987 and following games, culminating in an easy to use game editor called 3D Construction Kit 2.0 in 1992, which was used to make a few amateur games.
ScummVM reimplementation
Our freescape reimplementation aims to emulate the original one, with the following improvements:
- Three renderers available: TinyGL using software in their original resolution (320x200) and OpenGL in arbitrary resolution (with and without shaders).
The new ScummVM renderers remove completely the artifacts of the original freescape engine, since they perform computation on floats instead of integers.
- Mouse and mouselook support for every game. For instance, the original Driller only had mouse support for Amiga and Atari, the rest of the releases allowed to use only keyboard or joystick.
- Unified controls: Different releases featured different type of inputs and controls. ScummVM implementation unified them.
- Faster framerate. The original games run at 10fps (or less) while our implementation aims to have around 60fps or more. In theory, this should not affect the gameplay but this is still an area of research.
- More precise collision resolution to avoid artifacts and bugs.
- Quick save/load shortcuts
- Fixes for original bugs.
Optional features:
- Support for alternative controls (e.g. WASD keys or touchpad controls in mobile). This is an upcoming feature.
- Support for high-quality pre-recorded sounds: the DOS releases uses PC speaker sounds, which will not sound exactly the same if they are emulated, so we included pre-recorded version from real hardware. The same will be available for other releases which do not feature sample sounds (C64, ZX Spectrum and AmstradCPC).
- Restored music from different releases: most of the Freescape game releases do not feature any music at all (e.g. the DOS releases). Our implementation will allow, if the user owns more than one release, to replay the music from one release using other one. It will also allow to include restored music in the future.
- Extended cheats.
How to switch different renderers
The most prominent feature of the ScummVM reimplementation is the use of different renderers such as TinyGL or OpenGL. These can be selected changing the option in "Game 3D Renderer" either in the "Global Options..." (for all games) or the "Game Options.." for the Freescape games.
Roadmap
The Freescape technology evolved from 1987 to 1992. Our engine will progress supporting the following games/releases:
1. Driller DOS (EGA), Amiga and AtariST releases: Done.
2. Additional Driller releases: DOS (CGA, Tandy, Hercules), C64, AmstradCPC and ZX Spectrum: Done, except for the C64 release which has partial support. Tandy and Hercules support will be added later.
3. Dark Side (EGA), Amiga and AtariST releases: In progress.
4. Additional Dark side releases: DOS (CGA, Tandy, Hercules), C64, AmstradCPC and ZX Spectrum.
5. Total Eclipse / Total Eclipse II
6. Castle Master / Castle Master II: The Crypt
7. 3D Construction Kit demo game and other games
8. 3D Construction Kit 2.0 demo game and other games
Re-implementing the 3D Construction Kit itself (the program used to create games) is outside the scope of this project. ScummVM will only allow to play games already released, not create new ones.
History
The reverse engineering of the original engine and code development took several decades (!) and includes the following people:
- John Elliott for reverse engineering the file formats for 8-bit games and producing some code for rendering levels (2001)
- Thomas Harte for reverse engineering part of the file formats for 16-bit games as well as creating the original code of Phantasma, which served as initial code for this engine: https://github.com/TomHarte/Phantasma/ (2013).
- Jason "Joefish" Railton for providing some example code on decoding of Atari-ST Neochrome (.NEO) format low-resolution 16-colour images (2016).
- Richard Quirk for providing valuable information of the reverse engineering of Castle Master and other Freescape games.
- Chris Allen for providing valuable information and code for reproducing sound effects. He also provided high-definition recorded versions of emulated Driller sounds which are used by this engine.
- Franck "hitchhikr" Charlet for disassembling and documenting Driller for Amiga: https://github.com/hitchhikr/driller (2020)
- Santiago Ontañón for disassembling, investigate and annotate "Castle Master II: The Crypt" for ZX Spectrum: https://github.com/santiontanon/castlemaster2-disassembly (2023)
Bugs
Freescape games allowed a level of freedom in movement that was ahead of their time. As expected, with the increased complexity of their engine, it also included some bugs. This is an incomplete list of bugs in the original implementations, indicating if the bug is already fixed (✓) or not fixed (✗) in ScummVM:
✓ Rendering artifacts caused by imprecise computation during screen updates.
✓ Approaching geometric objects in different angles results in no interaction at all. This can be reproduced approaching an entrance to another area in a very skew angle. The player will not trigger the entrance, instead it will collided and be rejected by the object.
✓ Interacting with corners sometimes results in traveling to the incorrect area.
Cheats
The ScummVM reimplementation of Freescape features a number of generic cheats that are implemented for every supported game:
- Avoid failing: this disable falling in edges. The player will not able to complete a movement if it causes to fall.
- Disable sensor: sensors will not shoot the player.
- Extended timer: the game timer will be set to 99:59:59, which should give plenty of time to finish any game.