Revision as of 16:16, 16 January 2007 edit84.203.46.57 (talk) →Distance falloff← Previous edit | Latest revision as of 23:06, 18 October 2024 edit undo2a00:23c5:fe1c:3701:a41a:1766:9a8c:f7e9 (talk)No edit summary | ||
(418 intermediate revisions by more than 100 users not shown) | |||
Line 1: | Line 1: | ||
{{Short description|Depicting depth through varying levels of darkness}} | |||
{{dablink|For other uses, see ].}} | |||
{{about|shading in computer graphics|the GPU technology that performs these techniques|Shader|other uses|Shade (disambiguation){{!}}Shade}} | |||
'''Shading''' refers to depicting depth in 3D models by varying levels of darkness. | |||
{{More citations needed|date=May 2007}} | |||
==Drawing== | |||
{{Multiple image | |||
] | |||
| image1 = Flatshading01.png | |||
'''Shading''' is a process used in drawing for depicting levels of darkness on paper by applying more pressure with a drawing implement for darker areas, and less pressure for lighter areas. There are various techniques of shading including ] where perpendicular lines of varying closeness are drawn in a grid pattern to shade an area. The closer the lines are together, the darker the area appears. Likewise, the farther apart the lines are, the lighter the area appears. | |||
| image2 = Gouraudshading01.png | |||
The term has been recently generalized to mean that ]s are applied. | |||
| image3 = Phongshading01.png | |||
| width = 350px | |||
| align = | |||
| direction = vertical | |||
| total_width = | |||
| alt1 = | |||
| caption1 = ] describes a number of simple lighting techniques. In this case, the lighting value is determined once for each face. The color value can also be determined per object or per vertex. | |||
| caption2 = ] (1971) improved the appearance of curved objects. | |||
| background color = | |||
| caption3 = ] ] is a more realistic shading technique developed by ] in 1973. | |||
}} | |||
'''Shading''' refers to the depiction of ] in ]s (within the field of ]) or ]s (in ]) by varying the level of ].<ref>{{Cite web|url=http://hexianghu.com/graphics/2015/03/23/shading/|title=Graphics: Shading|website=hexianghu.com|access-date=2019-09-10}}</ref> Shading tries to approximate local behavior of ] on the object's surface and is not to be confused with techniques of adding shadows, such as ] or ]s, which fall under global behavior of light. | |||
Light patterns, such as objects having light areas and shaded areas, help when creating the illusion of depth on paper and on computer screens. | |||
== |
==In drawing== | ||
'''Shading''' is used traditionally in ] for depicting a range of darkness by applying media more densely or with a darker shade for darker areas, and less densely or with a lighter shade for lighter areas. Light patterns, such as objects having light and shaded areas, help when creating the illusion of depth on paper.<ref>{{cite web|url=http://www.drawingwithconfidence.com/drawing-techniques/|title=Drawing Techniques|publisher=Drawing With Confidence|url-status=dead|archive-url=https://web.archive.org/web/20121124221319/http://www.drawingwithconfidence.com:80/drawing-techniques/|archive-date=November 24, 2012|access-date=19 September 2012}}</ref><ref>{{cite web|url=http://www.dueysdrawings.com/shading_tutorial.html |title=Shading Tutorial, How to Shade in Drawing |publisher=Dueysdrawings.com |date=2007-06-21 |access-date=2012-02-11}}</ref> | |||
In computer graphics, '''Shading''' refers to the process of altering a color based on its angle to lights and its distance from lights to create a ] effect. Shading is performed during the ] process. | |||
There are various techniques of shading, including ], where perpendicular lines of varying closeness are drawn in a grid pattern to shade an area. The closer the lines are together, the darker the area appears. Likewise, the farther apart the lines are, the lighter the area appears. | |||
===Angle to light source=== | |||
Shading alters the colors of faces in your 3D model based on the angle of the surface to the sun or other light sources. | |||
'''{{anchor|Powder shading}}Powder shading''' is a ] shading method. In this style, ] and paper ] are used to draw a picture. (This is also in color.) The stumping powder is smooth and doesn't have any shiny particles. The paper to be used should have small grains on it so that the powder remains on the paper. | |||
==In computer graphics== | |||
], developed by ] in 1971, was one of the first shading techniques developed for ].]] | |||
] including aluminum, brass, bronze, copper, electrum, gold, iron, pewter, silver, clay, foil, glaze, plastic, rubber, satin, and velvet. created in ] 13.1]] | |||
In ], shading refers to the process of altering the color of an object/surface/polygon in the 3D scene, based on things like (but not limited to) the surface's angle to lights, its distance from lights, its angle to the camera and material properties (e.g. ]) to create a ] effect. | |||
Shading is performed during the ] process by a program called a ]. | |||
===Surface angle to a light source=== | |||
Shading alters the colors of faces in a 3D model based on the angle of the surface to a light source or light sources. | |||
The first image below has the faces of the box rendered, but all in the same color. Edge lines have been rendered here as well which makes the image easier to see. | The first image below has the faces of the box rendered, but all in the same color. Edge lines have been rendered here as well which makes the image easier to see. | ||
Line 19: | Line 41: | ||
The third image has shading enabled, which makes the image more realistic and makes it easier to see which face is which. | The third image has shading enabled, which makes the image more realistic and makes it easier to see which face is which. | ||
{{multiple image | |||
] | |||
| align = center | |||
] | |||
| image1 = Shading1.png | |||
] | |||
| caption1 = Rendered image of a box. This image has no shading on its faces, but instead uses ''edge lines'' (also known as '']'') to separate the faces and a bolder ''outline'' to separate the object from the background. | |||
<br clear=all/> | |||
| image2 = Shading2.svg | |||
| caption2 = This is the same object with the lines removed; the only indication of the interior geometry are the points of the object's ]. | |||
| image3 = Shading3.svg | |||
| caption3 = This is the same object rendered with ''flat shading''. The color of the 3 visible front faces has been set based on their angle (determined by the ]) to the light sources. | |||
}} | |||
===Types of lighting=== | |||
] using a ]]] | |||
When a shader computes the result color, it uses a ] to determine the amount of light reflected at specific points on the surface. Different lighting models can be combined with different shading techniques — while lighting says how much light is reflected, shading determines how this information is used in order to compute the final result. It may for example compute lighting only at specific points and use ] to fill in the rest. The shader may also decide about how many light sources to take into account etc. | |||
====Ambient lighting==== | |||
An ambient light source represents an omnidirectional, fixed-intensity and fixed-color light source that affects all objects in the scene equally (is omnipresent). During rendering, all objects in the scene are brightened with the specified intensity and color. This type of light source is mainly used to provide the scene with a basic view of the different objects in it. This is the simplest type of lighting to implement, and models how light can be scattered or ] many times, thereby producing a uniform effect. | |||
Ambient lighting can be combined with ] to represent how exposed each point of the scene is, affecting the amount of ambient light it can reflect. This produces diffused, non-directional lighting throughout the scene, casting no clear shadows, but with enclosed and sheltered areas darkened. The result is usually visually similar to an overcast day. | |||
====Point lighting==== | |||
Light originates from a single ] and spreads outward in all directions. | |||
====Spotlighting==== | |||
Models a ]: light originates from a single point and spreads outward in a ]. | |||
====Area lighting==== | |||
Light originates from a small area on a single ]. (A more realistic model than a point light source.) | |||
==== Directional lighting ==== | |||
A directional light source illuminates all objects equally from a given ], like an area light of infinite size and infinite distance from the scene; there is shading, but cannot be any distance falloff. This is like the ]. | |||
===Distance falloff=== | ===Distance falloff=== | ||
{{multiple image | |||
Theoretically, two surfaces which are parallel, are illuminated the same amount from a distant light source, such as the sun. Even though one surface is further away, your eye sees more of it in the same space, so the illumination appears the same. | |||
| align = left | |||
| total_width = 600 | |||
| image1 = 2squares-1.jpg | |||
| caption1 = Two boxes rendered with ] (Note that the color of the two front faces is the same even though one is farther away.) | |||
| image2 = 2squares-2.jpg | |||
| caption2 = The same model rendered using ], which implements ''distance falloff'' to make surfaces that are closer to the eye brighter | |||
}} | |||
{{clear}} | |||
Theoretically, two surfaces which are ] are illuminated virtually the same amount from a ''distant'' unblocked light source such as the sun. The distance falloff effect produces images which have more shading and so would be realistic for proximal light sources. | |||
The left image doesn't use distance falloff. Notice that the colors on the front faces of the two boxes are ''exactly'' the same. It may appear that there is a slight difference where the two faces directly overlap, but this is an ] caused by the vertical edge below where the two faces meet. | |||
The right image does use distance falloff. Notice that the front face of the closer box is brighter than the front face of the back box. Also, the floor goes from light to dark as it gets farther away. | |||
==== Calculation ==== | |||
Distance falloff can be calculated in a number of ways: | |||
* ''Power of the distance'' – For a given point at a distance <var>x</var> from the light source, the light intensity received is proportional to {{math|1/<var>x</var><sup><var>n</var></sup>}}. | |||
** ''None'' ({{math|<var>n</var> {{=}} 0}}) – The light intensity received is the same regardless of the distance between the point and the light source. | |||
** ''Linear'' ({{math|<var>n</var> {{=}} 1}}) – For a given point at a distance <var>x</var> from the light source, the light intensity received is proportional to {{math|1/<var>x</var>}}. | |||
** ''Quadratic'' ({{math|<var>n</var> {{=}} 2}}) – This is how light intensity decreases in reality if the light has a free path (i.e. no ] or any other thing in the air that can ] or ] the light). For a given point at a distance <var>x</var> from the light source, the light intensity received is proportional to {{math|1/<var>x</var><sup>2</sup>}}. | |||
* Any number of other ] may also be used. | |||
===Shading techniques=== | |||
During shading a ] is often needed for lighting computation. The normals can be precomputed and stored for each vertex of the model. | |||
====Flat shading==== | |||
] ]]] | |||
] | |||
Here, the lighting is evaluated only once for each polygon (usually for the first vertex in the polygon, but sometimes for the ] for triangle meshes), based on the polygon's surface normal and on the assumption that all polygons are flat. The computed color is used for the whole polygon, making the corners look sharp. This is usually used when more advanced shading techniques are too computationally expensive. ] highlights are rendered poorly with flat shading: If there happens to be a large specular component at the representative vertex, that brightness is drawn uniformly over the entire face. If a specular highlight doesn't fall on the representative point, it is missed entirely. Consequently, the specular reflection component is usually not included in flat shading computation. | |||
====Smooth shading==== | |||
In contrast to flat shading where the colors change discontinuously at polygon borders, with smooth shading the color changes from pixel to pixel, resulting in a smooth color transition between two adjacent polygons. Usually, values are first calculated in the vertices and ] is used to calculate the values of pixels between the vertices of the polygons. Types of smooth shading include ]<ref>{{cite journal|last=Gouraud|first=Henri|title=Continuous shading of curved surfaces|journal=IEEE Transactions on Computers|year=1971|volume=C-20|issue=6|pages=623–629|doi=10.1109/T-C.1971.223313|s2cid=123827991 }}</ref> and ].<ref>B. T. Phong, , ''Communications of ACM'' 18 (1975), no. 6, 311–317. (])</ref> | |||
=====Gouraud shading===== | |||
# Determine the normal at each polygon vertex. | |||
# Apply an ] to each vertex to calculate the light intensity from the vertex normal. | |||
# Interpolate the vertex intensities using ] over the surface polygon. | |||
Problems: | |||
* Due to lighting being computed only at vertices, the inaccuracies (especially of specular highlights on large triangles) can become too apparent. | |||
* T-junctions with adjoining polygons can sometimes result in visual anomalies. In general, T-junctions should be avoided. | |||
=====Phong shading===== | |||
Phong shading is similar to Gouraud shading, except that instead of interpolating the light intensities the normals are interpolated between the vertices and the lighting is evaluated per-pixel. Thus, the specular highlights are computed much more precisely than in the Gouraud shading model. | |||
# Compute a normal N for each vertex of the polygon. | |||
# Using ] compute a normal, N<sub>i</sub> for each pixel. (Normal has to be renormalized each time.) | |||
# Apply an ] to each pixel to calculate the light intensity from N<sub>i</sub>. | |||
====Deferred shading==== | |||
] is a shading technique by which computation of shading is deferred to later stage by rendering in two passes, potentially increasing performance by not discarding expensively shaded pixels. The first pass only captures surface parameters (such as depth, normals and material parameters), the second one performs the actual shading and computes the final colors.<ref name="urlForward Rendering vs. Deferred Rendering">{{cite web |url=https://gamedevelopment.tutsplus.com/articles/forward-rendering-vs-deferred-rendering--gamedev-12342 |title=Forward Rendering vs. Deferred Rendering |format= |accessdate=}}</ref><ref name="urlLearnOpenGL - Deferred Shading">{{cite web |url=https://learnopengl.com/Advanced-Lighting/Deferred-Shading |title=LearnOpenGL - Deferred Shading |format= |accessdate=}}</ref><ref name="akenine">{{cite book |last1=Akenine-Möller |first1=Tomas |last2=Haines |first2=Eric |last3=Hoffman |first3=Naty |title=Real-Time Rendering |date=2018 |isbn=978-1-1386-2700-0 |edition=Fourth}}</ref>{{rp|884}} | |||
=====Other approaches===== | |||
Notice in the first image that the color on the front faces of the two boxes is exactly the same. It appears that there is a slight difference where the two faces meet, but this is an optical illusion because of the vertical edge below where the two faces meet. | |||
Both ] and ] can be implemented using ]. Bishop and Weimer <ref>Gary Bishop and David M. Weimer. 1986. Fast Phong shading. ''SIGGRAPH Comput. Graph''. 20, 4 (August 1986), 103–106.</ref> proposed to use a ] expansion of the resulting expression from applying an ] and bilinear interpolation of the normals. Hence, second-degree ] was used. This type of biquadratic interpolation was further elaborated by Barrera et al.,<ref>T. Barrera, A. Hast, E. Bengtsson. . ''WSCG'06'', pp. 109–116. 2006</ref> where one second-order polynomial was used to interpolate the diffuse light of the ] and another second-order polynomial was used for the specular light. | |||
Spherical linear interpolation (]) was used by Kuij and Blake<ref>Kuijk, A. A. M. and E. H. Blake, . ''Computer Graphics Forum'' 8(4):315–324. 1989 (])</ref> for computing both the normal over the polygon, as well as the vector in the direction to the light source. A similar approach was proposed by Hast,<ref>A. Hast. . ''WSCG'05''. pp. 53–56. 2005.</ref> which uses ] interpolation of the normals with the advantage that the normal will always have unit length and the computationally heavy normalization is avoided. | |||
Notice in the second image that the surfaces on the boxes are bright on the front box and darker on the back box. Also the floor goes from light to dark as it gets farther away. | |||
====Flat vs. smooth shading==== | |||
This distance falloff effect produces images which appear more realistic without having to add additional lights to achieve the same effect. | |||
{| class="wikitable" | |||
<br clear=all/> | |||
|- | |||
]. | |||
! Flat !! Smooth | |||
Note that the colors of the two front faces are the same even though one box is further away.]] | |||
|- | |||
] | |||
| Uses the same color for every pixel in a face – usually the color of the first vertex || Smooth shading uses linear interpolation of either colors or normals between vertices | |||
<br clear=all/> | |||
|- | |||
| Edges appear more pronounced than they would on a real object because in reality almost all edges are somewhat round || The edges disappear with this technique | |||
|- | |||
| Same color for any point of the face || Each point of the face has its own color | |||
|- | |||
| Individual faces are visualized || underlying surface are visualized | |||
|- | |||
| Not suitable for smooth objects || Suitable for any objects | |||
|- | |||
| Less computationally expensive || More computationally expensive | |||
|} | |||
== |
==Computer vision== | ||
]" reconstruction]] | |||
] | |||
In ], some methods for ] are based on shading, or ''shape-from-shading''. Based on an image's shading, a three-dimensional model can be reconstructed from a single photograph.<ref>Horn, Berthold K.P. "." (1970). (])</ref> | |||
An OpenGL interface allows shadows from the sun. However with ] ]s you can add light bulbs, flood lights and spot lights. | |||
==See also== | |||
The intensity of the light is altered because of the angle of the surface to the light, the distance from the surface to the light, and because of the beam angle of the flood light. | |||
* ] | |||
<br clear=all/> | |||
* ] | |||
] | |||
* ] | |||
* ] | |||
* ] | |||
* ] to visualize curvature | |||
==References== | |||
===Flat vs smooth shading=== | |||
{{reflist}} | |||
'''Flat shading''' is lighting technique used in ]. It shades each ] of an object based on the angle between the polygon's ] and the direction of the light source, their respective colors and the intensity of the light source. It is usually used for high speed ]ing where more advanced shading techniques are too computationally expensive. | |||
==Further reading== | |||
The disadvantage of flat shading is that it gives low-polygon models a faceted look. Sometimes this look can be advantageous though, such as in modeling boxy objects. Artists sometimes use flat shading to look at the polygons of a solid model they are creating. More advanced and realistic lighting and shading techniques include ] and ]. | |||
* | |||
== See also == | |||
]. | |||
{{color topics}} | |||
] | |||
{{Computer graphics}} | |||
] | |||
{{Authority control}} | |||
] | ] | ||
] | ] | ||
] | |||
] | |||
] |
Latest revision as of 23:06, 18 October 2024
Depicting depth through varying levels of darkness This article is about shading in computer graphics. For the GPU technology that performs these techniques, see Shader. For other uses, see Shade.This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed. Find sources: "Shading" – news · newspapers · books · scholar · JSTOR (May 2007) (Learn how and when to remove this message) |
Shading refers to the depiction of depth perception in 3D models (within the field of 3D computer graphics) or illustrations (in visual art) by varying the level of darkness. Shading tries to approximate local behavior of light on the object's surface and is not to be confused with techniques of adding shadows, such as shadow mapping or shadow volumes, which fall under global behavior of light.
In drawing
Shading is used traditionally in drawing for depicting a range of darkness by applying media more densely or with a darker shade for darker areas, and less densely or with a lighter shade for lighter areas. Light patterns, such as objects having light and shaded areas, help when creating the illusion of depth on paper.
There are various techniques of shading, including cross hatching, where perpendicular lines of varying closeness are drawn in a grid pattern to shade an area. The closer the lines are together, the darker the area appears. Likewise, the farther apart the lines are, the lighter the area appears.
Powder shading is a sketching shading method. In this style, stumping powder and paper stumps are used to draw a picture. (This is also in color.) The stumping powder is smooth and doesn't have any shiny particles. The paper to be used should have small grains on it so that the powder remains on the paper.
In computer graphics
In computer graphics, shading refers to the process of altering the color of an object/surface/polygon in the 3D scene, based on things like (but not limited to) the surface's angle to lights, its distance from lights, its angle to the camera and material properties (e.g. bidirectional reflectance distribution function) to create a photorealistic effect.
Shading is performed during the rendering process by a program called a shader.
Surface angle to a light source
Shading alters the colors of faces in a 3D model based on the angle of the surface to a light source or light sources.
The first image below has the faces of the box rendered, but all in the same color. Edge lines have been rendered here as well which makes the image easier to see.
The second image is the same model rendered without edge lines. It is difficult to tell where one face of the box ends and the next begins.
The third image has shading enabled, which makes the image more realistic and makes it easier to see which face is which.
Rendered image of a box. This image has no shading on its faces, but instead uses edge lines (also known as wireframe) to separate the faces and a bolder outline to separate the object from the background.This is the same object with the lines removed; the only indication of the interior geometry are the points of the object's silhouette.This is the same object rendered with flat shading. The color of the 3 visible front faces has been set based on their angle (determined by the normal vector) to the light sources.Types of lighting
When a shader computes the result color, it uses a lighting model to determine the amount of light reflected at specific points on the surface. Different lighting models can be combined with different shading techniques — while lighting says how much light is reflected, shading determines how this information is used in order to compute the final result. It may for example compute lighting only at specific points and use interpolation to fill in the rest. The shader may also decide about how many light sources to take into account etc.
Ambient lighting
An ambient light source represents an omnidirectional, fixed-intensity and fixed-color light source that affects all objects in the scene equally (is omnipresent). During rendering, all objects in the scene are brightened with the specified intensity and color. This type of light source is mainly used to provide the scene with a basic view of the different objects in it. This is the simplest type of lighting to implement, and models how light can be scattered or reflected many times, thereby producing a uniform effect.
Ambient lighting can be combined with ambient occlusion to represent how exposed each point of the scene is, affecting the amount of ambient light it can reflect. This produces diffused, non-directional lighting throughout the scene, casting no clear shadows, but with enclosed and sheltered areas darkened. The result is usually visually similar to an overcast day.
Point lighting
Light originates from a single point and spreads outward in all directions.
Spotlighting
Models a spotlight: light originates from a single point and spreads outward in a cone.
Area lighting
Light originates from a small area on a single plane. (A more realistic model than a point light source.)
Directional lighting
A directional light source illuminates all objects equally from a given direction, like an area light of infinite size and infinite distance from the scene; there is shading, but cannot be any distance falloff. This is like the sun.
Distance falloff
Two boxes rendered with OpenGL (Note that the color of the two front faces is the same even though one is farther away.)The same model rendered using ARRIS CAD, which implements distance falloff to make surfaces that are closer to the eye brighterTheoretically, two surfaces which are parallel are illuminated virtually the same amount from a distant unblocked light source such as the sun. The distance falloff effect produces images which have more shading and so would be realistic for proximal light sources.
The left image doesn't use distance falloff. Notice that the colors on the front faces of the two boxes are exactly the same. It may appear that there is a slight difference where the two faces directly overlap, but this is an optical illusion caused by the vertical edge below where the two faces meet.
The right image does use distance falloff. Notice that the front face of the closer box is brighter than the front face of the back box. Also, the floor goes from light to dark as it gets farther away.
Calculation
Distance falloff can be calculated in a number of ways:
- Power of the distance – For a given point at a distance x from the light source, the light intensity received is proportional to 1/x.
- None (n = 0) – The light intensity received is the same regardless of the distance between the point and the light source.
- Linear (n = 1) – For a given point at a distance x from the light source, the light intensity received is proportional to 1/x.
- Quadratic (n = 2) – This is how light intensity decreases in reality if the light has a free path (i.e. no fog or any other thing in the air that can absorb or scatter the light). For a given point at a distance x from the light source, the light intensity received is proportional to 1/x.
- Any number of other mathematical functions may also be used.
Shading techniques
During shading a surface normal is often needed for lighting computation. The normals can be precomputed and stored for each vertex of the model.
Flat shading
Here, the lighting is evaluated only once for each polygon (usually for the first vertex in the polygon, but sometimes for the centroid for triangle meshes), based on the polygon's surface normal and on the assumption that all polygons are flat. The computed color is used for the whole polygon, making the corners look sharp. This is usually used when more advanced shading techniques are too computationally expensive. Specular highlights are rendered poorly with flat shading: If there happens to be a large specular component at the representative vertex, that brightness is drawn uniformly over the entire face. If a specular highlight doesn't fall on the representative point, it is missed entirely. Consequently, the specular reflection component is usually not included in flat shading computation.
Smooth shading
In contrast to flat shading where the colors change discontinuously at polygon borders, with smooth shading the color changes from pixel to pixel, resulting in a smooth color transition between two adjacent polygons. Usually, values are first calculated in the vertices and bilinear interpolation is used to calculate the values of pixels between the vertices of the polygons. Types of smooth shading include Gouraud shading and Phong shading.
Gouraud shading
- Determine the normal at each polygon vertex.
- Apply an illumination model to each vertex to calculate the light intensity from the vertex normal.
- Interpolate the vertex intensities using bilinear interpolation over the surface polygon.
Problems:
- Due to lighting being computed only at vertices, the inaccuracies (especially of specular highlights on large triangles) can become too apparent.
- T-junctions with adjoining polygons can sometimes result in visual anomalies. In general, T-junctions should be avoided.
Phong shading
Phong shading is similar to Gouraud shading, except that instead of interpolating the light intensities the normals are interpolated between the vertices and the lighting is evaluated per-pixel. Thus, the specular highlights are computed much more precisely than in the Gouraud shading model.
- Compute a normal N for each vertex of the polygon.
- Using bilinear interpolation compute a normal, Ni for each pixel. (Normal has to be renormalized each time.)
- Apply an illumination model to each pixel to calculate the light intensity from Ni.
Deferred shading
Deferred shading is a shading technique by which computation of shading is deferred to later stage by rendering in two passes, potentially increasing performance by not discarding expensively shaded pixels. The first pass only captures surface parameters (such as depth, normals and material parameters), the second one performs the actual shading and computes the final colors.
Other approaches
Both Gouraud shading and Phong shading can be implemented using bilinear interpolation. Bishop and Weimer proposed to use a Taylor series expansion of the resulting expression from applying an illumination model and bilinear interpolation of the normals. Hence, second-degree polynomial interpolation was used. This type of biquadratic interpolation was further elaborated by Barrera et al., where one second-order polynomial was used to interpolate the diffuse light of the Phong reflection model and another second-order polynomial was used for the specular light.
Spherical linear interpolation (Slerp) was used by Kuij and Blake for computing both the normal over the polygon, as well as the vector in the direction to the light source. A similar approach was proposed by Hast, which uses quaternion interpolation of the normals with the advantage that the normal will always have unit length and the computationally heavy normalization is avoided.
Flat vs. smooth shading
Flat | Smooth |
---|---|
Uses the same color for every pixel in a face – usually the color of the first vertex | Smooth shading uses linear interpolation of either colors or normals between vertices |
Edges appear more pronounced than they would on a real object because in reality almost all edges are somewhat round | The edges disappear with this technique |
Same color for any point of the face | Each point of the face has its own color |
Individual faces are visualized | underlying surface are visualized |
Not suitable for smooth objects | Suitable for any objects |
Less computationally expensive | More computationally expensive |
Computer vision
In computer vision, some methods for 3D reconstruction are based on shading, or shape-from-shading. Based on an image's shading, a three-dimensional model can be reconstructed from a single photograph.
See also
- Computer graphics lighting
- Lambertian reflectance
- List of art techniques
- List of common shading algorithms
- Shader
- Zebra analysis to visualize curvature
References
- "Graphics: Shading". hexianghu.com. Retrieved 2019-09-10.
- "Drawing Techniques". Drawing With Confidence. Archived from the original on November 24, 2012. Retrieved 19 September 2012.
- "Shading Tutorial, How to Shade in Drawing". Dueysdrawings.com. 2007-06-21. Retrieved 2012-02-11.
- Gouraud, Henri (1971). "Continuous shading of curved surfaces". IEEE Transactions on Computers. C-20 (6): 623–629. doi:10.1109/T-C.1971.223313. S2CID 123827991.
- B. T. Phong, Illumination for computer generated pictures, Communications of ACM 18 (1975), no. 6, 311–317. (PDF)
- "Forward Rendering vs. Deferred Rendering".
- "LearnOpenGL - Deferred Shading".
- Akenine-Möller, Tomas; Haines, Eric; Hoffman, Naty (2018). Real-Time Rendering (Fourth ed.). ISBN 978-1-1386-2700-0.
- Gary Bishop and David M. Weimer. 1986. Fast Phong shading. SIGGRAPH Comput. Graph. 20, 4 (August 1986), 103–106.
- T. Barrera, A. Hast, E. Bengtsson. Fast Near Phong-Quality Software Shading. WSCG'06, pp. 109–116. 2006
- Kuijk, A. A. M. and E. H. Blake, Faster Phong shading via angular interpolation. Computer Graphics Forum 8(4):315–324. 1989 (PDF)
- A. Hast. Shading by Quaternion Interpolation. WSCG'05. pp. 53–56. 2005.
- Horn, Berthold K.P. "Shape from shading: A method for obtaining the shape of a smooth opaque object from one view." (1970). (PDF)
Further reading
Color topics | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|
Color science |
| |||||||||
Color philosophy |
| |||||||||
Color terms |
| |||||||||
Color organizations | ||||||||||
Names |
| |||||||||
Related | ||||||||||
Computer graphics | |||
---|---|---|---|
Vector graphics | |||
2D graphics |
| ||
3D graphics | |||
Concepts | |||
Graphics software | |||
Algorithms |