KEMBAR78
Lecture 8 | PDF | Geometry
0% found this document useful (0 votes)
18 views40 pages

Lecture 8

The document provides an overview of two-dimensional viewing in computer graphics, detailing the viewing pipeline, coordinate transformations, and various clipping operations. It covers techniques for point, line, and polygon clipping, including algorithms such as Cohen-Sutherland and Sutherland-Hodgeman. Additionally, it discusses the setup of viewing coordinate reference frames and the mapping of window-to-viewport coordinates.

Uploaded by

u1904031
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
18 views40 pages

Lecture 8

The document provides an overview of two-dimensional viewing in computer graphics, detailing the viewing pipeline, coordinate transformations, and various clipping operations. It covers techniques for point, line, and polygon clipping, including algorithms such as Cohen-Sutherland and Sutherland-Hodgeman. Additionally, it discusses the setup of viewing coordinate reference frames and the mapping of window-to-viewport coordinates.

Uploaded by

u1904031
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 40

Two-Dimensional Viewing

COMPUTER GRAPHICS

7/18/2023 1
Contents
• The Viewing Pipeline
• Viewing Coordinate Reference Frame
• Window-To-Viewport Coordinate Transformation
• Two-Dimensional Viewing Functions
• Clipping Operations
• Point Clipping
• Line Clipping
• Polygon Clipping
7/18/2023 2
The Viewing Pipeline (1/3)
• What’s the viewing pipe line??
– Viewing transformation in several steps
• A viewing transformation using standard
rectangles for the window and viewport
ywmax ywmax

ywmin ywmin
xvmin xvmax xvmin xvmax
World Coordinates Device Coordinate
7/18/2023 3
The Viewing Pipeline (2/3)
• The two-dimensional viewing-
transformation pipeline
Construct World Coordinate Convert
Scene Using World-Coordinates
Modeling-Coordinate to
Transformation Viewing Coordinates

Map Normalized Map Viewing Coordinates to


Viewport to Normalized Viewing
Device Coordinates using
Coordinates Window-Viewport Specifications

7/18/2023 4
The Viewing Pipeline (3/3)
• Setting up a rotated world window in viewing
coordinates and the corresponding normalized-
coordinate viewport

y world 1

y0 Viewpoint

x0 x world 0 1
World Coordinates Normalized
Device Coordinates
7/18/2023 5
Viewing Coordinate Reference Frame (1/2)
• Used to provide a method for setting up arbitrary
orientations for rectangular windows
• Matrix for converting world-coordinate
positions to viewing coordinate

Μ W C,VC = R  Τ
R: rotation matrix
T: translation matrix

7/18/2023 6
Viewing Coordinate Reference Frame (2/2)
• The steps in this coordinate transformation
– A viewing coordinate frame is moved into
coincidence with the world frame in two steps
a) Translate the viewing origin to the world origin, then
b) Rotate to align the axes of the two systems

7/18/2023 7
Window-To-Viewport Coordinate
Transformation (1/5)
• Window-to-viewport mapping
– A point at position (xw, yw) in a designated window is
mapped to viewport coordinates (xv, yv) so that relative
positions in the two areas are the same

7/18/2023 8
Window-To-Viewport Coordinate
Transformation (2/5)
• To maintain the same relative placement
xv − xvmin xw − xwmin
xvmax − xvmin = xwmax − xwmin
yv − yvmin yw − ywmin
yvmax − yvmin = ywmax − ywmin
• Solving these expressions for the viewport
position (xv, yv)
xv = xvmin ( xw − xwmin ) sx
yv = yvmin ( yw − ywmin ) sy
7/18/2023 9
Window-To-Viewport Coordinate
Transformation (3/5)
• The scaling factors
xvmax − xvmin
sx = xwmax − xwmin
yvmax − yvmin
sy = ywmax − ywmin
• Conversion sequence of transformation
1. Perform a scaling transformation using a fixed-point
position of (xwmin, ywmin) that scales the window area
to the size of the viewport
2. Translate the scaled window area to the position of
the viewport
7/18/2023 10
Window-To-Viewport Coordinate
Transformation (4/5)
• The way of character string mapping
– Maintaining character size
• Using standard character fonts
– Changing character size
• Using characters formed with line segments
• Workstation transformation
– Opening any number of output devices in a particular
application
– Performing another window-to-viewport transformation
for each open output device

