Viewing in 3D Lecture 11. Viewing in 3D2 u The 3D viewing process is inherently more complex than is the 2D viewing process. F In 2D, we simply specify.

Slides:



Advertisements
Similar presentations
GR2 Advanced Computer Graphics AGR
Advertisements

Computer Graphics Lecture 8 Arbitrary Viewing II: More Projection, Clipping and Mathematics of 3D Viewing.
Three Dimensional Viewing
1 Computer Graphics Chapter 8 3D Transformations.
Projection.
Three-Dimensional Viewing Sang Il Park Sejong University Lots of slides are stolen from Jehee Lee’s.
CS 325 Introduction to Computer Graphics 02 / 24 / 2010 Instructor: Michael Eckmann.
CS 376 Introduction to Computer Graphics 02 / 26 / 2007 Instructor: Michael Eckmann.
4.1si31_2001 SI31 Advanced Computer Graphics AGR Lecture 4 Projection Clipping Viewport Transformation.
3D Concepts UNIT 3. 3-D Coordinate Spaces Remember what we mean by a 3-D coordinate space x axis y axis z axis P y z x Right-Hand Reference System.
1 Chapter 5 Viewing. 2 Perspective Projection 3 Parallel Projection.
Visualization- Determining Depth From Stereo Saurav Basu BITS Pilani 2002.
CHAPTER 7 Viewing and Transformations © 2008 Cengage Learning EMEA.
Projection Projection - the transformation of points from a coordinate system in n dimensions to a coordinate system in m dimensions where m
12.1 Si23_03 SI23 Introduction to Computer Graphics Lecture 12 – 3D Graphics Transformation Pipeline: Projection and Clipping.
Copyright  1999 by James H. Money. All rights reserved. Except as permitted under United States Copyright Act of 1976, no part of this publication may.
Computer Graphics (fall 2009)
Advanced Computer Graphics Three Dimensional Viewing
Transformation & Projection Feng Yu Proseminar Computer Graphics :
1 2D Transformations 几何变换. 2 What is a transformation? A transformation is an operation that transforms or changes a shape (line, drawing etc.) There.
2 COEN Computer Graphics I Evening’s Goals n Discuss the mathematical transformations that are utilized for computer graphics projection viewing.
CS559: Computer Graphics Lecture 9: Projection Li Zhang Spring 2008.
Viewing Angel Angel: Interactive Computer Graphics5E © Addison-Wesley
Graphics Graphics Korea University cgvr.korea.ac.kr 3D Viewing 고려대학교 컴퓨터 그래픽스 연구실.
Computer Graphics Bing-Yu Chen National Taiwan University.
CAP 4703 Computer Graphic Methods Prof. Roy Levow Chapter 5.
1 Computer Graphics Week9 -3D Geometric Transformation.
CS 376 Introduction to Computer Graphics 02 / 23 / 2007 Instructor: Michael Eckmann.
CS 325 Introduction to Computer Graphics 02 / 22 / 2010 Instructor: Michael Eckmann.
Basic Projections 2D to 3D
CS 325 Introduction to Computer Graphics 02 / 26 / 2010 Instructor: Michael Eckmann.
University of North Carolina at Greensboro
2003CS Hons RW778 Graphics1 Chapter 7: Three-Dimensional Viewing Chapter 5: Camera with parallel projection Chapter 5: Camera with parallel projection.
Basic Perspective Projection Watt Section 5.2, some typos Define a focal distance, d, and shift the origin to be at that distance (note d is negative)
Review on Graphics Basics. Outline Polygon rendering pipeline Affine transformations Projective transformations Lighting and shading From vertices to.
Three-Dimensional Viewing
Three-Dimensional Viewing Hearn & Baker Chapter 7
12/24/2015 A.Aruna/Assistant professor/IT/SNSCE 1.
1 Angel: Interactive Computer Graphics 4E © Addison-Wesley 2005 Classical Viewing Ed Angel Professor of Computer Science, Electrical and Computer Engineering,
Rendering Pipeline Fall, D Polygon Rendering Many applications use rendering of 3D polygons with direct illumination.
1 Projection: Completing the Camera Model ©Yiorgos Chrysanthou 2001, Anthony Steed
CS552: Computer Graphics Lecture 11: Orthographic Projection.
Coordinate Systems Lecture 1 Fri, Sep 2, The Coordinate Systems The points we create are transformed through a series of coordinate systems before.
CS559: Computer Graphics Lecture 9: 3D Transformation and Projection Li Zhang Spring 2010 Most slides borrowed from Yungyu ChuangYungyu Chuang.
CS 376 Introduction to Computer Graphics 02 / 21 / 2007 Instructor: Michael Eckmann.
RAC/RA Projection Types of Projection Simple Projections Generalized Projection.
Viewing Angel Angel: Interactive Computer Graphics5E © Addison-Wesley
Viewing. Classical Viewing Viewing requires three basic elements - One or more objects - A viewer with a projection surface - Projectors that go from.
Projection. Conceptual model of 3D viewing process.
Computer Graphics Projections.
3D Viewing and Clipping Ming Ouhyoung 歐陽明 Professor Dept. of CSIE and GINM NTU.
CS552: Computer Graphics Lecture 9: Perspective Projection.
Three Dimensional Viewing
Rendering Pipeline Fall, 2015.
Computer Graphics CC416 Week 14 3D Graphics.
Projection Our 3-D scenes are all specified in 3-D world coordinates
Prof. Lizhuang Ma Shanghai Jiao Tong University
Rendering Pipeline Aaron Bloomfield CS 445: Introduction to Graphics
CSCE 441 Computer Graphics 3-D Viewing
CSC461: Lecture 20 Parallel Projections in OpenGL
Viewing in 3D Chapter 6.
CENG 477 Introduction to Computer Graphics
3D Clipping.
Three Dimensional Viewing
3D Graphics.
Viewing (Projections)
Viewing (Projections)
Prof. Lizhuang Ma Shanghai Jiao Tong University
THREE-DIMENSIONAL VIEWING
Viewing Transformations II
Presentation transcript:

