KEMBAR78
Computer Graphics - 2D Transformation | PDF | 2 D Computer Graphics | Euclidean Geometry
0% found this document useful (0 votes)
26 views8 pages

Computer Graphics - 2D Transformation

The document discusses 2D transformations in computer graphics, including translation, rotation, scaling, reflection, and shearing. It explains the use of homogeneous coordinates and transformation matrices to perform these operations efficiently. Composite transformations are also covered, highlighting the importance of the order of transformations in achieving desired results.

Uploaded by

raagavi109
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)
26 views8 pages

Computer Graphics - 2D Transformation

The document discusses 2D transformations in computer graphics, including translation, rotation, scaling, reflection, and shearing. It explains the use of homogeneous coordinates and transformation matrices to perform these operations efficiently. Composite transformations are also covered, highlighting the importance of the order of transformations in achieving desired results.

Uploaded by

raagavi109
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/ 8

Page 1 of 8

Computer Graphics - 2D Transformation


Transformation means changing some graphics into something else by applying rules. We
can have various types of transformations such as translation, scaling up or down,
rotation, shearing, etc. When a transformation takes place on a 2D plane, it is called 2D
transformation.

Transformations play an important role in computer graphics to reposition the graphics


on the screen and change their size or orientation.

Homogenous Coordinates
To perform a sequence of transformation such as translation followed by rotation and
scaling, we need to follow a sequential process −

Translate the coordinates,


Rotate the translated coordinates, and then

Scale the rotated coordinates to complete the composite transformation.

To shorten this process, we have to use 3×3 transformation matrix instead of 2×2
transformation matrix. To convert a 2×2 matrix to 3×3 matrix, we have to add an extra
dummy coordinate W.

In this way, we can represent the point by 3 numbers instead of 2 numbers, which is
called Homogenous Coordinate system. In this system, we can represent all the
transformation equations in matrix multiplication. Any Cartesian point P(X, Y) can be
converted to homogenous coordinates by P’ (Xh, Yh, h).

Translation
A translation moves an object to a different position on the screen. You can translate a
point in 2D by adding translation coordinate (tx, ty) to the original coordinate (X, Y) to
get the new coordinate (X’, Y’).

https://www.tutorialspoint.com/computer_graphics/2d_transformation.htm 1/8
Page 2 of 8

From the above figure, you can write that −

X’ = X + tx

Y’ = Y + ty

The pair (tx, ty) is called the translation vector or shift vector. The above equations can
also be represented using the column vectors.

[X] [X ] [tx ]
P = p' = ′
T=
[Y ] [Y ] [ty ]

We can write it as −

P’ = P + T

Explore our latest online courses and learn new skills at your own pace. Enroll and
become a certified expert to boost your career.

Rotation
In rotation, we rotate the object at particular angle θ (theta) from its origin. From the
following figure, we can see that the point P(X, Y) is located at angle φ from the
horizontal X coordinate with distance r from the origin.

Let us suppose you want to rotate it at the angle θ. After rotating it to a new location,
you will get a new point P’ (X’, Y’).

https://www.tutorialspoint.com/computer_graphics/2d_transformation.htm 2/8
Page 3 of 8

Using standard trigonometric the original coordinate of point P(X, Y) can be represented
as −

X = r cos ϕ. . . . . . (1)

Y = r sin ϕ. . . . . . (2)

Same way we can represent the point P’ (X’, Y’) as −


x = r cos (ϕ + θ) = r cos ϕ cos θ − r sin ϕ sin θ. . . . . . . (3)


y = r sin (ϕ + θ) = r cos ϕ sin θ + r sin ϕ cos θ. . . . . . . (4)

Substituting equation (1) & (2) in (3) & (4) respectively, we will get


x = x cos θ − y sin θ


y = x sin θ + y cos θ

Representing the above equation in matrix form,

cosθ sinθ
′ ′
[X Y ] = [XY ] [ ] OR
−sinθ cosθ

P’ = P . R

Where R is the rotation matrix

cosθ sinθ
R = [ ]
−sinθ cosθ

The rotation angle can be positive and negative.