7/18/2023 11
Window-To-Viewport Coordinate
Transformation (5/5)
• Mapping selected
parts of a scene
in normalized
coordinates to
different video
monitors with
Workstation
transformation

7/18/2023 12
Two-Dimensional Viewing Functions (1/2)
• Definition about a viewing reference system
– evaluateViewOrientationMatrix (x0, y0, xV, yV, error, viewMatrix)
• Setting up the elements of a window-to-viewport mapping
matrix
– setviewRepresentation (ws, viewIndex, viewMatrix, viewMap-
pingMatrix, xclipmin, xclipmin, xclipmin, xclipmin, clipxy)
• Storing combinations of viewing and window-viewport
mappings for various workstations in a viewing table
– evaluateViewMappingMatrix (xwmin, xwmax, ywmin, ywmax,
xvmin, xvmax, yvmin, yvmax, error, viewMappingMatrix)

7/18/2023 13
Two-Dimensional Viewing Functions (2/2)
• Selection of a paticular set of options from
the viewing table
– setViewIndex (viewIndex)
• Selection of a workstation window-
viewport pair
– setWorkstationWindow (ws, xwsWindmin,
xwsWindmax, ywsWindmin, ywsWindmax)
– setWorkstationViewport (ws, xwsVPortmin,
xwsVPortmax, ywsVPortmin, ywsVPortmax)
7/18/2023 14
Clipping Operations
• Clipping
– Any procedure that identifies those portions of a picture
that are either inside or outside of a specified region of
space
• Applied in World Coordinates
• Adapting Primitive Types
– Point
– Line
– Area (or Polygons)
– Curve, Text (omit!!)

7/18/2023 15
Point Clipping
• Assuming that the clip window is a
rectangle in standard position
• Saving a point P=(x, y) for display
xwmin  x  xwmax
ywmin  y  ywmax
• Appling Fields
– Particles (explosion, sea foam)

7/18/2023 16
Line Clipping (1/3)
• Line clipping against a rectangular clip window

a) Before Clipping b) After Clipping

7/18/2023 17
Line Clipping (2/3)
• Parametric representation of Line segment
with endpoints (x1, y1) and (x2, y2)
x = x1 + u(x2 − x1 )
y = y1 + u(y2 − y1 ), 0  u  1
• Exterior of the window
– Intersection with outside the range u
• Interior of the window
– Intersection with inside the range u

7/18/2023 18
Line Clipping (3/3)
• Cohen-Sutherland Line Clipping
• Liang-Barsky Line Clipping
• NLN(Nicholl-Lee-Nicholl) Line Clipping
• Line Clipping Using Nonrectangular Clip
Windows
• Splitting Concave Polygons

7/18/2023 19
Cohen-Sutherland Line Clipping (1/3)
• Region Code Creation
– Region Code 1 2 3 4
• Bit 1: above window
• Bit 2: below window
• Bit 3: right of window
• Bit 4: left of window
– Calculate differences between endpoint coordinates and
clipping boundaries
– Use the resultant sign bit of each difference calculation
to set the corresponding value in the region code

7/18/2023 20
Cohen-Sutherland Line Clipping (2/3)
• Line visible if both the region codes 0000
• Not visible if bitwise logical AND of the
codes is not 0000
• Clipping candidate if bitwise logical AND
of region codes is 0000

7/18/2023 21
Cohen-Sutherland Line Clipping (3/3)
• Calculate Intersection Point
– Using the slope-intercept form
– Vertical Boundary
y = y1 + m( x − x1 )
– Horizontal Boundary
y − y1
x = x1 +
m
m = ( y2 − y1 ) /( x2 − x1 )
7/18/2023 22
Liang-Barsky Line Clipping (1/4)
• Following parametric equations represent a
line along with its infinite extension.
x = x1 + ux x = x2 − x1 0  u  1
y = y1 + uy, y = y2 − y1
• For any point inside the clipping window:
xwmin  x1 + ux  xwmax
ywmin  y1 + uy  ywmax

7/18/2023 23
Liang-Barsky Line Clipping (2/4)
• Four inequalities can be expressed as
upk  qk , k = 1, 2, 3, 4
• Definition of parameter p, q
p1 = −x, q1 = x1 − xwmin
p2 = x, q2 = xwmax − x1
p3 = −y, q3 = y1 − ywmin
p4 = y q4 = ywmax − y1

