Web colors

This is an old revision of this page, as edited by Codingmasters (talk | contribs) at 23:57, 24 April 2006 (X11 color names). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

Authors of web pages have a variety of options available for specifying colors for elements of web documents. Colors may be specified as an RGB triplet in hexadecimal format (a hex triplet); they may also be specified according to their common English names in some cases.

The first versions of Mosaic and Netscape Navigator used the X11 color names as the basis for their color lists, as both started as X Window System applications. The origin of the X11 color list is unknown. [1]

Web colors have an unambiguous colorimetric definition, sRGB, which relates the chromaticities of a particular phosphor set, a given transfer curve, adaptive whitepoint, and viewing conditions. These have been chosen to be similar to many real-world monitors and viewing conditions, so that even without color management rendering is fairly close to the specified values. However, user agents vary in the fidelity with which they represent the specified colors. More advanced user agents use color management to provide better color fidelity; this is particularly important for Web to print applications.

Hex triplet

A hex triplet is a six-digit, three-byte hexadecimal number used in HTML and CSS, and other computing applications, to represent colors. The bytes represent the red, green and blue components of the color. One byte represents a number in the range 00 to FF (in hexadecimal notation), or 0 to 255 in decimal notation. This represents the least (0) to the most (255) intensity of each of the color components. The hex triplet is formed by concatenating three bytes in hexadecimal notation, in the following order:

Byte 1: red value
Byte 2: green value
Byte 3: blue value

For example, consider the color where the red/green/blue values are decimal numbers: red=36, green=104, blue=160 (a greyish-blue color). The decimal numbers 36, 104 and 160 are 24, 68 and A0 respectively in hexadecimal notation. To obtain the hex triplet, we simply write the three hex bytes together without spaces, thus: 2468A0. If a byte is less than 16 (decimal) or 10 (hex) it must be represented with a leading zero to keep the number of digits in the triplet equal to six. For example, the decimal triplet 0,1,2 would be represented by the hex triplet 000102.

The number of colors that can be represented by this system is

 

Converting RGB to hexadecimal

Converting a decimal RGB value to a hexadecimal value is fairly straightforward. RGB values are usually given in the 0-255 range; if they are in the 0-1 range, multiply the value by 255 before conversion. The number of times this number divides into 16 gives us the first hexadecimal digit (between 0 and F, see hexadecimal if unsure). The remainder gives us the second digit. For instance the RGB value 201 divides 12 times into 16, thus the first digit is C. A remainder of 9 gives us the hexadecimal number C9. This process is repeated for each color value. Most modern operating systems have a built-in calculator to perform conversions between number bases; this can also be done with some calculators. This task can also be carried out with various Internet resources, for instance the website http://www.telacommunications.com/nutshell/rgbform.htm.

HTML color names

The HTML 4.01 specification[1] defines sixteen named colors, as follows (names are defined in this context to be case independent):

Color Hexadecimal Color Hexadecimal Color Hexadecimal Color Hexadecimal
aqua #00ffff black #000000 blue #0000ff fuchsia #ff00ff
gray #808080 green #008000 lime #00ff00 maroon #800000
navy #000080 olive #808000 purple #800080 red #ff0000
silver #c0c0c0 teal #008080 white #ffffff yellow #ffff00

These 16 were also specified as sRGB and included in the HTML 3.0 specification which noted "These colors were originally picked as being the standard 16 colors supported with the Windows VGA palette." [2]

X11 color names

In addition, a number of colors are defined by web browsers such as Internet Explorer or Mozilla Firefox. A particular browser may not recognize all of these colors, but as of 2005 all modern general-use browsers support the full list. Many of these colors are from the list of X11 color names distributed with the X Window System. These colors were standardized by SVG 1.0, and are accepted by SVG Full user agents. They are not part of SVG Tiny.

The list of colors actually shipped with the X11 product varies between implementations, and clashes with certain of the HTML names such as green. Furthermore, X11 colors are defined as simple RGB (hence, no particular color), rather than sRGB. This means that the list of colors found in X11 (e.g. in /usr/lib/X11/rgb.txt) should not directly be used to choose colors for the web.[3]

