PLAYPAL



The PLAYPAL lump is a set of color palettes the Doom engine uses to set the main colors for all graphics, including full color fades and tinting effects. Since the Doom engine can only display a maximum of 256 simultaneous colors, it performs a series of palette swaps to achieve these effects. Each palette in the lump contains 256 colors totaling 768 bytes, where each color is broken into three unsigned bytes. Each of these color components (red, green, and blue) range between 0 and 255.

The resource is built using the  and consists of a number of tables of indices into the palette through which colors can be remapped for sector lighting, distance fading, and partial screen color changes (such as the invulnerability effect). Any changes to the will be reflected in the, and if those changes are significant, they will require the  to be rebuilt in order to remain consistent with the palette.

Since only one palette can be displayed at a time, any effects that use cannot be combined; e.g. picking up a radiation suit (Green tint) and a berserk pack (red tint) will not display a yellow tint. However, a change can be combined with a  change with no issues.

Doom
The Doom contains a total of 14 palettes, where each palette has a specific function:

An examination of the Doom source code reveals that the unused palettes (1 and 9) were likely intended to be the first levels of the red and yellow tinting effects, but because of the logic used in the palette code, they are never used: if (cnt) { 	palette = (cnt+7)>>3; if (palette >= NUMREDPALS) palette = NUMREDPALS-1; palette += STARTREDPALS; }   else if (plyr->bonuscount) { 	palette = (plyr->bonuscount+7)>>3; if (palette >= NUMBONUSPALS) palette = NUMBONUSPALS-1; palette += STARTBONUSPALS; } Since the computer palette will always be at least, the first palette is skipped. This could have been fixed subtracting 1 while adding the (and therefore not while capping the palette).

The precise algorithm used to tint the palettes can be found in dcolors.c, a part of the Doom utilities.

Tools which can be used to manipulate the include Inkworks, DeePsea and SLADE 3.

Heretic
Heretic's is laid out identically to Doom's, using the same generator. The "radiation suit" palette is present despite not being used.

Hexen
In Hexen, the engine uses an extended lump containing 28 palettes, of which the additional palettes are used for several new effects.

Strife
Strife's is laid out identically to Doom's. The radiation suit palette is used for poisoning effects from certain types of damaging floors. With the way this effect is implemented in Strife, the palette change happens before damage starts being inflicted, serving as a warning to the player.

Index 247
Many specialized editing tools (notably NWT, SLumpEd and XWE) rely on the assumption that palette index 247 is not used and can safely be used as a "transparent color", which they display as cyan because it contrasts well with the rest of the Doom palette. This assumption, however, is incorrect. Palette index 247 is used by some Doom II graphics, and it is black (0, 0, 0), not cyan. All 256 colors of the palette are shown in the patches and sprites picture format, as a different mechanism for transparency is used. Palette index 247 is used even more in other Doom engine games such as Hexen. The mistaken assumption created by having these tools treating cyan as a transparent color when importing pictures and converting them to Doom-format graphics, or by giving transparency to pixels indexed 247 when exporting, results in many problems: patches and sprites exported from the IWADs might have "holes" that they shouldn't have, and attempts to actually use cyan as a color in graphics (with a palette that does contain this color) are hindered.

Technical limitations
The display hardware on which Doom-engine games were designed to run (specifically, in an unchained variant of  known as "Mode Y") only internally stores 6-bit values for red, green, and blue; all 8-bit values passed to the hardware have the two least significant bits dropped. The result of this is that VGA hardware can only display 64 different levels of red, green, or blue, and any more fine-grained differences will not be displayed.

The Doom palette appears to have been designed with this limitation in mind, as there are no gradients with variations smaller than 4 in any of the three component colors. However, the tinted palettes for taking damage, picking up items, and the radiation suit, as well as the colors for the gamma correction levels, were all algorithmically generated assuming that the full 24-bit color range would be available, and so they contain some slight color variations that are not faithfully represented when displayed on VGA hardware.

All other Doom-engine games have base palettes that contain colors which do not gracefully degrade to a 6-bit representation, and so some slight color accuracy is lost when they are displayed on VGA hardware. This can even result in colors being lost entirely. For instance, Heretic's base palette contains two similar grays: color #28 is (216, 216, 216), and color #29 is (219,219,219). These two colors are both displayed on VGA hardware as a gray of (54,54,54).

Source

 * This article incorporates information from the Unofficial Doom Specs, from the Doom utilities source code, and from analyses performed with SLADE 3.