|This article needs additional citations for verification. (March 2009)|
Cel shading (often misspelled as 'cell shading') or toon shading is a type of non-photorealistic rendering designed to make 3-D computer graphics appear to be flat. Cel-shading is often used to mimic the style of a comic book or cartoon. It is somewhat recent, appearing from around the beginning of the twenty-first century. The name comes from cels (short for celluloid), the clear sheets of acetate which are painted on for use in traditional 2D animation.
The cel-shading process starts with a typical 3D model. Where cel-shading differs from conventional rendering is in its non-photorealistic illumination model. Conventional (smooth) lighting values are calculated for each pixel and then mapped to a small number of discrete shades to create the characteristic flat look – where the shadows and highlights appear more like blocks of color rather than mixed in a smooth way.
Black "ink" outlines and contour lines can be created using a variety of methods. One popular method is to first render a black outline, slightly larger than the object itself. Backface culling is inverted and the back-facing triangles are drawn in black. To dilate the silhouette, these back faces may be drawn in wireframe multiple times with slight changes in translation. Alternatively, back-faces may be rendered solid-filled, with their vertices translated along their vertex normals in a vertex shader. After drawing the outline, back-face culling is set back to normal to draw the shading and optional textures of the object. Finally, the image is composited via Z-buffering, as the back-faces always lie deeper in the scene than the front-faces. The result is that the object is drawn with a black outline and interior contour lines. The term "cel-shading" is popularly used to refer to the application of this "ink" outlining process in animation and games, although originally the term referred to the shading technique regardless of whether the outline was applied.
The Utah teapot rendered using cel-shading:
- The back faces are drawn with thick lines
- The object is drawn with a basic texture
Steps 2 and 3 can be combined using multi-texturing (see texture mapping).
Another outlining technique is to use 2D image-processing. First, the scene is rendered (with cel-shading) to a screen-sized color texture:
Then, the scene's depth and world-space surface normal information are rendered to screen-sized textures:
A Sobel filter or similar edge-detection filter is applied to the normal/depth textures to generate an edge texture. Texels on detected edges are black, while all other texels are white:
Finally, the edge texture and the color texture are composited to produce the final rendered image:
Cel-shading in video games
Cel-shading in interactive media got its start with Jet Set Radio in 2000 for the Sega Dreamcast. A few games use cel-shading today, including more mature titles such as No More Heroes and Crackdown. The Legend of Zelda: The Wind Waker, Viewtiful Joe, and Dragon Quest VIII are also popular examples of cel-shaded games.
List of cel-shaded media
- 2008 Scion xD Little Deviants
- 2009 Dodge Journey
- BP Connect 2007 ad's
- Nick Jr. ID's by Steve Speer
- Commit mint lozenges
- HSBC HSBCdirect.com
- Hewlett Packard xw8400 Workstation Titans of iron
- Mr. Clean
- Pampers Kandoo Flushable Toilet Wipes, Foaming Handsoap
- Post Cereals Fruity Pebbles cereal (Bowling for Fruity Pebbles ad)
- Lego Exo-Force
- L'Oréal Couleur Expert
- Lunchables Pizza (Atlantis Paradise Island promotion ad)
- McCain's Zwak Punch
- Neopets virtual prize code (Canadian Betty Crocker fruit-flavored snacks promotional ad)
- Nickelodeon "Hans & Henrietta" ID's
- Oscar Mayer Lunchables Chicken Dunks (airhead mysteries ad)
- Sola/Nero/Vena/Olera/Zonte sparkling wine
- Toyo Tires Versado LX all-season touring tires (OK Tire promotional ad)
- Hachigian, Jennifer. "Celshader.com FAQ". Retrieved August 2, 2005.
- IGN: Jet Set Radio review. Retrieved August 4, 2005.
- GameDev.net - Cel-Shading. Retrieved August 5, 2005.