https://www.tutorialspoint.com/computer_graphics/2d_transformation.htm 3/8
Page 4 of 8

For positive rotation angle, we can use the above rotation matrix. However, for negative
angle rotation, the matrix will change as shown below −

cos(−θ) sin(−θ)
R = [ ]
−sin(−θ) cos(−θ)

cosθ −sinθ
= [ ] (∵ cos(−θ) = cosθ and sin(−θ) = −sinθ)
sinθ cosθ

Scaling
To change the size of an object, scaling transformation is used. In the scaling process,
you either expand or compress the dimensions of the object. Scaling can be achieved by
multiplying the original coordinates of the object with the scaling factor to get the
desired result.

Let us assume that the original coordinates are (X, Y), the scaling factors are (SX, SY),
and the produced coordinates are (X’, Y’). This can be mathematically represented as
shown below −

X' = X . SX and Y' = Y . SY

The scaling factor SX, SY scales the object in X and Y direction respectively. The above
equations can also be represented in matrix form as below −


X X Sx 0
( ) = ( )[ ]

Y Y 0 Sy

OR

P’ = P . S

Where S is the scaling matrix. The scaling process is shown in the following figure.

https://www.tutorialspoint.com/computer_graphics/2d_transformation.htm 4/8
Page 5 of 8

If we provide values less than 1 to the scaling factor S, then we can reduce the size of
the object. If we provide values greater than 1, then we can increase the size of the
object.

Reflection
Reflection is the mirror image of original object. In other words, we can say that it is a
rotation operation with 180°. In reflection transformation, the size of the object does not
change.

The following figures show reflections with respect to X and Y axes, and about the origin
respectively.

https://www.tutorialspoint.com/computer_graphics/2d_transformation.htm 5/8
Page 6 of 8

Shear
A transformation that slants the shape of an object is called the shear transformation.
There are two shear transformations X-Shear and Y-Shear. One shifts X coordinates
values and other shifts Y coordinate values. However; in both the cases only one
coordinate changes its coordinates and other preserves its values. Shearing is also
termed as Skewing.

X-Shear

The X-Shear preserves the Y coordinate and changes are made to X coordinates, which
causes the vertical lines to tilt right or left as shown in below figure.

The transformation matrix for X-Shear can be represented as −

1 shx 0
⎡ ⎤
X sh = ⎢ 0 1 0⎥

⎣ ⎦
0 0 1

https://www.tutorialspoint.com/computer_graphics/2d_transformation.htm 6/8
Page 7 of 8

Y' = Y + Shy . X

X’ = X

Y-Shear
The Y-Shear preserves the X coordinates and changes the Y coordinates which causes
the horizontal lines to transform into lines which slopes up or down as shown in the
following figure.

The Y-Shear can be represented in matrix from as −

1 0 0
⎡ ⎤
Y sh ⎢ shy 1 0⎥

⎣ ⎦
0 0 1

X’ = X + Shx . Y

Y’ = Y

Composite Transformation
If a transformation of the plane T1 is followed by a second plane transformation T2, then
the result itself may be represented by a single transformation T which is the
composition of T1 and T2 taken in that order. This is written as T = T1∙T2.

Composite transformation can be achieved by concatenation of transformation matrices


to obtain a combined transformation matrix.

A combined matrix −

[T][X] = [X] [T1] [T2] [T3] [T4] …. [Tn]

https://www.tutorialspoint.com/computer_graphics/2d_transformation.htm 7/8
Page 8 of 8

Where [Ti] is any combination of

Translation

Scaling

Shearing

Rotation

Reflection

The change in the order of transformation would lead to different results, as in general
matrix multiplication is not cumulative, that is [A] . [B] ≠ [B] . [A] and the order of
multiplication. The basic purpose of composing transformations is to gain efficiency by
applying a single composed transformation to a point, rather than applying a series of
transformation, one after another.

For example, to rotate an object about an arbitrary point (Xp, Yp), we have to carry out
three steps −

Translate point (Xp, Yp) to the origin.

Rotate it about the origin.

Finally, translate the center of rotation back where it belonged.

https://www.tutorialspoint.com/computer_graphics/2d_transformation.htm 8/8

You might also like