Build Engine
   HOME

TheInfoList



OR:

Build Engine is a
first-person shooter engine A first-person shooter engine is a video game engine specialized for simulating 3D environments for use in a first-person shooter video game. First-person refers to the view where the players see the world from the eyes of their characters. Shoot ...
created by Ken Silverman, author of ''
Ken's Labyrinth ''Ken's Labyrinth'' is a first-person shooter for MS-DOS published in 1993 by Epic MegaGames. It was programmed by Ken Silverman, who later designed the Build engine used for rendering in 3D Realms's ''Duke Nukem 3D'' (1996). Ken's Labyrinth con ...
'', for
3D Realms 3D Realms Entertainment ApS is a video game publisher based in Aalborg, Denmark. Scott Miller (entrepreneur), Scott Miller founded the company in his parents' home in Garland, Texas, in 1987 as Apogee Software Productions to release his game ' ...
. Like the ''Doom'' engine, the Build Engine represents its world on a two-dimensional grid using closed 2D shapes called sectors, and uses simple flat objects called sprites to populate the world geometry with objects. The Build Engine is generally considered to be a
2.5D 2.5D (two-and-a-half dimensional) perspective refers to gameplay or movement in a video game or virtual reality environment that is restricted to a two-dimensional (2D) plane with little to no access to a third dimension in a space that otherwis ...
engine since the basic world geometry is two-dimensional with an added height component, allowing each sector to have a different ceiling height and floor height. Playing the game shows that some floors can be lower and some can be higher; the same is true with ceilings (in relation to each other). Floors and ceilings can hinge along one of the sector's walls, resulting in a slope. With this information, the Build Engine renders the world in a way that looks
three-dimensional Three-dimensional space (also: 3D space, 3-space or, rarely, tri-dimensional space) is a geometric setting in which three values (called ''parameters'') are required to determine the position of an element (i.e., point). This is the informal ...
, unlike modern game engines that create actual 3D environments. Though the Build Engine achieved most of its fame as a result of powering the
1996 File:1996 Events Collage.png, From left, clockwise: A Centennial Olympic Park bombing, bomb explodes at Centennial Olympic Park in Atlanta, set off by a radical Anti-abortion violence, anti-abortionist; The center fuel tank explodes on TWA Flight 8 ...
first-person shooter First-person shooter (FPS) is a sub-genre of shooter video games centered on gun and other weapon-based combat in a first-person perspective, with the player experiencing the action through the eyes of the protagonist and controlling the pl ...
''
Duke Nukem 3D ''Duke Nukem 3D'' is a first-person shooter video game developed by 3D Realms. It is a sequel to the platform games ''Duke Nukem'' and ''Duke Nukem II'', published by 3D Realms. ''Duke Nukem 3D'' features the adventures of the titular Duke Nuke ...
'', it was also used for many other games.


Technical features


Sectors

