- 180 Views
- Updated On :
- Presentation posted in: General

Computer Graphics

Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author.While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server.

- - - - - - - - - - - - - - - - - - - - - - - - - - E N D - - - - - - - - - - - - - - - - - - - - - - - - - -

- One of the central components of three-dimensional graphics has been a basic system that renders objects represented by a set of polygons
- One approach to rendering three-dimensional objects is to build a basic renderer then add on enhancements
- The basic renderer may be one which incorporates a local reflection model, such as the Phong model, into a Phong incremental shader

- Advantages gained by this approach include:
- Modeling objects using polygons is straighforward
- Piecewise linearities are rendered invisible by the shading technique

- Geometric information is only stored at the polygonal vertices - information required for the reflection model that evaluates a shade at each pixel is interpolated from this information
- This allows fast, hardware-based shading

- Modeling objects using polygons is straighforward

- More accurate representations made up of a set of bicubic patches can be converted to a polygon representation and fed to such a renderer
- One drawback of using polygons to model objects is that a large number of polygons are required to achieve much detail for complex objects

- The main steps in rendering a polygonal object are:
- 1. Polygons representing an object are extracted from the database and transformed into the world coordinate system using linear transformations such as translation and scaling
- 2. A scene constructed in this way is transformed into a coordinate system based on a view point or view direction.
- 3. The polygons are then subjected to a visibility test. This is called ‘backface elimination’ or ‘culling’ and removes those polygons that face away from the viewer.

- The main steps in rendering a polygonal object are:
- 4. Unculled polygons are clipped against a three-dimensional view volume.
- 5. Clipped polygons are then projected onto a view plane or image plane
- 6. Projected polygons are then shaded by an incremental shading algorithm. First, the polygon is rasterized, or those pixels that the edges of the polygon contain are determined. Second, a depth for each pixel is evaluated and a hidden surface calculation is performed. Third, the polygon is shaded.

- Objects that possess curved surfaces have these surfaces approximated by polygonal facets
- The error introduced by this representation may be visually diminished by using interpolative shading algorithms

- For complex objects, a number of polygons in excess of 100,000 is not uncommon
- Another problem occurs when objects are scaled up
- An object adequately represented at one size may degrade when the object is enlarged
- This has been called ‘geometric aliasing’

- Polygonal representations can be generated manually from a designer’s abstraction, or automatically from real objects by using devices such as laser rangers in conjunction with the appropriate software
- Complete information necessary to shade a polygon is usually stored in a hierarchical data structure - objects; surfaces; vertices and normals

- One view of the geometric part of the rendering process is that it consists of the application of a series of coordinate transformations that takes an object database through a series of coordinate systems
- For ease of modeling and application of local transformations, it makes sense to store the vertices of an object with respect to some point conveniently located in or near the the object
- This is called the local coordinate system

- Once an object has been modeled, the next stage is to place it in the scene that we wish to render
- The global coordinate system of the scene is known as the world coordinate system
- All the objects have to be placed into this common space in order to have their relative spatial relationships defined
- The act of placing an object in a scene defines the transformation required to take the object from local space to global space
- If this object is being animated, then the animation provides a time-varying transformation that takes the object into world space on a frame-by-frame basis

- The scene is lit in world space
- Light sources are specified
- The eye or camera coordinate system is a a space used to establish viewing parameters and view volume
- A virtual camera can be positioned anywhere in the world space and can point in any direction
- The scene is projected on a view plane

- This operation removes entire polygons that face away from the viewer
- When dealing with a single convex object, culling completely solves the hidden surface problem
- If an object contains a concavity, or if we have multiple objects in a scene, a general hidden surface removal algorithm is needed as well as culling

- We can determine whether a polygon is visible from a view point by a simple geometric test
- The geometric normal to the polygon is calculated and the angle between this and the line-of-sight vector is determined. (The line-of-sight vector is the vector from the polygon to the view point)
- If this angle is greater than 90 degrees, then the polygon is invisible.

- The fundamental transformation that takes us into screen space is the perspective transformation which takes a point in the scene and projects it onto a view plane positioned at disance D away from the view point and oriented normal to the viewing direction