Some of the web "X11 colors", along with their hexadecimal equivalents, are listed below. For a full list, which also displays by both name and hexadecimal in your browser, see http://www.w3.org/TR/2001/WD-css3-color-20010305#x11-color.

HTML
name
R G B
Hex code
Color
example
Red colors
Indianred CD 5C 5C  
Lightcoral F0 80 80  
Salmon FA 80 72  
Darksalmon E9 96 7A  
Orangered FF 45 00  
Red FF 00 00  
Crimson DC 14 3C  
Firebrick B2 22 22  
Darkred 8B 00 00  
Pink colors
Pink FF C0 CB  
Lightpink FF B6 C1  
Palevioletred DB 70 93  
Hotpink FF 69 B4  
Deeppink FF 14 93  
Mediumvioletred C7 15 85  
Yellos colors
Lightyellow FF FF E0  
Lemonchiffon FF FA CD  
Lightgoldenrodyellow FA FA D2  
Papayawhip FF EF D5  
Moccasin FF E4 B5  
Peachpuff FF DA B9  
Palegoldenrod EE E8 AA  
Khaki F0 E6 8C  
Yellow FF FF 00  
Gold FF D7 00  
Darkkhaki BD B7 6B  
Bleu colors
Lightcyan E0 FF FF  
Paleturquoise AF EE EE  
Aqua 00 FF FF  
Aquamarine 7F FF D4  
Turquoise 40 E0 D0  
Mediumturquoise 48 D1 CC  
Darkturquoise 00 CE D1  
Powderblue B0 E0 E6  
Lightsteelblue B0 C4 DE  
lLightblue AD D8 E6  
Skyblue 87 CE EB  
Lightskyblue 87 CE FA  
Deepskyblue 00 BF FF  
Cornflowerblue 64 95 ED  
Steelblue 46 82 B4  
Cadetblue 5F 9E A0  
Mediumslateblue 7B 68 EE  
Dodgerblue 1E 90 FF  
Royalblue 41 69 E1  
Blue 00 00 FF  
Mediumblue 00 00 CD  
Darkblue 00 00 8B  
Navy 00 00 80  
Midnightblue 19 19 70  
Orange colors
Lightsalmon FF A0 7A  
Orange FF A5 00  
Darkorange FF 8C 00  
Coral FF 7F 50  
Tomato FF 63 47  
Orangered FF 45 00  
Green colors
Greenyellow AD FF 2F  
Chartreuse 7F FF 00  
Lawngreen 7C FC 00  
Lime 00 FF 00  
Palegreen 98 FB 98  
Lightgreen 90 EE 90  
Mediumspringgreen 00 FA 9A  
Springgreen 00 FF 7F  
Yellowgreen 9A CD 32  
Limegreen 32 CD 32  
Mediumseagreen 3C B3 71  
Seagreen 2E 8B 57  
Forestgreen 22 8B 22  
Green 00 80 00  
Olivedrab 6B 8E 23  
Olive 80 80 00  
Darkolivegreen 55 6B 2F  
Darkgreen 00 64 00  
Aquamarine 7F FF D4  
Mediumaquamarine 66 CD AA  
Darkseagreen 8F BC 8F  
Lightseagreen 20 B2 AA  
Darkcyan 00 8B 8B  
Teal 00 80 80  
Purple colors
Lavender E6 E6 FA  
Thistle D8 BF D8  
Plum DD A0 DD  
Violet EE 82 EE  
Fuchsia FF 00 FF  
magenta FF 00 FF  
Orchid DA 70 D6  
Mediumorchid BA 55 D3  
Mediumpurple 93 70 DB  
Slateblue 6A 5A CD  
Blueviolet 8A 2B E2  
Darkviolet 94 00 D3  
Darkorchid 99 32 CC  
Darkmagenta 8B 00 8B  
Purple 80 00 80  
Darkslateblue 48 3D 8B  
Indigo 4B 00 82  
Brown colors
Cornsilk FF F8 DC  
Blanchedalmond FF EB CD  
Bisque FF E4 C4  
Navajowhite FF DE AD  
Wheat F5 DE B3  
Burlywood DE B8 87  
Tan D2 B4 8C  
Rosybrown BC 8F 8F  
Sandybrown F4 A4 60  
Goldenrod DA A5 20  
Darkgoldenrod B8 86 0B  
Peru CD 85 3F  
Chocolate D2 69 1E  
Saddlebrown 8B 45 13  
Sienna A0 52 2D  
Brown A5 2A 2A  
Maroon 80 00 00  
White colors
White FF FF FF  
Snow FF FA FA  
Honeydew F0 FF F0  
Mintcream F5 FF FA  
Azure F0 FF FF  
Aliceblue F0 F8 FF  
Ghostwhite F8 F8 FF  
Whitesmoke F5 F5 F5  
Seashell FF F5 EE  
Beige F5 F5 DC  
Oldlace FD F5 E6  
Floralwhite FF FA F0  
Ivory FF FF F0  
Antiquewhite FA EB D7  
Linen FA F0 E6  
Lavenderblush FF F0 F5  
Mistyrose FF E4 E1  
Grey colors
Gainsboro DC DC DC  
Lightgrey D3 D3 D3  
Silver C0 C0 C0  
Darkgray A9 A9 A9  
Gray 80 80 80  
Dimgray 69 69 69  
Lightslategray 77 88 99  
Slategray 70 80 90  
Darkslategray 2F 4F 4F  
Black 00 00 00  