Viewing in 3D Lecture 11

Viewing in 3D2 u The 3D viewing process is inherently more complex than is the 2D viewing process. F In 2D, we simply specify a window on the 2D world and a viewport on the 2D view surface. F Conceptually, objects in the world are clipped against the window and then transformed into the viewport for display. F Although 3D viewing may seem overwhelming at first, it is less daunting when viewed as a series of easily understood steps, many of which we have prepared for in earlier chapters.

Viewing in 3D3 1. The Synthetic Camera and Steps in 3D Viewing n A useful metaphor for creating 3D scenes is the notion of a synthetic camera

Viewing in 3D4 u While the synthetic camera is a useful concept, there is a bit more to producing an image than just pushing a button. u Creation of our photo is accomplished as a series of steps: F Specification of projection type F Specification of viewing parameters F Clipping in three dimensions F Projection and Display

Viewing in 3D5 2. Projections n In general, projections transform points in a coordinate system of dimension n into points in a coordinate system of dimension less than n. n For now we shall limit ourselves to 3D to 2D.

Viewing in 3D6 u The projection of a 3D object is defined by straight projection rays, called projectors, emanating from a center of projection, passing through each point of the object, and intersecting a projection plane to form the projection. F Two locations for the center of projection: finite distance (perspective projection) andfinite distance (perspective projection) and infinite distance (parallel projection)infinite distance (parallel projection)

Viewing in 3D7

8 2.1 Perspective Projections u The perspective projections of any set of parallel lines that are not parallel to the projection plane converge to a vanishing point. F if the set of lines is parallel to one of the three principal axes, the vanishing point is called an axes vanishing point

Viewing in 3D9 u Perspective projections are categorized by their number of principal vanishing points F One point perspective projection

Viewing in 3D10 F Two point perspective projection

Viewing in 3D Parallel Projections u Parallel projections are categorized into two types, depending on the relation between the direction of projection and the normal to the projection plane. u The two most common are: F orthographic -- direction of the projection and the normal of the plane are the same F oblique -- they are not the same.

Viewing in 3D12 u The most common types of orthographic projections are F front-elevation F top-elevation F side-elevation

Viewing in 3D13 u A special sub-type of orthographic projections are isometric projections. The projection plan normal makes equal angles with each principal axis.