- Screen space is defined to act within a closed volume called the viewing frustum that delineates the volume of space which is to be rendered
- Objects that lie outside the viewing frustum are not rendered

- A point in three dimensional space requires 3 coordinates - x, y and z - to describe its location
- In homoegeneous coordinates, an extra coordinate (which can be thought of as a scaling term) is added
- By using homogeneous coordinates, we are able to represent transformations as matrix multiplications
- Then in order to compute the transformation of some object, we need only perform matrix multiplications for the vertices of the polygons making up the object’s representation

- The transformations we are most interested in are scaling, translation and rotation
- These can be defined as follows

- Rotations about the y and z axis are similar
- A series of operations can be combined by performing a series of multiplications
- If the scaling factor is greater than one, the resulting coordinates must be divided by that number at the end of the operation

- The near plane is the view plane at distance D. The far plane is at distance F
- If the height of the view plane is 2h, then the perspective transformation can be given by the following matrix:
1000

0101

00hF/(D(F-D))h/D

00-hF/(F-D)0

- This transformation can simply be concatenated with all of the other transformations in the rendering pipeline
- Clipping is performed against the viewing frustum
- Objects lying completely outside the frustum are discarded
- Objects inside the frustum are transformed into screen space and then rendered
- Objects intersecting the frustum are clipped and then transformed into screen space

- Once the objects in a scene have been translated into screen space, the processing is oriented towards pixels rather than polygons
- Rasterization, hidden-surface removal and shading are all pixel-level processes

- Rasterization is the process of finding out which pixels a polygon projects onto in screen space
- Calculate, for each scan line within a polygon, by linear interpolation, the x values of the edge pixels, xstart and xend
- This results in a span of pixels between two edges that have to be rendered
- Care must be taken in these calculations, otherwise we will have aliasing problems (e.g. a straight line may appear to be a series of steps)
- Most of these problems are caused by rounding errors in the interpolation of polygon edges

- We now know which pixels contain which objects, however since some pixels may contain two or more objects we must calculate which of these objects is visible and which are hidden
- Hidden surface removal is generally accomplished using the Z-buffer algorithm

- In this algorithm, we set aside a two-dimensional array of memory (the Z-buffer) of the same size as the screen (#rows x #columns)
- This is in addition to the buffer we will use to store the values of pixels which will be displayed (color values)
- The Z-buffer will hold values which are depths (or z-values)
- The buffer is initialized so that each element has the value of the far clipping plane (the largest possible z-value after clipping has been performed)
- The other buffer is initialized so that each element contains a value which is the background color

- Now for each polygon we have a set of pixel values which that polygon covers
- For each one of these pixels, we compare its interpolated depth (z-value) with the value of the corresponding element already stored in the Z-buffer
- If this value is less than the previously stored value, the pixel is nearer the viewer than previously encountered pixels
- Replace the old value of the Z- buffer with the new, interpolated value and replace the old value of the other buffer with the value (color) of the pixel

- Repeat for all polygons in the image

- A major reason for the growth of popularity of polygon-based renderers is the existence of two interpolative or incremental shading algorithms usually known as Gouraud shading and Phong shading
- Gouraud shading is faster than the other method, but cannot produce accurate highlights. It is usually used in applications where speed is important

- Phong shading gives higher quality images, but is more expensive
- Gouraud shading calculates intensities at polygon vertices only, using a local reflection model, and interpolates these for pixels within the polygon
- Phong shading interpolates vertex normals and applies a local reflection model at each pixel

- The motivation of both schemes is efficiency and the ‘convincing’ rendering of polygonal objects
- This means that as well as giving an impression of solidity or three-dimensionality to the model, the shared edges in adjacent polygons that approximate a curved surface, are made invisible

- Generally, the intensity of light at a polygon vertex is described as a function of the orientation of vertex normals with respect to both the light source and the eye
- This function is called a reflection model
- Gouraud shading applies a local reflection model at each vertex of a polygon to calculate a set of vertex intensities
- These intensities are linearly interpolated across the polygon interior on a scan line basis

- In Phong shading, the vertex normals (calculated exactly as in Gouraud shading) are linearly interpolated
- The local reflection model is then applied at each pixel using the interpolated normal
- This solves the highlight problem and Mach banding, but is more computationally expensive