© University of Wisconsin, CS559 Spring 2004

Slides:



Advertisements
Similar presentations
Polygon Rendering Flat Rendering Goraud Rendering Uses Phong Reflectance Phong Rendering.
Advertisements

2 COEN Computer Graphics I Evening’s Goals n Discuss the fundamentals of lighting in computer graphics n Analyze OpenGL’s lighting model n Show.
1 Graphics CSCI 343, Fall 2013 Lecture 18 Lighting and Shading.
Virtual Realism LIGHTING AND SHADING. Lighting & Shading Approximate physical reality Ray tracing: Follow light rays through a scene Accurate, but expensive.
1. What is Lighting? 2 Example 1. Find the cubic polynomial or that passes through the four points and satisfies 1.As a photon Metal Insulator.
Based on slides created by Edward Angel
1 Angel: Interactive Computer Graphics 5E © Addison-Wesley 2009 Shading I.
University of New Mexico
Computer Graphics - Class 10
IMGD 1001: Illumination by Mark Claypool
1 CSCE 641: Computer Graphics Lighting Jinxiang Chai.
Objectives Learn to shade objects so their images appear three- dimensional Learn to shade objects so their images appear three- dimensional Introduce.
1 Angel: Interactive Computer Graphics 4E © Addison-Wesley 2005 Shading I Ed Angel Professor of Computer Science, Electrical and Computer Engineering,
Course Website: Computer Graphics 16: Illumination.
LIGHTING Part One - Theory based on Chapter 6. Lights in the real world Lights bounce off surfaces and reflect colors, scattering light in many directions.
CS 480/680 Computer Graphics Shading I Dr. Frederick C Harris, Jr.
CS 445 / 645: Introductory Computer Graphics
Computer Graphics Lighting.
1 Introduction to Computer Graphics with WebGL Ed Angel Professor Emeritus of Computer Science Founding Director, Arts, Research, Technology and Science.
COMPUTER GRAPHICS CS 482 – FALL 2014 AUGUST 27, 2014 FIXED-FUNCTION 3D GRAPHICS MESH SPECIFICATION LIGHTING SPECIFICATION REFLECTION SHADING HIERARCHICAL.
CS 638, Fall 2001 Admin Grad student TAs may have had their accounts disabled –Please check and the lab if there is a problem If you plan on graduating.
CS 481 Preview, Some Lighting Details Glenn G. Chappell U. of Alaska Fairbanks CS 381 Lecture Notes Wednesday, November 19, 2003.
CSC418 Computer Graphics n Illumination n Lights n Lightinging models.
Rendering Overview CSE 3541 Matt Boggus. Rendering Algorithmically generating a 2D image from 3D models Raster graphics.
Taku KomuraComputer Graphics Local Illumination and Shading Computer Graphics – Lecture 10 Taku Komura Institute for Perception, Action.
Steve Sterley. Real World Lighting Physical objects tend to interact with light in three ways: Absorption (black body) Reflection (mirror) Transmission.
University of Texas at Austin CS 378 – Game Technology Don Fussell CS 378: Computer Game Technology Basic Rendering Pipeline and Shading Spring 2012.
03/14/02 (c) 2002 University of Wisconsin, CS559 Last Time Some more visibility (Hidden Surface Removal) algorithms –A-buffer –Scanline –Depth sorting.
Lighting Review & Example Glenn G. Chappell U. of Alaska Fairbanks CS 381 Lecture Notes Monday, November 17, 2003.
Computer Graphics: Programming, Problem Solving, and Visual Communication Steve Cunningham California State University Stanislaus and Grinnell College.
11/04/04© University of Wisconsin, CS559 Fall 2004 Last Time Visibility –Z-Buffer and transparency –A-buffer –Area subdivision –BSP Trees –Exact Cell-Portal.
Illumination and Shading
1 Introduction to Computer Graphics with WebGL Ed Angel Professor Emeritus of Computer Science Founding Director, Arts, Research, Technology and Science.
Shading in OpenGL Ed Angel Professor Emeritus of Computer Science University of New Mexico 1 E. Angel and D. Shreiner: Interactive Computer Graphics 6E.
Lecture Fall 2001 Illumination and Shading in OpenGL Light Sources Empirical Illumination Shading Transforming Normals Tong-Yee Lee.
Cornell CS465 Spring 2004 Lecture 4© 2004 Steve Marschner 1 Shading CS 465 Lecture 4.
Where We Stand So far we know how to: –Transform between spaces –Rasterize –Decide what’s in front Next –Deciding its intensity and color.
1 CSCE 441: Computer Graphics Lighting Jinxiang Chai.
In the name of God Computer Graphics. Where We Stand So far we know how to: –Transform between spaces –Draw polygons Next –Deciding a pixel’s intensity.
OpenGL Shading. 2 Objectives Learn to shade objects so their images appear three-dimensional Introduce the types of light-material interactions Build.
Lighting and Reflection Angel Angel: Interactive Computer Graphics5E © Addison-Wesley
1 CSCE 441: Computer Graphics Lighting Jinxiang Chai.
CS552: Computer Graphics Lecture 33: Illumination and Shading.
1 CSCE 441: Computer Graphics Lighting Jinxiang Chai.
03/19/2002(c) University of Wisconsin, CS 559 Last Time BSP Tree rendering and exact visibility in mazes Local Shading –Diffuse term –Specular term.
Computer Graphics: Illumination
Illumination Models and Surface-Rendering Methods CEng 477 Introduction to Computer Graphics.
Illumination and Shading. Illumination (Lighting) Model the interaction of light with surface points to determine their final color and brightness OpenGL.
Chapter 5. Lighting Computer Graphics (spring, 2009) School of Computer Science University of Seoul.
Computer Graphics (fall,2010) School of Computer Science University of Seoul Minho Kim.
Illumination : Hearn & Baker Ch. 10
7. Illumination Phong Illumination Diffuse, Specular and Ambient
Shading To determine the correct shades of color on the surface of graphical objects.
Modeling 101 For the moment assume that all geometry consists of points, lines and faces Line: A segment between two endpoints Face: A planar area bounded.
Unit-7 Lighting and Shading
School of Computer Science
Lighting.
Lighting and Materials
Lighting – Light Sources
Isaac Gang University of Mary Hardin-Baylor
Chapter IX Lighting.
Simple Illumination CSE 681.
Last Time Liang-Barsky Details Weiler-Atherton clipping algorithm
Computer Graphics Material Colours and Lighting
Computer Graphics (Fall 2003)
Illumination Model 고려대학교 컴퓨터 그래픽스 연구실.
Illumination Model 고려대학교 컴퓨터 그래픽스 연구실.
CS 480/680 Computer Graphics Shading.
Computer Graphics Shading in OpenGL
Lighting Calculations
Presentation transcript:

© University of Wisconsin, CS559 Spring 2004 Last Time Visibility Area Subdivision (Warnock’s) BSP Trees Cells and Portals 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 Today Lighting and Shading No lecture Tuesday March 30 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 Where We Stand So far we know how to: Transform between spaces Draw polygons Decide what’s in front Next Deciding a pixel’s intensity and color 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 Normal Vectors The intensity of a surface depends on its orientation with respect to the light and the viewer The surface normal vector describes the orientation of the surface at a point Mathematically: Vector that is perpendicular to the tangent plane of the surface What’s the problem with this definition? Just “the normal vector” or “the normal” Will use n or N to denote Normals are either supplied by the user or automatically computed 3/25/04 © University of Wisconsin, CS559 Spring 2004

Transforming Normal Vectors Normal vectors are directions To transform a normal, multiply it by the inverse transpose of the transformation matrix Recall, rotation matrices are their own inverse transpose Don’t include the translation! Use (x,y,z,0) for homogeneous coordinates 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 Local Shading Models Local shading models provide a way to determine the intensity and color of a point on a surface The models are local because they don’t consider other objects We use them because they are fast and simple to compute They do not require knowledge of the entire scene, only the current piece of surface. Why is this good? For the moment, assume: We are applying these computations at a particular point on a surface We have a normal vector for that point 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 Local Shading Models What they capture: Direct illumination from light sources Diffuse and Specular reflections (Very) Approximate effects of global lighting What they don’t do: Shadows Mirrors Refraction Lots of other stuff … 3/25/04 © University of Wisconsin, CS559 Spring 2004

“Standard” Lighting Model Consists of three terms linearly combined: Diffuse component for the amount of incoming light reflected equally in all directions Specular component for the amount of light reflected in a mirror-like fashion Ambient term to approximate light arriving via other surfaces 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 Diffuse Illumination Incoming light, Ii, from direction L, is reflected equally in all directions No dependence on viewing direction Amount of light reflected depends on: Angle of surface with respect to light source Actually, determines how much light is collected by the surface, to then be reflected Diffuse reflectance coefficient of the surface, kd Don’t want to illuminate back side. Use 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 Diffuse Example Where is the light? Which point is brightest (how is the normal at the brightest point related to the light)? 3/25/04 © University of Wisconsin, CS559 Spring 2004

Illustrating Shading Models Show the polar graph of the amount of light leaving for a given incoming direction: Show the intensity of each point on a surface for a given light position or direction Diffuse? Diffuse? 3/25/04 © University of Wisconsin, CS559 Spring 2004