Sectors are the building blocks of a level's layout, consisting of a two-dimensional polygonal outline when viewed from above, with the top and bottom faces of the sector given separate
altitude Altitude or height (also sometimes known as depth) is a distance measurement, usually in the vertical or "up" direction, between a reference datum and a point or object. The exact definition and reference datum varies according to the context ...
s to create a three-dimensional space. Hence, all walls are perfectly vertical—anything appearing otherwise is technically a sloped floor or ceiling. The word ''room'' can be used as a loose substitute to aid understanding, though one room in the game world can consist of many sectors, and
parallax Parallax is a displacement or difference in the apparent position of an object viewed along two different lines of sight and is measured by the angle or semi-angle of inclination between those two lines. Due to foreshortening, nearby objects ...
ed skies can give the illusion of being outdoors. Sectors can be manipulated in real-time; ''all'' of their attributes such as shape, height, and slope could be modified "on-the-fly" by games, unlike the earlier ''Doom'' engine. This allowed games to have destructible environments, such as those seen in ''
Blood Blood is a body fluid in the circulatory system of humans and other vertebrates that delivers necessary substances such as nutrients and oxygen to the cells, and transports metabolic waste products away from those same cells. Blood in the c ...
''. This technique is similar to the use of push walls in the earlier Apogee Software title '' Rise of the Triad'' which featured similar dynamic environments. Developers of games based on the engine used special reserved "sprites" (game objects), often called "sector ", that, when given special tags (numbers with defined meanings), would allow the level designer to construct a dynamic world; similar tag information could be given to the sector walls and floor area to give a sector special characteristics. For example, a particular sector effector may let players fall through the floor if they walk over it and teleport them to another sector; in practice, this could be used to create the effect of falling down a hole to a bigger room or creating a body of water that could be jumped into to explore underwater. A sector could be given a tag that made it behave like an elevator or lift. Sectors could overlap one another, provided they could not be seen at the same time (if two overlapping sectors were seen at the same time, a hall of mirrors effect resulted). This allowed the designers to create, for instance, air ducts that appeared to extend across the top of another room (however, doing so could be tricky for designers due to the 2D viewpoint used for much of the editing process). This allowed the designers to create worlds that would be physically impossible (e.g. a doorway of a small building could lead into a network of rooms larger than the building itself). While all these made the games using the engine appear to be 3D, it wouldn't be until later first-person shooters, such as '' Quake'', which used the ''Quake'' engine, that the engine actually stored the world geometry as true 3D information, making the creation of one area stacked atop another area in a single map very feasible.


Voxels

Later versions of Ken Silverman's Build Engine allowed game selected art tiles to be replaced by 3D objects made of voxels. This feature appeared too late to be used in ''Duke Nukem 3D'', but was seen in some of the later Build Engine games. ''Blood'' uses voxels for weapon and ammo pickups, power-ups, and eye-candy (such as the tombstones in the "Cradle to Grave" level, some chairs, and a crystal ball in "Dark Carnival"). ''Shadow Warrior'' makes even more advanced use of the technology, with voxels that can be placed on walls (all of the game's switches and buttons are voxels). For several years, Ken worked on a modern engine based entirely on voxels, known as ''
Voxlap Ken Silverman (born November 1, 1975) is an American game programmer, best known for writing the Build engine. It was most notably utilized by ''Duke Nukem 3D'', ''Shadow Warrior'', ''Blood'', and more than a dozen other games in the mid- to la ...
''.


Room over room

