Download presentation
Presentation is loading. Please wait.
Published byEdwin Black Modified over 9 years ago
1
Review on Graphics Basics
2
Outline Polygon rendering pipeline Affine transformations Projective transformations Lighting and shading From vertices to fragments
3
Outline Polygon rendering pipeline Affine transformations Projective transformations Lighting and shading From vertices to fragments
4
Polygon Rendering Pipeline Process objects one at a time in the order they are generated by the application Pipeline architecture All steps can be implemented in hardware on the graphics card application program display
5
Vertex Processing Much of the work in the pipeline is in converting object representations from one coordinate system to another – Object coordinates – Camera (eye) coordinates – Screen coordinates Every change of coordinates is equivalent to a matrix transformation Vertex processor also computes vertex colors
6
Projection Projection is the process that combines the 3D viewer with the 3D objects to produce the 2D image – Perspective projections: all projectors meet at the center of projection – Parallel projection: projectors are parallel, center of projection is replaced by a direction of projection
7
Primitive Assembly Vertices must be collected into geometric objects before clipping and rasterization can take place – Line segments – Polygons – Curves and surfaces
8
Clipping Just as a real camera cannot “see” the whole world, the virtual camera can only see part of the world or object space – Objects that are not within this volume are said to be clipped out of the scene
9
Rasterization If an object is not clipped out, the appropriate pixels in the frame buffer must be assigned colors Rasterizer produces a set of fragments for each object Fragments are “potential pixels” – Have a location in frame buffer – Color and depth attributes Vertex attributes are interpolated over objects by the rasterizer
10
Fragment Processing Fragments are processed to determine the color of the corresponding pixel in the frame buffer Colors can be determined by texture mapping or interpolation of vertex colors Fragments may be blocked by other fragments closer to the camera – Hidden-surface removal
11
Outline Polygon rendering pipeline Affine transformations Projective transformations Lighting and shading From vertices to fragments
12
Affine Transformations Line and parallelism preserving Affine transformations used in Graphics – Rigid body transformations: rotation, translation – Scaling, shear Importance in graphics is that we need only transform endpoints of line segments and let implementation draw line segment between the transformed endpoints
13
Homogeneous Coordinates The homogeneous coordinates form for a three dimensional point [x y z] is given as p =[x’ y’ z’ w] T =[wx wy wz w] T We return to a three dimensional point (for w 0 ) by x x’ /w y y’/w z z’/w If w=0, the representation is that of a vector Note that homogeneous coordinates replaces points in three dimensions by lines through the origin in four dimensions For w=1, the representation of a point is [x y z 1]
14
Homogeneous Coordinates and Computer Graphics Homogeneous coordinates are key to all computer graphics systems – All standard transformations (rotation, translation, scaling) can be implemented with matrix multiplications using 4 x 4 matrices – Hardware pipeline works with 4 dimensional representations
15
Translation Matrix We can also express translation using a 4 x 4 matrix T in homogeneous coordinates p ’= Tp where T = T (d x, d y, d z ) = This form is better for implementation because all affine transformations can be expressed this way and multiple transformations can be concatenated together
16
Rotation (2D) Consider rotation about the origin by degrees – radius stays the same, angle increases by x’=x cos –y sin y’ = x sin + y cos x = r cos y = r sin x’ = r cos ( y’ = r sin (
17
Rotation about the z axis Rotation about z axis in three dimensions leaves all points with the same z – Equivalent to rotation in two dimensions in planes of constant z – or in homogeneous coordinates p ’= R z ( )p x’=x cos –y sin y’ = x sin + y cos z’ =z
18
Rotation Matrix R = R z ( ) =
19
Scaling S = S(s x, s y, s z ) = x’=s x x y’=s y x z’=s z x p’=Sp Expand or contract along each axis (fixed point of origin)
20
Reflection corresponds to negative scale factors original s x = -1 s y = 1 s x = -1 s y = -1s x = 1 s y = -1
21
Shear Helpful to add one more basic transformation Equivalent to pulling faces in opposite directions
22
Shear Matrix Consider simple shear along x axis x’ = x + y cot y’ = y z’ = z H( ) =
23
Outline Polygon rendering pipeline Affine transformations Projective transformations Lighting and shading From vertices to fragments
24
Affine vs. Projective Transformation Difference is in the last line of the transformation matrix. – Projective transformation preserves collinearity but not parallelism, length, and angle. – Affine transformation is a special case of the projective transformation. However, it preserves parallelism. M a = M p =
25
Projections and Normalization The default projection in the eye (camera) frame is orthogonal For points within the default view volume Most graphics systems use view normalization – All other views are converted to the default view by transformations that determine the projection matrix – Allows use of the same pipeline for all views x p = x y p = y z p = 0
26
Homogeneous Coordinate Representation x p = x y p = y z p = 0 w p = 1 p p = Mp M = In practice, we can let M = I and set the z term to zero later default orthographic projection
27
Simple Perspective Center of projection at the origin Projection plane z = d, d < 0
28
Perspective Equations Consider top and side views x p =y p = z p = d
29
Homogeneous Coordinate Form M = consider q = Mp where q = p =
30
Perspective Division However w 1, so we must divide by w to return from homogeneous coordinates This perspective division yields the desired perspective equations We will consider the corresponding clipping volume with the OpenGL functions x p =y p = z p = d
31
Outline Polygon rendering pipeline Affine transformations Projective transformations Lighting and shading From vertices to fragments
32
Phong Model For each light source and each color component, the Phong model can be written as I = (a+bd+cd 2 ) -1 [ k d I d l · n+k s I s ( v · r ) +k a I a ] For each color component we add contributions from all sources
33
Example Only differences in these teapots are the parameters in the modified Phong model
34
Outline Polygon rendering pipeline Affine transformations Projective transformations Lighting and shading From vertices to fragments
35
Pipeline Clipping of Polygons Three dimensions: add front and back clippers Strategy used in SGI Geometry Engine Small increase in latency
36
Scan Conversion and Interpolation span C1C1 C3C3 C2C2 C5C5 C4C4 scan line C 1 C 2 C 3 specified by glColor or by vertex shading C 4 determined by interpolating between C 1 and C 2 C 5 determined by interpolating between C 2 and C 3 interpolate between C 4 and C 5 along span
37
Hidden Surface Removal z-Buffer Algorithm – Use a buffer called the z or depth buffer to store the depth of the closest object at each pixel found so far – As we render each polygon, compare the depth of each pixel to depth in z buffer – If less, place shade of pixel in color buffer and update z buffer
Similar presentations
© 2024 SlidePlayer.com. Inc.
All rights reserved.