Illustrating Shading Models Show the polar graph of the amount of light leaving for a given incoming direction: Show the intensity of each point on a surface for a given light position or direction Diffuse: Diffuse: 3/25/04 © University of Wisconsin, CS559 Spring 2004

Specular Reflection (Phong Model) V R Incoming light is reflected primarily in the mirror direction, R Perceived intensity depends on the relationship between the viewing direction, V, and the mirror direction Bright spot is called a specularity Intensity controlled by: The specular reflectance coefficient, ks The Phong Exponent, p, controls the apparent size of the specularity Higher n, smaller highlight 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 Specular Example 3/25/04 © University of Wisconsin, CS559 Spring 2004

Illustrating Shading Models Show the polar graph of the amount of light leaving for a given incoming direction: Show the intensity of each point on a surface for a given light position or direction Specular? Specular? 3/25/04 © University of Wisconsin, CS559 Spring 2004

Illustrating Shading Models Show the polar graph of the amount of light leaving for a given incoming direction: Show the intensity of each point on a surface for a given light position or direction Specular Lobe Specular: Specular: 3/25/04 © University of Wisconsin, CS559 Spring 2004

Specular Reflection Improvement H N V Compute based on normal vector and “halfway” vector, H Always positive when the light and eye are above the tangent plane Not quite the same result as the other formulation (need 2H) 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 Putting It Together Global ambient intensity, Ia: Gross approximation to light bouncing around of all other surfaces Modulated by ambient reflectance ka Just sum all the terms If there are multiple lights, sum contributions from each light Several variations, and approximations … 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 Color Do everything for three colors, r, g and b Note that some terms (the expensive ones) are constant For reasons we will not go into, using only three colors is an approximation, but few graphics practitioners realize it Aliasing in color space Better results use 9 color samples 3/25/04 © University of Wisconsin, CS559 Spring 2004

Approximations for Speed The viewer direction, V, and the light direction, L, depend on the surface position being considered, x Distant light approximation: Assume L is constant for all x Good approximation if light is distant, such as sun Distant viewer approximation Assume V is constant for all x Rarely good, but only affects specularities 3/25/04 © University of Wisconsin, CS559 Spring 2004

Distant Light Approximation The viewer direction, V, and the light direction, L, depend on the surface position being considered, x Distant light approximation: Assume L is constant for all x Good approximation if light is distant, such as sun Generally called a directional light source What aspects of surface appearance are affected by this approximation? Diffuse? Specular? 3/25/04 © University of Wisconsin, CS559 Spring 2004

Local Viewer Approximation Specularities require the viewing direction: V(x) = ||c-x|| Slightly expensive to compute Local viewer approximation uses a global V Independent of which point is being lit Use the view plane normal vector Error depends on the nature of the scene Is the diffuse component affected? 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 Describing Surfaces The various parameters in the lighting equation describe the appearance of a surface (kd,r,kd,g,kd,b): The diffuse color, which most closely maps to what you would consider the “color” of a surface Also called diffuse reflectance coefficients (ks,r,ks,g,ks,b): The specular color, which controls the color of specularities The same as the diffuse color for metals, white for plastics Some systems do not let you specify this color separately (ka,r,ka,g,ka,b): The ambient color, which controls how the surface looks when not directly lit Normally the same as the diffuse color 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 OpenGL Model Allows emission, E: Light being emitted by surface Allows separate light intensity for diffuse and specular Ambient light can be associated with light sources Allows spotlights that have intensity that depends on outgoing light direction Allows attenuation of light intensity with distance Can specify coefficients in multiple ways Too many variables and commands to present in class The OpenGL programming guide goes through it all (the red book) 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 OpenGL Commands (1) glMaterial{if}(face, parameter, value) Changes one of the coefficients for the front or back side of a face (or both sides) glLight{if}(light, property, value) Changes one of the properties of a light (intensities, positions, directions, etc) There are 8 lights: GL_LIGHT0, GL_LIGHT1, … glLightModel{if}(property, value) Changes one of the global light model properties (global ambient light, for instance) glEnable(GL_LIGHT0) enables GL_LIGHT0 You must enable lights before they contribute to the image You can enable and disable lights at any time 3/25/04 © University of Wisconsin, CS559 Spring 2004

© University of Wisconsin, CS559 Spring 2004 OpenGL Commands (2) glColorMaterial(face, mode) Causes a material property, such as diffuse color, to track the current glColor() Speeds things up, and makes coding easier glEnable(GL_LIGHTING) turns on lighting You must enable lighting explicitly – it is off by default Don’t use specular intensity if you don’t have to It’s expensive - turn it off by giving 0,0,0 as specular color of the lights Don’t forget normals If you use scaling transformations, must enable GL_NORMALIZE to keep normal vectors of unit length Many other things to control appearance 3/25/04 © University of Wisconsin, CS559 Spring 2004