One limitation of the Build Engine is that its level geometry is only capable of representing one connection between sectors for any given wall. Due to this, a structure as simple as a shelf with space both above and below it is impossible, though sometimes sprites or voxels can be substituted. Buildings with several floors are technically possible, but it is not possible for such a building to contain an external window directly above or below another window. In addition, some liberties will need to be taken with the staircases, elevators, and other methods of access for each floor. Several Build Engine games (namely ''Shadow Warrior'', ''Blood'', and ''Redneck Rampage'') worked around this by displaying a "viewport" to another sector through an additional rendering pass. This technique, called ''
room-over-room This list includes terms used in video games and the video game industry, as well as slang used by players. 0–9 A ...
'' (ROR), appears seamless to the player. In addition to an expanded range of vertical construction, ROR was often used to give bodies of water
translucent In the field of optics, transparency (also called pellucidity or diaphaneity) is the physical property of allowing light to pass through the material without appreciable scattering of light. On a macroscopic scale (one in which the dimensions a ...
surfaces. ROR was never a feature of the Build Engine itself, but rather a "trick" that was created by game developers. A trick used in ''Duke Nukem 3D'' to get around this, as in the case of its opaque underwater sections, was to simply transport the player quickly to another region of the map made to mimic it, similar to the elevators from '' Rise of the Triad''. In 2011, a feature was added to EDuke32 called ''true room over room'' (TROR), which allows multiple sectors to be stacked vertically so that each sector's wall has its own connection, enabling vertically-unrestricted structures. The difference between ROR and TROR is that TROR sectors physically overlap in the map data and editor (allowing for easy creation and visualization), rather than being drawn from separate locations using view portals, hence ''true'' room over room. TROR is a feature of the EDuke32 source port, not a game feature or trick.


List of Build Engine games

; Games that are built directly on the Build Engine * ''Rock'n Shaolin: Legend of Seven Paladins 3D'' (1994) (only released in Taiwan and South Korea, illegally used an early version of the Build Engine) * ''
Witchaven ''Witchaven'' (usually pronounced ) is a dark fantasy first-person shooter video game developed by Capstone Software and published by Intracorp Entertainment in 1995. Its sword-and-sorcery themed story tasks the knight Grondoval with a quest to ...
'' (1995) * ''
William Shatner's TekWar ''William Shatner's TekWar'' is a 1995 first-person shooter video game derived from the ''TekWar'' series of novels created by William Shatner and ghost-written by science-fiction author Ron Goulart. It was designed using the Build engine. Plot ...
'' (1995) * ''
Duke Nukem 3D ''Duke Nukem 3D'' is a first-person shooter video game developed by 3D Realms. It is a sequel to the platform games ''Duke Nukem'' and ''Duke Nukem II'', published by 3D Realms. ''Duke Nukem 3D'' features the adventures of the titular Duke Nuke ...
'' (1996) ** ''Duke Nukem 3D: Plutonium PAK'' (1996) ** ''Duke Nukem 3D: Atomic Edition'' (1996) ** ''Duke!ZONE II'' (1997) ** ''Duke Xtreme'' (1997) ** ''Duke it Out in D.C.'' (1997) ** ''Duke Caribbean: Life's a Beach'' (1997) ** ''Duke: Nuclear Winter'' (1997) * ''
PowerSlave ''Powerslave'' is the fifth studio album by the English heavy metal band Iron Maiden, released on 3 September 1984 through EMI Records in Europe and its sister label Capitol Records in North America. It was re-released by Sanctuary and Columbia ...
'' (''Exhumed'' in
Europe Europe is a large peninsula conventionally considered a continent in its own right because of its great physical size and the weight of its history and traditions. Europe is also considered a Continent#Subcontinents, subcontinent of Eurasia ...
and ''Seireki 1999: Pharaoh no Fukkatsu'' in
Japan Japan ( ja, 日本, or , and formally , ''Nihonkoku'') is an island country in East Asia. It is situated in the northwest Pacific Ocean, and is bordered on the west by the Sea of Japan, while extending from the Sea of Okhotsk in the north ...
) (1996) * '' Witchaven II: Blood Vengeance'' (1996) * ''
Blood Blood is a body fluid in the circulatory system of humans and other vertebrates that delivers necessary substances such as nutrients and oxygen to the cells, and transports metabolic waste products away from those same cells. Blood in the c ...
'' (1997) ** ''Blood: Plasma Pak'' (1997) ** ''Blood: Cryptic Passage'' (1997) * '' Shadow Warrior'' (1997) ** ''Shadow Warrior: Twin Dragon'' (1998) ** ''Shadow Warrior: Wanton Destruction'' (2005) ; Games that are based on the ''Duke Nukem 3D'' code * ''
Redneck Rampage ''Redneck Rampage'' is a 1997 first-person shooter game developed by Xatrix Entertainment and published by Interplay Entertainment, Interplay. The game is a first-person shooter with a variety of weapons and levels, and has a hillbilly theme, pr ...
'' (1997) ** ''Redneck Rampage: Suckin' Grits on Route 66'' (1997) * ''
Redneck Rampage Rides Again ''Redneck Rampage Rides Again'' is a video game developed by Xatrix Entertainment and published by Interplay Entertainment for MS-DOS in 1998. It was rereleased on Steam for Microsoft Windows on June 5, 2017, and for macOS on June 18. The game is ...
'' (1998) * ''
Redneck Deer Huntin' ''Redneck Deer Huntin is a hunting simulation video game developed by Xatrix Entertainment and published by Interplay Entertainment for MS-DOS and Microsoft Windows in 1998. It is a spinoff of the 1997 first-person shooter ''Redneck Rampage''. It ...
'' (1998) * '' Extreme Paintbrawl'' (1998) * ''
NAM Nam, Nam, or The Nam are shortened terms for: * Vietnam, which is also spelled ''Viet Nam'' * The Vietnam War Nam, The Nam or NAM may also refer to: Arts and media * Nam, a fictional character in anime series ''Dragon Ball'' * ''NAM'' (video ...
'' (1998) * ''Liquidator'' (1998) (only released in Russia, illegally used Build Engine and published by
Akella Akella (russian: Акелла) was a Russian software company specializing in the development, publishing and distribution of video games and multimedia products. The founders of Akella met in 1993 and decided to start a company together, and ...
) * '' WWII GI'' (1999) ** ''WWII GI: Platoon Leader'' (1999) * ''
Ion Fury ''Ion Fury'' (originally titled ''Ion Maiden'') is a 2019 cyberpunk first-person shooter video game developed by Finnish studio Voidpoint and published by 3D Realms. It is a prequel to the 2016 video game '' Bombshell''. ''Ion Fury'' runs on a m ...
'' (2019) (via ''EDuke32'') * ''A.W.O.L.'' (2022) (via ''EDuke32'') ; Unreleased Build Engine games * ''Fate'' (unfinished, only a demo exists) * ''Corridor 8: Galactic Wars'' (unfinished, source code is available) * ''Shadow Warrior: Deadly Kiss'' (unreleased, screenshots were released in January 1998)


Development

The Build Engine was essentially a one-man project for Ken Silverman, though he consulted
John Carmack John D. Carmack II (born August 20, 1970) is an American computer programmer and video game developer. He co-founded the video game company id Software and was the lead programmer of its 1990s games ''Commander Keen'', ''Wolfenstein 3D'', ''Doo ...
for guidance early in the project. Silverman was hired by 3D Realms on the basis of his demo for Build. Though he continued to refine the engine after becoming employed at 3D Realms, according to Silverman he never teamed with any other 3D Realms employees on the project and was never directed to tailor the engine towards any particular game.


Source release and further developments

On June 20, 2000 (according to his website) Ken Silverman released the Build Engine
source code In computing, source code, or simply code, is any collection of code, with or without comments, written using a human-readable programming language, usually as plain text. The source code of a program is specially designed to facilitate the wo ...
under a proprietary
non-commercial A non-commercial (also spelled noncommercial) activity is an activity that does not, in some sense, involve commerce, at least relative to similar activities that do have a commercial objective or emphasis. For example, advertising-free community ...
license. Silverman explained that after id Software set a precedent by releasing the source code for the Doom engine, fans had been pressuring him to release the source code for the Build Engine.


Early days

Version 2.0 of Matt Saettler's EDuke, a project to improve ''Duke Nukem 3D'' for
modders ''Modding'' is a slang expression derived from the English verb " to modify". The term refers to modification of hardware, software, or anything else, to perform a function not originally intended by the designer, or to achieve bespoke specific ...
, was sent to 3D Realms for packaging shortly after the release of the Build source, leaving Duke Nukem 3D the pre-built libraries that 3D Realms had used with the original Duke. (Both ''Duke Nukem 3D'' and ''EDuke'' were still closed-source at this point.) With the 2.1 private
betas ''Betas'' is an American streaming television series that was produced by Amazon Studios. The show starred Joe Dinicol and Karan Soni as "dating app" developers in Silicon Valley who are looking for an investor. Amazon offered the first three e ...
, Saettler worked towards integrating Silverman's build source into the Duke source code, but the project fizzled out before producing anything more than some very buggy private betas. A few total conversion teams for Build games decided to work from Silverman's Build code directly, and an enhanced version of the Build editor known as Mapster was also developed. It was claimed at the time by many on the 3D Realms forums that it would be impossible to port Build to a multitasking OS, as it needed a large contiguous block of memory that wouldn't be available in a multitasking environment. This statement did not hold up to scrutiny, as all modern operating systems use
virtual memory In computing, virtual memory, or virtual storage is a memory management technique that provides an "idealized abstraction of the storage resources that are actually available on a given machine" which "creates the illusion to users of a very l ...
which allows apps to get contiguous logical memory without using contiguous physical memory, but conventional wisdom of the time was that porting Build to such an OS was unfeasible.


''Duke Nukem 3D'' source release

On April 1, 2003, after several years of claims to the contrary, 3D Realms released the source code to ''Duke Nukem 3D'' under the GPL-2.0-or-later license. Not long afterwards, both
Ryan C. Gordon Ryan C. Gordon (also known as icculus) is a computer programmer and former Loki Software employee responsible for ''icculus.org'', which hosts many Loki Software projects as well as others. Gordon's site hosts projects with the code from such ...
and Jonathon Fowler created and released source ports of the game, including the Build Engine. It was possible to play ''Duke Nukem 3D'' well on the NT line of Windows (including Windows 2000/XP) and on
Linux Linux ( or ) is a family of open-source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991, by Linus Torvalds. Linux is typically packaged as a Linux distribution, which ...
and other
Unix Unix (; trademarked as UNIX) is a family of multitasking, multiuser computer operating systems that derive from the original AT&T Unix, whose development started in 1969 at the Bell Labs research center by Ken Thompson, Dennis Ritchie, and ot ...
operating systems, and interest in the source ports soared.


icculus.org port

Ryan C. Gordon Ryan C. Gordon (also known as icculus) is a computer programmer and former Loki Software employee responsible for ''icculus.org'', which hosts many Loki Software projects as well as others. Gordon's site hosts projects with the code from such ...
(icculus), with the help of others, made the first port of the engine using SDL. The port was first to
Linux Linux ( or ) is a family of open-source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991, by Linus Torvalds. Linux is typically packaged as a Linux distribution, which ...
, then to
Cygwin Cygwin ( ) is a POSIX-compatible programming and runtime environment that runs natively on Microsoft Windows. Under Cygwin, source code designed for Unix-like operating systems may be compiled with minimal modification and executed. The Cygwin in ...
, and finally to a native Windows build using the Watcom C++ compiler, which was the compiler used for the original DOS build (despite being compiled with Watcom C++, Build is plain C.) There was some talk of Matt Saettler using this to port ''EDuke'' to Windows, but nothing came of it.


JonoF port

A second source port was made to Windows, and later to Linux and Mac OS X, by Jonathon Fowler (JonoF). This port, JFDuke3D, initially did not have network game support, though this was added later in development.


Polymost

The task of updating the Build Engine to a true 3D renderer was taken on by Silverman himself. In the release notes for Polymost, he wrote: "When 3D Realms released the Duke Nukem 3D source code, I thought somebody would do a OpenGL or Direct3D port. Well, after a few months passed, I saw no sign of somebody working on a true hardware-accelerated port of Build, just people saying it wasn't possible. Eventually, I realized the only way this was going to happen was for me to do it myself." The Polymost renderer allowed for 3D hardware-accelerated graphics using
OpenGL OpenGL (Open Graphics Library) is a cross-language, cross-platform application programming interface (API) for rendering 2D and 3D vector graphics. The API is typically used to interact with a graphics processing unit (GPU), to achieve hardwa ...
. It also introduced "hightile", a feature that made it possible to replace the game's original textures with high-resolution replacements in a variety of formats. Polymost has been utilized in Jonathon Fowler's JFBuild, JFDuke3D, JFShadowWarrior, and source ports derived from their code bases.


EDuke32

The source for EDuke 2.0 was later released, followed by the source for the last private beta of ''EDuke'' 2.1 (which never made it to a release version). Richard Gobeille (TerminX) merged the EDuke 2.0 source with JFDuke3D to make ''EDuke32''. Another port, ''Wineduke'', based on the icculus code, has since died off, leaving EDuke32 the only EDuke port still in development. EDuke32 also supports the games ''NAM'' and ''WWII GI'', as EDuke was based on the code to those games.


Polymer

On April 1, 2009, an OpenGL shader model 3.0 renderer was revealed to have been developed for EDuke32, named ''Polymer'' to distinguish from Ken Silverman's ''Polymost''. At first it was thought to be an April Fools' joke, but the renderer was later made public. It allows for more modern effects such as real-time dynamic colored lighting and shadow mapping, specular and normal mapping, and other shader-based features in addition to most of the features added to Polymost over the years. Although Polymer is completely usable, it is technically incomplete and unoptimised, and is still in development. The developers of EDuke32 have stated that once Polymer has been rewritten for speed, it will supplant Polymost completely, as it is a superior renderer, and can be made to look identical to Polymost.


Other game ports

The ''Shadow Warrior'' source code was released on April 1, 2005 under the GPL-2.0-or-later license, and JonoF released a source port of it, JFShadowWarrior, on April 2, 2005. However, he admitted that he had access to the ''Shadow Warrior'' source code about a week before its release. This port was later forked by ProASM for the SWP port. The '' Transfusion'' project aimed to re-create ''Blood'' in the
DarkPlaces engine The ''Quake'' engine is the game engine developed by id Software to power their 1996 video game '' Quake''. It featured true 3D real-time rendering and is now licensed under the terms of GNU General Public License v2.0 or later. After releas ...
, but as of 2006, this project is far from complete, though it has complete deathmatch multiplayer; a similar project is '' BloodCM'' which recreates all of the Monolith made single player levels for ''Blood'' on top of EDuke32, as well as '' ZBlood'' which ports some ''Blood'' assets and levels onto '' ZDoom''. The source code of ''Witchaven'', ''Witchaven II: Blood Vengeance'', ''William Shatner's TekWar'', and ''Corridor 8: Galactic Wars'' have also surfaced. The legal status of these, however, is unclear. The full source code to an alpha version of ''Blood'' was also leaked, and was used as a reference for an otherwise reverse engineered port to
Java Java (; id, Jawa, ; jv, ꦗꦮ; su, ) is one of the Greater Sunda Islands in Indonesia. It is bordered by the Indian Ocean to the south and the Java Sea to the north. With a population of 151.6 million people, Java is the world's List ...
using
LibGDX libGDX is a free and open-source game-development application framework written in the Java programming language with some C and C++ components for performance dependent code. It allows for the development of desktop and mobile games by usin ...
called ''BloodGDX'' in May 2017. This followed from the author's previous port of ''TekWar'' released in January 2016, and has been followed up by ports for ''Witchaven'', ''Redneck Rampage'', ''Duke Nukem 3D'', ''Powerslave'', ''Legends of the Seven Paladins'' and ''Shadow Warrior'', now all collectively called ''BuildGDX''. A further port of ''Blood'', called ''NBlood'', was released in January 2019 based on EDuke32 and the creator's previous ''Rednukem'' port for ''Redneck Rampage''. An EDuke32 port for ''
PowerSlave ''Powerslave'' is the fifth studio album by the English heavy metal band Iron Maiden, released on 3 September 1984 through EMI Records in Europe and its sister label Capitol Records in North America. It was re-released by Sanctuary and Columbia ...
'', called ''PCExhumed'', was released on November 21, 2019. The source port ''Raze'' forks various Build Engine ports, including ''JFDuke3D'', ''SWP'', ''NBlood'', ''Rednukem'', and ''PCExhumed'', and ties it to a new underlying backend based on
GZDoom The present article is a list of known platforms to which ''Doom'' has been confirmed to be ported. ''Doom'' is one of the most widely ported video games. Since the original MS-DOS version, it has been released officially for a number of operatin ...
.


Successor

After multiple attempts to design a successor to Build, Silverman again began experimenting with such an idea in 2006. He used this work - now called Build 2 - while teaching 3D game programming to children at a summer camp from 2007 until 2009, and work continued until 2011 when he lost interest in the project. It features a more advanced lighting system, voxel rendering for entities and true room-over-room 3D spaces, and at least in part retained backwards compatibility with the original Build. Silverman released his drafts to the public on March 7, 2018. The source code was published under a proprietary non-commercial license on June 8, 2019.


References


External links


Ken Silverman's Build Engine Page



Build Engine basic tutorial using mapster32
* {{DEFAULTSORT:Build Engine 1995 software Game engines for Linux Video game engines