Viewing in 3D14 u The other type of parallel projection is an Oblique projection F the projection plane normal and the direction of the projection differ.

Viewing in 3D15 3. Specification of an Arbitrary 3D View u 3D viewing involves not just a projection, but also a view volume against which the 3D world is clipped. u The projection and the view volume together provide all the information that we need to clip and project into 2D space. u Then the 2D transformation into physical device coordinates is straightforward.

Viewing in 3D16 u The projection plane (view plane in the graphics literature) is defined by F a point in the plane called a view reference point (VRP) and F a normal to the plane called the view-plane normal (VPN)

Viewing in 3D17 u To define a window on the view plane, we need to specify minimum and maximum window coordinates

Viewing in 3D18 F for a perspective projection it looks like: F for a parallel projection it looks like: u The center of projection and direction of projection are defined by the Projection Reference Point (PRP)

Viewing in 3D19 u At times we may want the view volume to be finite, in order to limit the number of output primitives projected onto the view plane. F You specify the front and back clipping planes F For parallel projections it looks like: F for perspective projections it looks like:

Viewing in 3D20 4. Examples of 3D Viewing n In this section, we consider how we can apply the basic viewing concepts introduced in Section 3 to create a variety of projections. u such as this house.

Viewing in 3D21 u Because this house is used throughout this section, it will be helpful to remember its dimensions and position, which are indicated here:

Viewing in 3D Perspective Projections u To obtain the front one-point perspective view shown here: F position the center of projection (the viewer) at (8,6,84)

Viewing in 3D23 u To make the vie larger and centered, F make the view plane and the front of the house coincide. F place the viewer at (8, 6, 30) in front of this plane.

Viewing in 3D24 u Other views could look like:

Viewing in 3D25 u And

Viewing in 3D Parallel Projections

Viewing in 3D Finite View Volumes n In all the examples so far, the view volume has been assumed to be infinite. n If we start with this setup

Viewing in 3D28 u and add a far clipping plane right in front of the far wall of the house, we can end up with an image that looks like:

Viewing in 3D29 5. The Mathematics of Planar Geometric Projections n Here we introduce the basic mathematics of planar geometric projections. n For simplicity, we start by assuming that,  in the perspective projection, the projection plane is normal to the z axis at z=d,  and that in the parallel projection, the projection plane is at z=0.

Viewing in 3D30  Each of the projections can be defined by a 4x4 matrix. F This is convenient, because the projection matrix can be composed with the transformation matrices, allowing two operations (transform then project) to be represented in a single matrix.  In this section we derive 4x4 matrices for several projections

Viewing in 3D31  Given a point P to be projected onto the plane, calculate the point P p =(x p, y p, z p ) which is the projection. u We use similar triangles as found in this figure u and calculate ratios for the transformation as:

Viewing in 3D32 u These ratios lead to a transformation matrix for a perspective projection of:

Viewing in 3D33  The orthographic projection pane at z=0 is straightforward, and ends up as:

Viewing in 3D34 6. Implementation of Planar Geometric Projections n Given a view volume and a projection, let us consider how the viewing operation of clipping and projecting is applied. n The brute force method was: u clip each line with the 6 planes of the volume. u project remaining lines by solving simultaneous equations for the projection onto the view plane u Then transform these to 2D space...

Viewing in 3D35 u The large number of calculations required for this process, repeated for many lines, involves considerable computing. u Happily there is a more efficient procedure, based on the divide-and-conquer strategy of breaking down a difficult problem into a series of simpler ones. F And they are much easier if you use the canonical volumes shown here:

Viewing in 3D36  Our goal is to find the normalizing transformations N par and N per that transform an arbitrary parallel or perspective projection view volume into the parallel and perspective view volumes u Then the rest of the process is done F clipping, F projection into 2D

Viewing in 3D The Parallel Projection Case In this section, we derive the normalizing transformation N par for parallel projections. In this section, we derive the normalizing transformation N par for parallel projections. n This is done in order to transform world- coordinate positions such that the view volume is transformed into the canonical view volume. n Then we clip and project.

Viewing in 3D38  Transformation N par is derived for the most general case, the oblique (rather than the orthographic) parallel projection.  N par thus includes a shear transformation that causes the direction of projection in viewing coordinates to be parallel to z.  By including this shear we can do the projection onto z=0 plane simply by setting z=0.