7/18/2023 24
Liang-Barsky Line Clipping (3/4)
• pk = 0
– qk = 0: boundary
– qk < 0: rejection
– qk > 0: test!!
• pk < 0
– Line proceeds from outside to inside
• pk > 0
– Line proceeds from inside to outside

7/18/2023 25
Liang-Barsky Line Clipping (4/4)
• pk < 0
qk
– u1 = min(u) u=
pk
• pk > 0
– u2 = max(u)
• u1 > u2
– Rejection
• u1 < u2 or u1 = u2
– Draw

7/18/2023 26
NLN Line Clipping(1/4)
• Three possible position for a line end point P1
– Equal position with rotation or translation

7/18/2023 27
NLN Line Clipping (2/4)
• The four clipping region when P1 is inside the clip window
• The four clipping region when P1 is directly left of the clip
window
• The two possible sets of clipping regions when P1 is above
and to the left of the clip window

7/18/2023 28
NLN Line Clipping (3/4)
• Region Determination
– P1 is left of the clipping rectangle, then P2 is in
the region LT if
Slope P1PTR < slope P1P2 < slope P1PTL
yT − y1 y2 − y1 yT − y1
or  
xR − x1 x2 − x1 xL − x1
– Clipping the entire line
( yT − y1 )( x2 − x1 )  ( xL − x1 )( y2 − y1 )
7/18/2023 29
NLN Line Clipping (4/4)
• Intersection Position Calculation
x = x1 + ( x2 − x1 )u
y = y1 + ( y2 − y1 )u
– Left Boundary
x = xL y2 − y1
y = y1 + ( xL − x1 )
u = ( xL − x1 ) /( x2 − x1 ) x2 − x1
– Top Boundary
y = yT x2 − x1
x = x1 + ( yT − y1 )
u = ( yT − y1 ) /( y2 − y1 ) y2 − y1

7/18/2023 30
Line Clipping Using Nonrectangular
Clip Windows
• Line clipping against arbitrarily shaped polygon
• Modifying the algorithm to include the parametric
equations for the boundaries of the clip region
• Concave Polygon Clipping Region
– Splitting concave polygon into a set of convex
polygons
• Circle, Curved-Boundary Clipping Region
– Less Commonly Used
– Very Slow Algorithm
7/18/2023 31
Polygon Clipping
• Convex polygon and concave polygon: In a convex polygo
n, a line joining any two interior points of the polygon lies
completely inside the polygon
• Positive orientation (counter clockwise orientation) and ne
gative orientation (clockwise orientation)
• Let A( x1, y2 ) and B( x2 , y2 ) be the end points of a directed li
ne segments. A point P ( x, y ) will be to the left of the line s
egment if the expression C = ( x − x )( y − y ) − ( y − y )( x − x )
2 1 1 2 1 1
is positive.

7/18/2023 32
Splitting Concave Polygons (1/2)
• Vector Method
– Identifying a
concave
polygon by
calculating
cross products
of successive
pairs of edge
vectors

7/18/2023 33
Polygon Clipping (1/2)
• Display of polygon processed by a line-
clipping algorithm

• Display of a correctly clipped polygon


7/18/2023 34
Polygon Clipping (2/2)
• Sutherland-Hodgeman Polygon Clipping
• Weiler-Atherton Polygon Clipping
• Other Polygon-Clipping Algorithm

7/18/2023 35
Sutherland-Hodgeman Polygon Clipping
(1/2)
• Clipping a polygon against successive window boundary

• Successive processing of pairs of polygon vertices against


the left window boundary

7/18/2023 36
Sutherland-Hodgeman Polygon Clipping
(2/2)
• A polygon
overlapping
a rectangular
clip window
• Processing the vertices of the polygon

7/18/2023 37
Weiler-Atherton Polygon Clipping (1/2)
• Problem of Sutherland-Hodgeman clipping
– Displaying extraneous line

??

7/18/2023 38
Weiler-Atherton Polygon Clipping (2/2)
• Rules
– For an outside-to-inside pair of vertices, follow the polygon
boundary
– For an inside-to-outside pair of vertices, follow the window
boundary in clockwise direction
• Correct Result

7/18/2023 39
Other Polygon-Clipping Algorithm
• Extending parametric line-clipping method
– Well suited for convex polygon-clipping
– Using region testing procedures
• Clipping a polygon
by determining the
intersection of two
polygon areas

7/18/2023 40

You might also like