Shading, Surfaces & Textures

Slides:



Advertisements
Similar presentations
Virtual Realism TEXTURE MAPPING. The Quest for Visual Realism.
Advertisements

1 Graphics CSCI 343, Fall 2013 Lecture 18 Lighting and Shading.
03/16/2009Dinesh Manocha, COMP770 Texturing Surface’s texture: its look & feel Graphics: a process that takes a surface and modifies its appearance using.
Computer Graphics Inf4/MSc Computer Graphics Lecture 13 Illumination I – Local Models.
Virtual Realism LIGHTING AND SHADING. Lighting & Shading Approximate physical reality Ray tracing: Follow light rays through a scene Accurate, but expensive.
1 Computer Graphics By : Mohammed abu Lamdy ITGD3107 University of Palestine Supervision: Assistant Professor Dr. Sana’a Wafa Al-Sayegh.
COMPUTER GRAPHICS CS 482 – FALL 2014 OCTOBER 6, 2014 TEXTURE MAPPING TEXTURES BUMP MAPPING ENVIRONMENT MAPPING PROCEDURAL TEXTURING.
Illumination and Shading
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.
Computer Graphics - Class 10
University of British Columbia CPSC 314 Computer Graphics Jan-Apr 2008 Tamara Munzner Lighting/Shading III Week.
1GR2-00 GR2 Advanced Computer Graphics AGR Lecture 12 Solid Textures Bump Mapping Environment Mapping.
Rendering (彩現 渲染).
IMGD 1001: Illumination by Mark Claypool
Computer Graphics (Fall 2005) COMS 4160, Lecture 16: Illumination and Shading 1
Lighting and Shading Wen-Chieh (Steve) Lin
(conventional Cartesian reference system)
7M836 Animation & Rendering
Objectives Learn to shade objects so their images appear three- dimensional Learn to shade objects so their images appear three- dimensional Introduce.
University of British Columbia CPSC 314 Computer Graphics Jan-Apr 2005 Tamara Munzner Lighting and Shading Week.
CS 376 Introduction to Computer Graphics 03 / 30 / 2007 Instructor: Michael Eckmann.
6.1 Vis_04 Data Visualization Lecture 6 - A Rough Guide to Rendering.
Texture Mapping Texture Mapping Ltjg Omer Arisut Turkish Navy Turkish Navy Texture Mapping Texture Mapping Ltjg Omer Arisut Turkish Navy Turkish Navy.
Coordinate Systems X Y Z (conventional Cartesian reference system) X Y Z.
1 3D –graphics and animation Shading and Surface Characteristics Harri Airaksinen.
University of British Columbia CPSC 414 Computer Graphics © Tamara Munzner 1 Shading Week 5, Wed 1 Oct 2003 recap: lighting shading.
Aaron Bloomfield CS 445: Introduction to Graphics Fall 2006
Computer Graphics Inf4/MSc Computer Graphics Lecture 11 Texture Mapping.
CS 445 / 645: Introductory Computer Graphics
UFCEKT-20-33D Modelling and Animation 3D Modelling & Animation Materials and Textures Maps.
1 Computer Graphics Week13 –Shading Models. Shading Models Flat Shading Model: In this technique, each surface is assumed to have one normal vector (usually.
Polygon Shading. Assigning color to a shape to make graphical scenes look realistic, or artistic, or whatever effect we’re attempting to achieve But first.
CS 445 / 645 Introduction to Computer Graphics Lecture 18 Shading Shading.
Shading (introduction to rendering). Rendering  We know how to specify the geometry but how is the color calculated.
University of Illinois at Chicago Electronic Visualization Laboratory (EVL) CS 426 Intro to 3D Computer Graphics © 2003, 2004, 2005 Jason Leigh Electronic.
COMPUTER GRAPHICS CS 482 – FALL 2014 AUGUST 27, 2014 FIXED-FUNCTION 3D GRAPHICS MESH SPECIFICATION LIGHTING SPECIFICATION REFLECTION SHADING HIERARCHICAL.
Modelling and Simulation Types of Texture Mapping.
Textures and Maps MCC Computer Modelling Trimester 1 – 2015/2016.
COLLEGE OF ENGINEERING UNIVERSITY OF PORTO COMPUTER GRAPHICS AND INTERFACES / GRAPHICS SYSTEMS JGB / AAS 1 Shading (Shading) & Smooth Shading Graphics.
Shading & Texture. Shading Flat Shading The process of assigning colors to pixels. Smooth Shading Gouraud ShadingPhong Shading Shading.
CS447/ Realistic Rendering -- Radiosity Methods-- Introduction to 2D and 3D Computer Graphics.
David Luebke 1 10/26/2015 Lighting CS 445/645 Introduction to Computer Graphics David Luebke, Spring 2003.
CS 325 Introduction to Computer Graphics 03 / 26 / 2010 Instructor: Michael Eckmann.
Taku KomuraComputer Graphics Local Illumination and Shading Computer Graphics – Lecture 10 Taku Komura Institute for Perception, Action.
Computer Graphics: Programming, Problem Solving, and Visual Communication Steve Cunningham California State University Stanislaus and Grinnell College.
Komputer Grafik 2 (AK045206) Shading 1/17 Realisme : Shading.
Illumination and Shading
Course Introduction to virtual engineering Óbuda University John von Neumann Faculty of Informatics Institute of Applied Mathematics Lecture and laboratory.
CS 325 Introduction to Computer Graphics 03 / 29 / 2010 Instructor: Michael Eckmann.
RENDERING Introduction to Shading models – Flat and Smooth shading – Adding texture to faces – Adding shadows of objects – Building a camera in a program.
Lecture Fall 2001 Illumination and Shading in OpenGL Light Sources Empirical Illumination Shading Transforming Normals Tong-Yee Lee.
CS 376 Introduction to Computer Graphics 04 / 02 / 2007 Instructor: Michael Eckmann.
UV Mapping After a 3D object has been modeled it must be prepared for texturing. 3D surfaces can be “unwrapped” into a 2D representation with. This process.
Local Illumination and Shading
Illumination and Shading Prof. Lizhuang Ma Shanghai Jiao Tong University.
Render methods. Contents Levels of rendering Wireframe Plain shadow Gouraud Phong Comparison Gouraud-Phong.
Illumination and Shading Sang Il Park Sejong University.
Lighting and Reflection Angel Angel: Interactive Computer Graphics5E © Addison-Wesley
David Luebke3/16/2016 CS 551 / 645: Introductory Computer Graphics David Luebke
Illumination Models. Introduction 1 Illumination model: Given a point on a surface, what is the perceived color and intensity? Known as Lighting Model,
CPSC 314 LIGHTING AND SHADING UGRAD.CS.UBC.CA/~CS314 slide credits: Mikhail Bessmeltsev et al 1.
Computer Graphics Ken-Yi Lee National Taiwan University (the slides are adapted from Bing-Yi Chen and Yung-Yu Chuang)
Computer Graphics: Illumination
Illumination and Shading. Illumination (Lighting) Model the interaction of light with surface points to determine their final color and brightness OpenGL.
Illumination and Shading Prof. Lizhuang Ma Shanghai Jiao Tong University.
So Far We have assumed that we know: The point The surface normal
Chapter 14 Shading Models.
CSC461: Lecture 23 Shading Computation
Illumination and Shading
Chapter 14 Shading Models.
Presentation transcript:

Shading, Surfaces & Textures 1

Outline Polygon shading models Lighting models Surfaces properties Constant, interpolated, polygon mesh, Lambert, Gouraud, Phong Lighting models Lambert, Phong, Blinn Surfaces properties Surface mapping Texture Bump Displacement … 2

Lighting algorithms Most algorithms use the polygon or surface normal (vector that is perpendicular to the polygon) The amount of light reflected depends on the angle of the incident light, e.g. for diffuse reflection: N L 3

Constant shading Also known as Lambert, faceted and flat shading Calculates a single intensity value for each polygon Valid if following assumptions are true: Light source is at infinity (i.e. angle between light and surface is constant) Viewer is at infinity (i.e. angle between viewer and surface is constant) Polygon is not an approximation of a curved surface 4

Interpolated shading Shading is linearly interpolated across polygon Faster than calculating each pixel, better than flat shading Still assumes that polygon represents the true surface 5

Polygon mesh shading Many sets of polygons actually are approximations to curved surfaces Shading the polygons to realistically simulate the surface is therefore important Several methods exist to achieve this, the most important of which are Gouraud and Phong shading. 6

Gouraud shading This is a form of intensity interpolation shading (Henri Gouraud, PhD 1971) This is a form of intensity interpolation shading Starts from knowing the normal of the surface at each vertex of the polygon These may be stored with the mesh or may be averaged from the adjacent polygons Next step is to calculate the vertex intensities This will use the vertex normal and the illumination algorithm 7

Gouraud shading (2) The polygon is then shaded by: Interpolating the intensities along each edge Interpolating across the polygon between the edges along each scan line I1 I2 I3 IP 8

Gouraud algorithm Compute SA, SB, SC for triangle ABC. Si = shade of point i. For a scanline XY, compute SX, SY by interpolating e.g. tAB = |AX| / |AB|. SA = tAB* SA + (1-tAB)*SB Compute SP By interpolating between SX and SY B X P Y scanline SX SP SY A C

Gouraud example

Phong shading This is a form of normal-vector interpolation shading (Bui-Tong Phong, PhD 1975) This is a form of normal-vector interpolation shading Starts from the normal vector at each vertex again, but interpolates the vector rather than the intensity 9

Phong shading (2) In general, this yields much more realistic results, especially for specular surfaces Gouraud shading may miss specular highlights It is several orders of magnitude slower than Gouraud 10

Problems with interpolated shading Polygonal silhouette Perspective distortion Orientation dependence Shared vertices Unrepresentative vertex normals 11

Polygonal silhouette Approximation is polygonal, so no matter how good the shading algorithm the silhouette will be faceted Can be improved by increasing the polygon count at expense of processing time 12

Perspective distortion Because the interpolation is based on the scan lines, the number of interpolation increments per polygon depends on the angle of the polygon to the viewer Steep angle = few increments Shallow angle = more increments 13

Orientation dependence Because interpolation occurs between vertices and along scan lines, result depends on orientation of polygon relative to scan lines 14

Shared vertices Problems occur when adjacent polygons do not share vertices This can lead to discontinuities in shading 15

Unrepresentative vertex normals Vertices may not adequately represent the surface geometry Usually can be solved by further subdividing surface 16

Surfaces Definition of visual characteristics of a surface Often defined by a ‘shader’ or ‘material’ Specifies colour, how shiny it is, etc.

Surface parameters Colour usually defined by RGB values or via GUI Ambient is a false parameter that defines how ‘ambient’ light is treated Diffuse parameter specifies how much light in total is evenly reflected Specularity defines how shiny a surface is (a high value will have highlights like a billiard ball) May also have controls for highlight size and colour

Advanced surface parameters Reflectivity defines how much of the surrounding environment is reflected by the surface (like a mirror) Transparency defines of the background is visible through the surface Translucency defines how much light is transmitted through the surface Refractivity defines how much light is bent as it enters and leaves the material

Surfaces in Maya Basic materials: Special materials: Lambert Phong Phong E Blinn Special materials: Anisotropic, Layered Shader, Ocean Shader, Ramp Shader, Shading Map, Surface Shader, Use Background

Lambert This is the simplest material It creates a matt surface with diffuse and ambient components but no highlights The shading interpolates between adjacent polygon normals so the surface appears smooth It uses Lambert’s cosine law

Lambert’s Cosine Law “The reflected luminous intensity in any direction from a perfectly diffusing surface varies as the cosine of the angle between the direction of incident light and the normal vector of the surface” Johann Lambert, 1728-1777.

Lambert’s Cosine Law Ideal diffuse surfaces obey this cosine law Often called Lambertian surfaces. Id = kd Iincident cos  = kd Iincident (N·L). where kd is the diffuse reflectance of the material. Wavelength dependent, so usually specified as a colour.

Maya Lambert properties

Phong This lighting model includes specularity (Bui-Tong Phong, 1975) This lighting model includes specularity This takes into account that the amount of light you see depends on the viewer’s angle to the surface as well as the light’s angle His original formula for the specular term: W(i)(cos s )n s is the angle between the view and specular reflection directions. “W(i) is a function which gives the ratio of the specular reflected light and the incident light as a function of the the incident angle i.” Ranges from 10 to 80 percent. “n is a power which models the specular reflected light for each material.” Ranges from 1 to 10.

Phong lighting model More recent formulations are slightly different Replace W(i) with a constant ks, independent of the incident direction Is= ks Iincident cosn = ks Iincident (V·R)n. V is the view direction. R is the specular reflection direction L N  R V

Variation of n

Maya Phong properties

Maya’s ‘Phong E’ Uses a simplified model, faster to render than pure Phong

Maya’s Blinn Based on Blinn-Phong shading (an adaptation of Phong) (Jim Blinn, 1977) Based on Blinn-Phong shading (an adaptation of Phong) Offers great control over specularity but in general will not look as ‘shiny’ as a Phong material

Maya Blinn properties II

2D texture mapping A ‘cheap’ way of enhancing the the surface definition So far, surfaces have been defined with a plain colour In real life, many surfaces are multi-coloured E.g. Wood looks ‘wooden’ because of many different colour variations in the grain 3

2D texture mapping (2) 2D texture mapping involves applying a 2D image to the surface of a 3D object In this case the term ‘texture’ applies to the image rather than the more traditional ‘feel’ of the surface Textures may be ‘real’ (e.g. scanned), manually generated (e.g. with a paint program) or procedurally generated (e.g. by a computer program) 4

2D texture mapping (3) The process of applying the texture is the ‘mapping’ The two mapping processes: Projecting the image onto the surface Stretching the image to fit on the surface 5

Projection mapping In projection mapping the image is projected through space Wherever it ‘hits’ the surface the surface becomes the colour of the texture The purest form of this is planar projection 6

Cylindrical projection Image is bent into a cylinder before projection takes place Object is then placed ‘in’ the cylinder 7

Spherical projection Image bent onto an imaginary sphere before projection Object placed ‘in’ sphere 8

Limitations Unless mapping on a perfect flat surface, cylinder or sphere, all projection methods will have a tendency to ‘streak’ Parameterised texture mapping offers a solution to this problem 9

Parameterised (UV) mapping Imagine printing the texture image onto thin transparent film Then stretch the film over the surface This is the principle of parameterised texture mapping 10

Parameterised mapping (2) The 2D texture image is (obviously) an array of rectangular pixels These can be referenced by Cartesian coordinates, usually with the lower left pixel being (0,0) (and for a 512 x 512 image the top right being (511,511)) Each pixel rectangle is then mapped to a corresponding area of the 3D surface 11

Parameterised mapping (3) You therefore have to divide the surface into the same number of steps The surface patch is defined to use the coordinate system U and V to specify locations on it The area defined by (0,0) on the surface has the colour applied to it from the image pixel at (0,0) 12

Procedural textures Textures can be generated by procedures rather than using predefined images This is good for regular patterns (e.g. brickwork) or (semi-)random patterns (e.g. noise)

Maya procedural textures

Got to here! Other types of mapping So far, all examples have used the colour of the image to affect the colour of the surface - this is colour texture mapping Other options are transparency mapping, bump mapping and displacement mapping 14

Transparency mapping Use pixel value to define transparency of object Usually uses grey values, white = opaque & black = transparent 15

Bump mapping Uses pixel values to ‘perturb’ the surface normals Used to model tiny variations in surface contour Actual surface doesn’t change geometry, but appears to because normal is shifted Good for ‘orange peel’ like effects, but outline is still smooth 16

Displacement mapping Uses the intensity of the pixel to actually shift part of the surface up (for white) or down (for black) Used to model surface irregularity, but unlike bump mapping the surface geometry actually changes 17

Other image-based mapping Incandescence mapping Pixel values = ‘glow brightness’ Specularity mapping Pixel values = specularity Reflectivity mapping Pixel values = reflectivity 18

3D texture mapping Often, realistic objects require more than just 2D images mapped onto them E.g. Shiny surfaces (such as chrome) should reflect the environment that surrounds them Some of these effects can be achieved by ray tracing, but this is expensive We can use environmental reflection mapping (sometimes called just reflection mapping) 19

Reflection mapping Cubic (most common) Spherical Six views of the surrounding world are generated and mapped on the object using cubic texture mapping Six images may be rendered views Spherical Use a single image that is spherically texture mapped Difficult to generate the single image correctly 20

Solid texture mapping Useful for things such as wood grain, marble, etc. Create a volume of texture Object then ‘floats’ in this volume and surface points adopt colours defined in the volume Can also be used to model transparency and other effects 21

Summary Shading algorithms Lighting algorithms Surface properties Flat, Gouraud, Phong Lighting algorithms Lambert, Phong… Surface properties Diffuse, specular… Surface mapping Texture, bump, displacement…