Note: This table originates from the Dutch Wikipedia (the dutch names have been removed).

Web-safe colors

Another set of 216 color values are commonly considered to be the "web-safe" color palette; developed at a time when many computer displays were only capable of displaying 256 colors. A set of colors was needed that could be shown without dithering on 256-color displays; the number 216 was chosen partly because computer operating systems customarily reserved sixteen to twenty colors for their own use; it was also selected because it allows exactly six shades each of red, green, and blue. (6 × 6 × 6 = 216). The palette was first identified by Lynda Weinman.

The list of colors is often presented as if it has special properties that render them immune to dithering. In fact, on 256-color displays applications can set a palette of any selection of colors that they choose, dithering the rest. These colors were chosen specifically because they matched the palettes selected by the then leading browser applications. Fortunately, there were not radically different palettes in use in different popular browsers.

"Web-safe" colors had a flaw in that, on systems such as X Windows where the palette is shared between applications, smaller color cubes (5x5x5 or 4x4x4) were often allocated by browsers — thus, the "web safe" colors would actually dither on such systems. Better results were obtained by providing an image with a larger range of colors and allowing the browser to quantize the color space if needed, rather than suffer the quality loss of a double quantization.

By the early years of the 21st century, driven by the needs of video games and digital photos, personal computers typically had at least 16-bit color and usually 24-bit (truecolor). Even mobile devices had at least 16-bit color, driven by the inclusion of cameras on cellphones. The use of "web-safe" colors fell into disuse, but persisted as folklore.

The "web-safe" colors do not have names, but each can be specified by an RGB triplet. In the table below, a three-digit number is used as a shorthand notation for the six-digit hexadecimal numerals above. The digit "3" is equivalent to the hexadecimal numeral "33"; "C" is equivalent to "CC". For example, "F63" in the table below is equivalent to "#FF6633" in the system used previously. Below are the values for the 6 shades of each color out of 256 possible color shades.

6 shades of each color
digit hexadecimal decimal
0 00 0
3 33 51
6 66 102
9 99 153
C or (12) CC 204
F or (15) FF 255

The following table shows all of the "web-safe" colors, underlining the really-safe (see next section) colors. The lack of gamma correction means that the six desired intensities 0%, 20%, 40%, 60%, 80%, and 100% are displayed as 0%, 2%, 10%, 28%, 57%, and 100% on a standard 2.5 gamma CRT or LCD, making most colors very dark. The intensities at the low end of the range are nearly indistinguishable from each other:

Web-Safe Colors
000 300 600 900 C00 F00 003 303 603 903 C03 F03
006 306 606 906 C06 F06 009 309 609 909 C09 F09
00C 30C 60C 90C C0C F0C 00F 30F 60F 90F C0F F0F
030 330 630 930 C30 F30 033 333 633 933 C33 F33
036 336 636 936 C36 F36 039 339 639 939 C39 F39
03C 33C 63C 93C C3C F3C 03F 33F 63F 93F C3F F3F
060 360 660 960 C60 F60 063 363 663 963 C63 F63
066 366 666 966 C66 F66 069 369 669 969 C69 F69
06C 36C 66C 96C C6C F6C 06F 36F 66F 96F C6F F6F
090 390 690 990 C90 F90 093 393 693 993 C93 F93
096 396 696 996 C96 F96 099 399 699 999 C99 F99
09C 39C 69C 99C C9C F9C 09F 39F 69F 99F C9F F9F
0C0 3C0 6C0 9C0 CC0 FC0 0C3 3C3 6C3 9C3 CC3 FC3
0C6 3C6 6C6 9C6 CC6 FC6 0C9 3C9 6C9 9C9 CC9 FC9
0CC 3CC 6CC 9CC CCC FCC 0CF 3CF 6CF 9CF CCF FCF
0F0 3F0 6F0 9F0 CF0 FF0 0F3 3F3 6F3 9F3 CF3 FF3
0F6 3F6 6F6 9F6 CF6 FF6 0F9 3F9 6F9 9F9 CF9 FF9
0FC 3FC 6FC 9FC CFC FFC 0FF 3FF 6FF 9FF CFF FFF

Really web safe colors

Designers were often encouraged to stick to these 216 "web-safe" colors in their websites; however, 8-bit color displays were much more common when the 216-color palette was developed than they are now. David Lehn and Hadley Stern have since discovered that only 22 of the 216 colors in the web-safe palette are reliably displayed without inconsistent remapping on 16-bit computer displays. They called these 22 colors the "really safe" palette; it consists mainly of shades of green and yellow, as can be seen in the table above, where the "really safe" colors are underlined.

CSS colors

The Cascading Style Sheets language defines the same number of named colors as the HTML 4 spec, namely the 16 listed above. Additionally, CSS 2.1 adds the 'orange' color name to the list:

Color Hexadecimal
orange #ffa500

CSS 2, SVG and CSS 2.1 also allow web authors to use so-called system colors, which are color names whose values are taken from the operating system. This enables web authors to style their content in line with the operating system of the user agent. See [2]. As of early 2004, it appears that the CSS3 color module will once again drop these values, marking them deprecated, but this may change: [3].

The developing CSS3 specification will also introduce HSL color space values to style sheets:

/* RGB model */
p { color: #f00 }              /* #rgb */
p { color: #ff0000 }           /* #rrggbb */
p { color: rgb(255,0,0) }      /* integer range 0 - 255 */
p { color: rgb(100%, 0%, 0%) } /* float range 0.0% - 100.0% */
/* RGB with alpha channel, added to CSS3 */
p { color: rgba(255,0,0,0.5)    /* 0.5 opacity, semi-transparent */
/* HSL model, added to CSS3 */
p { color: hsl(0, 100%, 50%) }   /* red */
p { color: hsl(120, 100%, 50%) } /* green */ 
p { color: hsl(120, 100%, 25%) } /* light green */ 
p { color: hsl(120, 100%, 75%) } /* dark green */ 
p { color: hsl(120, 50%, 50%) }  /* pastel green */
/* HSL model with alpha channel */
p { color: hsla(120, 100%, 50%, 1) }   /* green */
p { color: hsla(120, 100%, 50%, 0.5) } /* semi-transparent green */
p { color: hsla(120, 100%, 50%, 0.1) } /* very transparent green */

Accessibility

  • Some browsers and devices don't support colors.
  • For blind and colorblind users Web content depending on colors can be unusable or difficult to use.
  • Mixing legacy markup like bgcolor with modern CSS fails for legacy browsers not supporting CSS.
  • The shorthand #RGB as in bgcolor="#0FF" does not work with some browsers, it should be #RRGGBB as in bgcolor="#00FFFF".
  • Both foreground and background color should be modified to avoid black on black effects.

Popular browsers show links as shades of blue, dark background colors like blue or navy don't work for such links. Using CSS to modify link colors cannot work with legacy browsers. The Netscape 4.x support for CSS is frequently disabled for being as paltry as it is.

References

See also