Viewing in 3D39  The series of transformations that make up N par is as follows: F Translate the VRP to the origin F Rotate VRC such that the n axis (VPN) becomes the z axis, the u axis becomes the x axis, and the v axis becomes the y axis. F Shear such that the direction of projection becomes parallel to the z axis. F Translate and scale into the parallel-projection canonical view volume.

Viewing in 3D The Perspective Projection Case u We now develop the normalizing transformation N per for perspective projections. u N per transforms world-coordinate positions such that the view volume becomes the perspective- projection canonical view volume, the truncated pyramid with the apex at the origin.  Then you clip and project using M per derived in section 6.5.

Viewing in 3D41  The series of transformations making up N per as follows: F Translate VRP to the origin F Rotate VRC such that the n axis (VPN) becomes the z axis, the u axis becomes the x axis, and the v axis becomes the y axis. F Translate such that the center of projection (COP), given by the PRP, is at the origin. F Shear that the center line of the view volume becomes the z axis F Scale such that the view volume becomes the canonical perspective view volume, the truncated right pyramid.

Viewing in 3D42 u This figure presents the view volume before and after the steps just described.

Viewing in 3D Clipping Against a Canonical View Volume in 3D u The canonical view volumes are: F the 2x2x1 prism for parallel projections F the truncated right regular pyramid for perspective projections

Viewing in 3D44 u Both the Cohen-Sutherland and Cyrus-Beck clipping algorithms discussed in Chapter 3 readily extend to 3D u There are also other clipping algorithms that are based on parametric expressions that can be more efficient than the simple Cohen- Sutherland algorithm (see Chapters 6 and 19 of Foley, vanDam, et.al. --the big white book).

Viewing in 3D Clipping in Homogeneous Coordinates u There are two reasons to clip in homogeneous coordinates: F efficiency translate perspective canonical to parallel canonical and do a single clip -- Hardware does this.translate perspective canonical to parallel canonical and do a single clip -- Hardware does this. F if you get a point with negative W it can be clipped in homogeneous, but not in 3D get negative W’s from unusual homogeneous transformations and from the use of parametric splines.get negative W’s from unusual homogeneous transformations and from the use of parametric splines.

Viewing in 3D46 u With regard to clipping, it can be shown that the transformation from the perspective- projection canonical view volume to the parallel-projection canonical view volume is:

Viewing in 3D47 F This matrix translates the canonical view volumes as shown: u As we will see in Chapter 9, it is sometimes desirable to represent points directly in homogeneous coordinates with arbitrary W.

Viewing in 3D Mapping into a Viewport n Output primitives are clipped in the normalized projection coordinate system, which is also called the 3D screen coordinate system

Viewing in 3D Implementation Summary u There are two generally used implementations of the overall viewing transformation F The first was discussed in Sections through appropriate when primitives are defined in 3D and the transformations never create a negative W.appropriate when primitives are defined in 3D and the transformations never create a negative W. F The second was discussed in Section required whenever primitives are defined and might have W<0, when transformations might create a W<0, or a single clip algorithm is implemented.required whenever primitives are defined and might have W<0, when transformations might create a W<0, or a single clip algorithm is implemented.

Viewing in 3D50 7. Coordinate Systems u Several different coordinate systems have been used in Chapters 5 and 6. u In this section we summarize all the systems, and also discuss their relationships to one another.

Viewing in 3D51 u Object Coordinate System F This is the system farthest removed from the actual display device. F The term local coordinate system is also commonly used here u World Coordinate System F Objects are transformed into this system by a modeling transformation. F This system is sometimes called the application- coordinate system

Viewing in 3D52 u The View-Reference coordinate system F used by some systems to define a view volume. F sometimes called the eye-coordinate system or the camera-coordinate system. u Normalized-Projection coordinate system F or 3D screen coordinates. F it is called normalized because the values are in the interval [0,1] (or [-1,1])

Viewing in 3D53 u The 2D Device coordinate system F projections from 3D into 2D creates this. F also called many other things: screen coordinate system,... u Unfortunately there is no single standard usage for many of these terms. F for example, the term screen-coordinate system is used by different authors to refer to the last three systems discussed.