Proto:Prey (2006)/1995 Prototype
This prototype is documented on Hidden Palace.
This is a sub-page of Proto:Prey (2006).
On December 25th, 2022, Hogsy of gaming preservation site TalonBrave.info would release a prototype of Prey from 1995. The build is dated November 9th, 1995. It was made during Tom Hall's lead on the project and was a pitch demo shown to GT Interactive, the publisher of Prey until 1999.[1]
This version of the game would continue to be worked on until August 1996, when much of the team, notably Hall would leave 3D Realms. Paul Schuytema would then be brought in were by November that year, everything would be scrapped in favor of a new vision and engine.
The build is more of a tech demo then a game, with the only thing to do is just wandering around. Outside of the sci-fi setting and name, nothing from this version of the game would appear in later builds or versions. To extract content from the prototype, it is recommended to use glPrey.
To do: Nearly done, just a few outlying things left:
|
This needs some investigation. Discuss ideas and findings on the talk page. Specifically:
|
Contents
Features
General
- Text saying " goddamnit!" (sic) can appear in game when loading into a map with the console open or when the game crashes. The message will rapidly appear and disappear, causing the screen to glitch out.
- The game is dead silent and has no sounds.
- The game possesses no HUD, weapons, enemies or portals.
- Portals seemingly were never considered for this iteration of the game.
- The game will check for a mouse open loading into the map.
- The build is generally quite unstable and will crash often, especially with its default settings. Disabling some variables in console, like mipmapping, can improve performance.
Platform
This build runs on DOS, whereas the final game was released for Windows, Xbox 360, Mac OS X, and Linux.
Engine
The game runs on a proprietary game engine from 3D Realms called Prey Engine, (the developers also gave the engine various inside joke names such as "Tears" which according to them is "what our competitors will be shedding when they see how cool it is")[2] primarily developed by the late William Scarboro. No commercial product ever made use of this engine.
The engine itself appears to be real-time 3D, processing basic collision and physics.
Paul Schuytema's 1996-1998 "Talon Brave" iteration of the game also used an engine called "Prey Engine" but it was separate from this one.
The final game runs on a modified version of id Tech 4.
WAD
The game uses a .WAD file to store its data, not so dissimilar to games like Doom, Quake and Rise of the Triad. The file is called MACT.WAD.
Controls
- Movement is handled with arrow keys: up or Mouse 2 will move you forward and down or Mouse 3 will move you backward, left and right will turn the camera.
- A will move you up, Z will move you down.
- X will strafe left, C will strafe right.
- W will cycle between three different rendering options: wireframe, flat shading and full rendering. By default, the build starts with wireframe rendering.
Wireframe | Flat Shading | Full Rendering |
---|---|---|
L will enable or disable an "auto leveling" mode, where the camera will automatically snap itself into a neutral position after you move it in a direction.
G will turn on or off gravity.
F will bring up some numbers displaying a measurement of time, but the purpose of them is unclear. The numbers appear to be randomly chosen from a pre-set list. Pressing F at the boot screen will show the player having "inf" time.
Space will perform a jump, but it only moves very slightly up in the build. pressing repeatably or holding space will make you move up regardless of if gravity is turned off or on.
Console
Tab ↹ will open the console; the console in the final game is opened with Crtl+Alt+~.
Prototype | Final |
---|---|
- help - List all the available commands.
- record - Records a demo.
- save - Stops recording of a demo.
- play - Plays a demo.
- load - Load into a map.
- print - Stats a specified variable in the console.
- set - Enable/disable a variable.
Variables that can be used with "print" and "set" include:
- mipmap - Enables/disables mipmapping. Enabled by default.
- shading - Enables/disables shading. Enabled by default.
- blockshading - Enables/disables "block shading". Enabled by default.
- span - Enables/disables textures. Enabled by default.
- volumerender - Enables/disables some sort of coordinate marker. Disabled by default. Disabling it again will cause a purple line to appear on the bottom of the screen.
- cellvis - Enables/disables complete rendering of the map. Enabled by default
- "precision", "videosize" and "videotype" can also be modified with the command but it is not known what they do precisely.
Mipmapping True (Full Rendering) | Mipmapping False (Full Rendering) | Mipmapping True (Wireframe) | Mipmapping False (Wireframe) |
---|---|---|---|
Cellvis True | Cellvis False | ||
Demos
To do: Add a video of the demos. |
The prototype has a few demo files (with .DMO as an extension) named MARK, MARK2 and TEST. The demos themselves are very fast and only feature wondering around the map.
The demos named "Mark" presumably refer to Mark Dochtermann, a former developer of Prey.
Crashing
When the prototype crashes, often the screen will become filled with garbage and the DOS command line will be made available. Otherwise, it will just crash to a black DOS screen with a message stating the cause of the crash.
Map
There is only a single map present, known as DEMO4.BSP. To load into the map, open the console at the bootup menu and type "load demo4" or start the build with "prey demo4" at DOS.
It is rather easy to get stuck in the collision of the map and you will have to turn gravity off to get out.
Starting Area
The area that the player starts at when the map loads in. It features a structure in the middle of the room and two hallways that lead to other areas of the map. The hallway to the player's right leads a hallway to a room with light. To the back of the room is a ramp that leads to various rooms.
Room with Light
The room with light features a large talon-like structure, various stalagmites and light. The room is a dead end.
Room with Bridge
A room with a bridge. The ceiling features a large cross. A window can be seen to the side of the room.
Room with Square Holes
A room with four square holes on the floor. The two protruding spikes on the right wall lack collision. The left wall has two pillars in each corner with lights.
The walls of the hallway after this room don't have any collision.
Large Room
A large room at the end of the downward rooms, it features a large cross above, a large purple pillar, some lights and a sign with the letters "GTIS", referring to GT Interactive Software. The spikes protruding out the walls also lack collision.
As seen in some prerelease screenshots, this room once had some details that are absent from the build.
- The sign said "PREY" instead of "GTIS".
- A large gray room can be seen to the distance, with a doorway leading to it.
To do: Any possible remnants of these? |
Prerelease Screenshot | Prototype |
---|---|
Prerelease Screenshot | Prototype |
Prerelease Screenshot | Prototype |
Textures
The build has various textures found in the WAD. None of the textures present made their way into the final game. Hogsy had released some textures in 2020 prior to releasing the prototype.
To do: Note which textures are unused. |
There are also a variety of textures from Rise of the Triad. These textures were likely used during the early stages of the project before more original art was made.
The colormap used by the prototype.
Text
Unused text found in the executable.
To do:
|
iew.bsp
venguv.dat
?m.bin
Atemact.wad
dlprey.exe
mar.dmo
aiERROR.TXT
Various files that don't exist in the prototype.
?cam.dmp camera saved ttcamera loaded at %f %f %f
Some kind of camera function?
D:\SOURCE\PREY\engine.c D:\SOURCE\PREY\clip.c D:\SOURCE\PREY\input.c D:\SOURCE\PREY\loader.c D:\SOURCE\PREY\surface.c D:\SOURCE\PREY\texture.c D:\SOURCE\PREY\preymain.c D:\SOURCE\PREY\span.c D:\SOURCE\PREY\vector3.c D:\SOURCE\PREY\cli.c D:\SOURCE\PREY\cli_util.c D:\SOURCE\PREY\actor.c
raster.asm P:\LIBMACT\clrmap.c fopen fclose set386 P:\LIBMACT\util_lib.c P:\LIBMACT\vidmsdos.c precise.asm P:\LIBMACT\wad.c
P:\LIBMACT\crc.c
P:\LIBMACT\task_man.c
Strings of the source tree of the engine at the time of the build's creation.
VECTOR3_VectorAdd_ VECTOR3_VectorSub_ VECTOR3_ScaleVector_ VECTOR3_VectorLength_ v VECTOR3_NormalizeVector_lv VECTOR3_2x2Det_ VECTOR3_CrossProduct_ VECTOR3_TripleProduct_(w VECTOR3_DecomposeVector_tw VECTOR3_RotateVAV_H& __IVECT& __JVEC __KVECl& __ZEROVECx& _clistarted CLI_Setup_ CLI_ReadSetup_Dy CLI_WriteSetup_ly CLI_printf_ CLI_Update_Xz CLI_Startup_ CLI_Shutdown_|& _float_precision _videosize _videotype _blockshadingP@ _preyframeT@ _cliscripthandle CLI_RecordCommand_x{ CLI_SaveCommand_l| CLI_PlayCommand_ CLIUTIL_ReadVariables_ CLIUTIL_WriteVariables_H CLI_Enable_T CLI_Disable_ CLI_Active_h CLI_DeleteVariable_ CLI_AddVariable_ CLI_GetVariable_H CLI_PrintVariable_ CLI_SetVariable_$ CLI_PrintAll_P CLI_CheckCommand_ CLI_SetCommand_ CLI_PrintCommand_ CLI_LoadCommand_\ CLI_PrintDirectory_ CLI_HelpCommand_ CLIUTIL_Startup_l CLIUTIL_ShutDown_ CLI_DrawFrameCharacter_ CLI_StringWidth_ CLI_NextWordInString_H CLI_ScrollFrame_ CLI_NextLine_ CLI_DrawString_T CLI_DrawCursor_ CLI_DrawPrompt_ CLI_AddInputNode_@ CLI_AddInput_
Various debug symbols.
References
- ↑ Scott Miller: This 1995 build of Prey was coded by William Scarboro (RIP -- 2002) and was Apogee's earliest attempt at creating a true 3D engine. This was before we had portals in the engine. The GTIS sign was meant to impress our publisher and help convince them to fund development. - Twitter, 25 December 2022
- ↑ A Titania Interview with 3D Realms (Archived) - Lon Matero