Computer Graphics

Download as pdf or txt
Download as pdf or txt
You are on page 1of 26

1

Unit 1. Introduction
Computer graphics involves creating, processing, and displaying visual content using computers. Its
applications range from creating video games, designing user interfaces, and simulating real-world phenomena
to medical imaging, architectural visualization, and data visualization.Examples:1. Video Games,2. Film and
Animation (CGI),3. Virtual Reality (VR) and Augmented Reality (AR),4. Computer-Aided Design (CAD),5. Data
Visualization,6. Medical Imaging,7. Simulations (e.g., weather, physics),8. User Interfaces (UI) and User
Experience (UX) Design,9. Graphic Design and Illustration,10. Scientific Visualization
1.1. History of Computer Graphics
Computer graphics have a rich history spanning several decades:
1. **1950s-1960s**: The emergence of computer graphics began with simple line drawings and primitive
displays. Ivan Sutherland's "Sketchpad" in 1963 was a milestone, allowing users to interact with graphics via a
light pen|||2. **1970s**: The development of raster graphics and the first graphical user interfaces (GUIs) like
Xerox Alto laid the foundation for modern computing interfaces. Pixar was founded in 1979, marking the start
of computer animation.|||
3. **1980s**: Advancements in hardware led to the proliferation of 2D graphics and early 3D rendering
techniques. Graphics standards like OpenGL and DirectX emerged, facilitating cross-platform
development.|||4. **1990s**: The 1990s saw significant advancements in 3D graphics, with the release of
landmark games like Doom and Quake, pushing the boundaries of realism. Pixar's "Toy Story" in 1995 became
the first feature-length film entirely created with CGI.|||
5. **2000s**: Improved hardware capabilities enabled more realistic graphics in games and movies. The rise
of social media and the internet led to the popularity of web graphics and interactive media|||6. **2010s**:
Virtual reality (VR) and augmented reality (AR) gained traction, leveraging powerful graphics processing for
immersive experiences. Graphics in movies and games reached unprecedented levels of realism.|||7.
**Present**: Computer graphics continue to evolve rapidly, driven by advancements in hardware, software,
and techniques like ray tracing and machine learning. They play a crucial role in entertainment, education,
design, simulation, and various other fields.|||
1.2. Application of Computer Graphics
Computer graphics finds major applications in various fields:
1. **Entertainment**: Creating animations, special effects, and video games.|||2. **Design and
Visualization**: Architectural visualization, product design, and virtual prototyping.|||3. **Simulation and
Training**: Flight simulators, medical simulations, and military training.|||4. **Education**: Interactive
learning materials, virtual laboratories, and educational games.|||5. **Data Visualization**: Presenting
complex data in visual formats for analysis and understanding.|||6. **Computer-Aided Design (CAD)**:
Designing objects and structures in engineering and manufacturing.|||7. **Virtual Reality (VR) and
Augmented Reality (AR)**: Immersive experiences, training simulations, and interactive marketing.|||8.
**Medicine**: Medical imaging, surgical simulations, and anatomical modeling.|||9. **Film and Television**:
Visual effects, CGI (Computer-Generated Imagery), and motion graphics.|||10. **Advertising and
Marketing**: Creating visually appealing advertisements, product visualizations, and brand promotion.|||

1.3. CAD and CAM:


CAD stands for Computer-Aided Design, a technology that utilizes computer software to assist in the creation,
modification, analysis, or optimization of a design. It's widely used across various industries such as
architecture, engineering, manufacturing, and construction.
CAD software allows designers and engineers to create precise and detailed drawings or models of objects,
structures, or systems in a virtual environment. These digital representations can range from simple 2D
drawings to complex 3D models. CAD software provides tools for drafting, modeling, rendering, simulation,
and analysis, enabling designers to visualize, analyze, and iterate designs before they are physically built.
CAD has revolutionized the design process by improving accuracy, efficiency, and productivity. It enables faster
iterations, better collaboration among team members, and reduces the need for physical prototypes, saving
2

time and costs in the design and development process. Additionally, CAD models can be easily shared,
modified, and archived, making it an essential tool in modern design and engineering workflows.
CAM stands for Computer-Aided Manufacturing, which is the use of computer software to control machine
tools and automate the manufacturing process. While CAD focuses on design, CAM focuses on the production
phase, converting the digital design into instructions that machines can follow to produce physical
components or products.
CAM software takes the digital design created in CAD and generates instructions, typically in the form of
G-code, which directs the machine tools such as CNC (Computer Numerical Control) machines, lathes, milling
machines, or 3D printers. These instructions dictate the precise movements of the tools and parameters such
as cutting speeds, tool paths, and tool changes needed to manufacture the part accurately.:
Overall, CAM software plays a crucial role in modern manufacturing by streamlining the production process,
improving accuracy, reducing lead times, and enabling the production of complex components with high
precision. It complements CAD software, forming an integrated CAD/CAM workflow that spans from design to
manufacturing.

#Difference between CAD and CAM

Unit 2. Graphics Hardware


Graphics hardware, or GPUs, are specialized circuits that speed up image rendering for tasks like gaming and
video editing. They're essential for high-performance graphics and come in two types: integrated (on the
motherboard) and dedicated (separate cards). Major manufacturers include NVIDIA, AMD, and Intel. Key
considerations are core count, memory, clock speed, and API support. They've evolved significantly in
performance and efficiency, with specialized versions for AI and cryptocurrency mining.
2.1. Input Hardware
Graphics input hardware encompasses devices used to input graphical data into computers. Examples
include graphics tablets, digital pens, scanners (both 2D and 3D), and cameras. They're vital for tasks like
digital art, graphic design, and 3D modeling, enabling precise and efficient creation and manipulation of
images and graphics.
1. **Keyboard:** A keyboard is a common input device that allows users to input text, numbers, and
commands into a computer. It consists of a set of keys, each representing a specific character or function.
Keyboards can be either membrane or mechanical, with mechanical keyboards using physical switches under
each key for better tactile feedback and durability.
2. **Mouse (mechanical & optical):** A mouse is a pointing device that allows users to interact with graphical
user interfaces by moving a cursor on the screen. Mechanical mouse use a rubber ball and internal rollers to
3

track movement, while optical mice use LED or laser sensors to track movement optically. Optical mouse are
more common today due to their greater precision and reliability.
3. **Light pen:** A light pen is a handheld input device that allows users to interact with a computer screen
by pointing directly at the display. It works by detecting light emitted from the screen, typically in response to
a user pressing the pen against the screen. Light pens were popular in early computer systems but have largely
been replaced by other input devices like touchscreens.
4. **Touch panel (Optical, Sonic, and Electrical):** Touch panels are input devices that detect and respond to
touch gestures on a screen. They come in various types, including optical touch panels that use infrared light
to detect touch, sonic touch panels that use sound waves, and electrical touch panels such as capacitive or
resistive panels that rely on changes in electrical conductivity when touched.
5. **Digitizers (Electrical, Sonic, Resistive):** Digitizers are devices used to convert analog signals, such as
handwritten or drawn input, into digital format. They come in different types, including electrical digitizers
that detect changes in electrical signals, sonic digitizers that use sound waves, and resistive digitizers that
respond to pressure applied to a flexible surface.
6. **Scanner:** A scanner is a device used to convert physical images or documents into digital format. It
works by capturing an image of the document using a sensor and converting it into a digital file that can be
stored, edited, or printed. Scanners are commonly used for tasks like document scanning, photo scanning, and
OCR (optical character recognition).
7. **Joystick:** A joystick is an input device consisting of a stick or lever that can be tilted or moved in various
directions. It's commonly used in gaming and flight simulation applications to control movement or direction
within a virtual environment. Joysticks may also feature buttons or triggers for additional input commands.
2.2. Output Hardware
Graphics output hardware includes the GPU (Graphics Processing Unit), video card, display ports,
monitor/display, and cables. It's responsible for rendering and displaying visual output on monitors or
projectors.
Sure, here are some examples of graphics output hardware:
1. **GPU**: NVIDIA GeForce RTX 3080, AMD Radeon RX 6900 XT
2. **Video Card/Graphics Card**: ASUS ROG Strix GeForce GTX 1660 Ti, MSI Radeon RX 580
3. **Display Ports**: HDMI 2.1, DisplayPort 1.4
4. **Monitor/Display**: ASUS ROG Swift PG279Q (27" 1440p 144Hz IPS), Dell UltraSharp U3219Q (32" 4K IPS)
5. **Cables and Connectors**: HDMI cable, DisplayPort cable
2.2.1. Monitors :Monitors are display devices that visually present information generated by a computer or
other electronic devices. They come in various sizes, resolutions, refresh rates, and panel types (such as LCD,
LED, or OLED). Monitors connect to the computer's graphics card via cables like HDMI, DisplayPort, or VGA.
They are essential for users to view and interact with the output of their computers, including text, images,
videos, and graphical user interfaces.
A CRT (Cathode Ray Tube) monitor is a display device that uses a large, vacuum-sealed glass tube to display
images. It works by emitting electron beams from a cathode at the back of the tube, which strike
phosphor-coated pixels on the screen, causing them to glow and produce images. CRT monitors were once
ubiquitous but have largely been replaced by LCD and LED displays due to their bulkiness, high power
consumption, and limitations in image quality.monitor is a display device that uses a large, vacuum-sealed
glass tube to display images. It works by emitting electron beams from a cathode at the back of the tube,
which strike phosphor-coated pixels on the screen, causing them to glow and produce images. CRT monitors
were once ubiquitous but have largely been replaced by LCD and LED displays due to their bulkiness, high
power consumption, and limitations in image quality.examples of CRT are Monochromatic CRT Monitors ,.
Color CRT Monitors /
2.2.2. Monochromatic CRT Monitors :Monochromatic CRT (Cathode Ray Tube) monitors are display devices
that use a single color phosphor coating on the screen, typically green or amber, to produce images. They
were common in early computing and are characterized by their bulky, boxy design. Monochromatic CRT
4

monitors were primarily used for text-based applications and lacked color capabilities. They functioned by
emitting electron beams onto the phosphor-coated screen, where the beams created patterns of light to form
text and graphics. Despite their simplicity and lower cost compared to color CRT monitors, they have largely
been replaced by modern LCD and LED displays due to their better image quality, lower power consumption,
and reduced size.
2.2.3. Color CRT Monitors :Color CRT (Cathode Ray Tube) monitors are display devices that can produce
images in full color. They work by using three electron beams (red, green, and blue) to illuminate
phosphor-coated pixels on the screen, creating a wide range of colors through additive color mixing. Color CRT
monitors were widely used in the late 20th century and early 21st century for computer displays and television
sets. However, they have become largely obsolete due to advancements in flat-panel display technologies like
LCD and LED, which offer better image quality, energy efficiency, and thinner form factors.
2.2.4. Flat Panel Display Monitors :Flat-panel display monitors are a type of display device that uses flat and
thin panels to display images. Unlike CRT monitors, which use bulky cathode ray tubes, flat-panel displays use
technologies like LCD (Liquid Crystal Display), LED (Light Emitting Diode), OLED (Organic Light Emitting Diode),
or plasma to produce images.
LCD monitors: These monitors use liquid crystal technology to modulate light and create images. They are
energy-efficient, lightweight, and offer sharp image quality. LCDs are commonly used in computer monitors,
TVs, and smartphones.
LED monitors: LED monitors are a type of LCD monitor that uses LED backlighting instead of traditional
fluorescent tubes. This technology provides better energy efficiency, higher brightness, and improved contrast
compared to standard LCDs.
OLED monitors: OLED monitors use organic compounds that emit light when an electric current is applied.
They offer superior color reproduction, high contrast ratios, and faster response times compared to LCDs.
OLED displays are commonly found in high-end smartphones, TVs, and some computer monitors.
Plasma monitors: Plasma displays use small cells containing electrically charged ionized gases to produce
images. They offer excellent color accuracy, wide viewing angles, and fast response times, making them
suitable for high-performance applications like professional video editing and gaming. However, plasma
displays are less common and have largely been replaced by LED and OLED technologies.
2.3. Hardcopy Devices :Hardcopy devices are hardware peripherals that produce physical copies of digital
documents or images. These devices are commonly used to create tangible records or duplicates of electronic
data. . Some examples of hardcopy devices include:
1. **Printers**: /2. **Scanners**:/3. **Photocopiers**: /4. **Fax Machines**: /5. **Plotters**:
**2.3.1. Plotters:**Plotters are devices primarily used for producing large-scale drawings, designs, and
graphics. Unlike printers, which apply ink or toner onto paper, plotters use pens, pencils, or other drawing
instruments to create precise lines on paper or other materials. Plotters are commonly used in engineering,
architecture, and design industries for tasks such as creating blueprints, architectural drawings, maps, and
technical diagrams. They are capable of producing high-quality, detailed outputs with accuracy and precision.
**2.3.2. Printers:**:Printers are devices used to produce paper copies of digital documents or images. They
work by transferring ink or toner onto paper to create text, graphics, or images. Printers come in various types,
including inkjet printers, laser printers, and dot matrix printers, each with its own technology and capabilities.
Inkjet printers use liquid ink sprayed onto paper, making them suitable for producing high-quality color prints
and photos. Laser printers use toner powder fused onto paper using heat, offering fast printing speeds and
crisp text quality. Dot matrix printers use a grid of tiny pins to impact an ink ribbon, typically used for printing
invoices, receipts, and other multipart forms. Printers are widely used in homes, offices, and businesses for
printing documents, photos, and other materials.

2.4. Raster and Vector Display Architectures, Principles and Characteristics


Raster and vector display architectures are two different approaches used in display technology:
**Raster Display Architecture:**Raster display architecture is the most common method used in modern
5

display devices, including monitors, televisions, and most types of digital screens. In raster displays, the
screen is divided into a grid of pixels arranged in rows and columns. Each pixel represents a tiny point of light,
and the entire image is composed by illuminating and controlling the intensity of each pixel. Raster displays
render images by scanning across each row of pixels from top to bottom, and then repeating this process for
subsequent rows. This scanning happens so quickly that the human eye perceives a complete image. Most
digital images, photographs, and videos are stored and displayed in raster format, with each pixel having a
specific color value (RGB) to create the desired image.
**Vector Display Architecture:**Vector display architecture, on the other hand, uses a different approach to
render images. Instead of representing images as a grid of pixels, vector displays use mathematical formulas to
define shapes, lines, and curves. Images are described as a series of geometric primitives, such as lines, circles,
and polygons, along with instructions on how to draw and manipulate them. Vector displays are particularly
well-suited for rendering graphics that involve precise shapes, such as technical drawings, diagrams, and
schematics. Unlike raster displays, vector displays do not suffer from pixelation or loss of image quality when
scaled to different sizes, making them ideal for tasks requiring high levels of accuracy and scalability.
raster and vector display principles:
**Raster Display:**
- Uses a grid of pixels to represent images.
- Each pixel corresponds to a specific point of light on the screen.
- Images are created by illuminating and controlling the intensity of individual pixels.
- Commonly used in modern display devices like monitors and televisions.
- Well-suited for displaying digital images, photographs, and videos.
- Pixel-based approach, meaning images may lose quality when scaled up or down.
**Vector Display:**
- Utilizes mathematical formulas to define shapes, lines, and curves.
- Images are described as a series of geometric primitives.
- Particularly effective for rendering precise shapes and graphics.
- Ideal for tasks requiring scalability and accuracy, such as technical drawings and diagrams.
- Does not suffer from pixelation or loss of quality when scaled to different sizes.
- Less commonly used in modern display devices compared to raster displays.
Here are the characteristics of raster and vector displays in short:
**Raster Display Characteristics:**
1. Pixel-based images.
2. Quality depends on resolution (PPI/DPI).
3. Limited scalability; may pixelate when enlarged.
4. Variable file sizes.
5. Varying color depths.
6. Editing can be challenging.
7. Common formats: JPEG, PNG, GIF, BMP.
8. Suitable for photos and detailed graphics.
**Vector Display Characteristics:**
1. Mathematically defined shapes.
2. Resolution-independent; no loss of quality when scaled.
3. Infinitely scalable without pixelation.
4. Consistent, smaller file sizes.
5. Flexible color usage.
6. Easy to edit and modify.
7. Common formats: SVG, EPS, PDF, AI.
8. Ideal for logos, icons, and technical illustrations.
Differentiate raster and Vector display technology
6

Differentiate raster and Vector scan display technology

Unit 3. Two Dimensional Algorithms and Transformations


3.1. Mathematical Line Drawing Concept :In computer graphics, mathematical line drawing involves using
algorithms to generate lines and shapes on a digital display. It's about representing lines and shapes with
mathematical equations or algorithms rather than storing individual pixels. This includes methods like DDA and
Bresenham's Line Algorithm for drawing lines efficiently, as well as techniques like antialiasing for smoother
edges. In vector graphics, shapes are stored as mathematical formulas or paths, allowing for precise scaling
and manipulation without loss of quality.
3.2. Line Drawing Algorithms :Line drawing algorithms are fundamental techniques used in computer
graphics to generate lines on a digital display. These algorithms calculate the coordinates of pixels that
approximate the desired line between two endpoints.Here are some key algorithms:
1. **Digital Differential Analyzer (DDA)**: A basic algorithm that calculates the coordinates of each pixel
along a line by incrementing either the x or y coordinate by fixed steps based on the slope of the line.
2. **Bresenham's Line Algorithm**: More efficient than DDA, this algorithm uses integer arithmetic to
7

calculate the positions of pixels on the line with the highest accuracy, minimizing rounding errors.
3. **Midpoint Line Algorithm**: Determines the pixels closest to the true line by calculating the midpoint
between two candidate pixels. It's useful for drawing lines with integer endpoints and is efficient for raster
displays.
4. **Xiaolin Wu's Line Algorithm**: An antialiasing technique that produces smoother lines by blending colors
along the edges, reducing aliasing artifacts.
5. **Cohen-Sutherland Line Clipping**: Used to determine which portions of a line are visible and should be
drawn when lines extend beyond the display boundaries.

3.2.1. Digital Differential Analyzer (DDA) :

*The steps of the algorithm can be summarized as follows:-


• Accept the coordinates of the line's two endpoints.
• Calculate the differences in x and y coordinates between the endpoints.
• Determine the number of steps needed to draw the line, which is the
maximum of the absolute values of the x and y differences.
• Calculate the increments for x and y for each step.
• Starting from the starting point, use the increments to plot pixels at
each step along the line.

3.2.2. Bresenham’s Line Drawing Algorithm


8

3.3. Mid-point Circle Drawing :The midpoint circle algorithm is an efficient algorithm used to determine the
points needed for rasterizing a circle on a computer screen or display. It is a generalization of Bresenham's
line algorithm and can be further extended to draw other conic sections.
The key aspects of the midpoint circle algorithm are:
1. It starts at the rightmost point on the circle (x = r, y = 0) and iterates through the first octant, determining
whether to increment x or decrement y based on the position of the midpoint between the two possible
pixels. [1][3]
2. The decision parameter P is used to determine whether to choose the pixel above the current pixel (x, y+1)
or the pixel diagonally above and to the left (x-1, y+1). If P is less than 0, the pixel above is chosen, otherwise
the diagonal pixel is chosen. [3][4]
3. The algorithm takes advantage of the symmetry of a circle to efficiently compute all 8 octants from the
calculations in the first octant. This makes it a computationally efficient approach. [1][2]
4. The algorithm can be further optimized by using integer-based arithmetic instead of floating-point, which
improves performance. [1]
In summary, the midpoint circle algorithm is a clever and efficient way to rasterize circles on a computer
display by making optimal decisions about which pixels to plot based on the midpoint between potential
pixels. This makes it a widely used technique in computer graphics.
Citations:
9

3.4. Mid-point Ellipse Drawing Algorithm :The Midpoint Ellipse Drawing Algorithm is used to efficiently draw
ellipses in computer graphics. It's based on Bresenham's line algorithm and exploits symmetry properties of
ellipses to plot only a portion and then reflect and replicate the remaining parts. Here's a concise explanation:
1. **Initialization**: Given center (xc, yc), major axis radius a, and minor axis radius b, calculate initial decision
parameter based on ellipse equation at point (0, b).
2. **Plotting Points**: Begin plotting points from initial point in one quadrant, increment x-coordinate and
choose next point based on decision parameter.
3. **Decision Parameter Update**: Update decision parameter at each step based on chosen point.
4. **Symmetry**: Utilize symmetry to plot points in all four quadrants, reducing computational overhead.
5. **Stopping Criterion**: Continue plotting until x-coordinate ≥ y-coordinate.
This algorithm efficiently rasterizes ellipses using integer arithmetic, making it suitable for implementation on
systems with limited computational resources.
3.5. Review of Matrix Operations – Addition and Multiplication
Matrix operations, particularly addition and multiplication, are fundamental in computer graphics for various
transformations, such as translation, rotation, scaling, and projection. Here's a brief overview:
1. **Matrix Addition**: In computer graphics, matrix addition is typically used when combining
transformations. If you have two matrices representing transformations (such as translation, rotation, or
scaling), adding them together results in a combined transformation matrix. For example, if you have a
translation matrix and a rotation matrix, adding them together gives you a single matrix that represents both
translation and rotation.
2. **Matrix Multiplication**: Matrix multiplication is extensively used in computer graphics to apply
transformations to geometric objects. When you multiply a transformation matrix by a vector representing a
point or a set of points, you effectively apply that transformation to those points. For instance, to translate a
point, you multiply the translation matrix by the vector representing the point.
Additionally, when you have multiple transformations to apply sequentially (like translation followed by
rotation followed by scaling), you multiply the transformation matrices together to get a single matrix
representing the combined transformation. This is known as concatenating transformations.
Matrix operations in computer graphics are often performed using libraries or graphics APIs like OpenGL,
DirectX, or Vulkan. These libraries provide efficient implementations of matrix operations optimized for
graphics processing units (GPUs), making rendering and manipulation of 3D graphics more efficient.
3.6. Two-dimensional Transformations
Two-dimensional transformations in computer graphics are mathematical operations used to modify the
position, orientation, or size of objects within a two-dimensional space. These transformations involve
applying mathematical operations to the coordinates of points or vertices to achieve the desired changes.
They are essential in various applications such as object manipulation, computer-aided design (CAD), image
processing, and graphical user interfaces (GUIs).
The fundamental 2D transformations include:
1. **Translation**: Moving objects in a specific direction by adding a translation vector to the original
coordinates.
2. **Rotation**: Changing the orientation of an object around a point or axis by a certain angle. This involves
applying a rotation matrix to the coordinates.
3. **Scaling**: Resizing objects by applying scaling factors to the coordinates. This can be done uniformly or
non-uniformly along the x and y axes.
Derived transformations include:
1. **Reflection**: Creating a mirror image of an object by reflecting it across a line or axis. This is essentially a
rotation operation by 180 degrees.
2. **Shearing**: Distorting objects along an axis by applying a shearing factor to the coordinates.
10

3.6.1. Translation: Translation in computer graphics is a fundamental 2D transformation that involves


moving objects from one position to another without deformation. It is a process of modifying the position of
graphics elements within a two-dimensional plane. When translating a point or object, each position or point is
moved by the same amount in a straight line. In the context of computer graphics, translation is achieved by
adding a translation vector to the original coordinates of the object. This vector, also known as a shift vector,
consists of two components: Tx for the distance to move along the x-axis and Ty for the distance to move
along the y-axis.
The translation process can be represented mathematically by adding the translation coordinates to the old
coordinates of the object. For a point with initial coordinates (Xold, Yold), the new coordinates after
translation (Xnew, Ynew) are calculated as follows:
- Xnew = Xold + Tx (translation along the x-axis)
- Ynew = Yold + Ty (translation along the y-axis)
In matrix form, these translation equations can be represented as a 3x3 matrix, where the homogeneous
coordinates representation of (X, Y) is (X, Y, 1). This matrix allows for efficient computation of translations and
other transformations through matrix/vector multiplications.
example :Moving a square 20 units to the right and 30 units down.
- Original square vertices: (0, 0), (1, 0), (1, 1), (0, 1)
- Translated square vertices: (20, 30), (21, 30), (21, 31), (20, 31)

3.6.2. Scaling :Scaling in computer graphics is a fundamental transformation used to modify the size of objects.
It involves changing the dimensions of an object by applying scaling factors, Sx and Sy, to the x and y
coordinates, respectively. When scaling, if the factors are less than one, the object shrinks, and if greater than
one, it enlarges. Scaling can be uniform (equal factors) or differential (unequal factors). The process is about
expanding or compressing objects and is represented mathematically by multiplying the old coordinates by the
scaling factors to obtain new coordinates. Scaling is crucial for resizing objects in graphics and is a key
component in creating various visual effects and transformations
examples: Scaling a circle by a factor of 2 in both dimensions.
- Original circle equation: x^2 + y^2 = 1
11

- Scaled circle equation: (x/2)^2 + (y/2)^2 = 1


3.6.3. Rotation :Rotation in 2D transformation in computer graphics involves changing the angle of an object
either clockwise or anticlockwise around a specified pivot point. This process allows for the rotation of
objects to view them from different perspectives. In this transformation, every point of the object is rotated by
the same angle, enabling the object to be repositioned in a circular manner. The rotation is typically defined by
specifying the angle of rotation and the rotation point, also known as the pivot point.
To perform a rotation in computer graphics, a rotation matrix is utilized. This matrix includes trigonometric
functions like sine and cosine to calculate the new coordinates of the rotated object. By applying these
mathematical operations, the object can be accurately rotated to the desired angle. Additionally, various
figures such as points, lines, and polygons can undergo rotation transformations to achieve different
orientations and perspectives within the graphical space.
example: Rotating a triangle 45 degrees clockwise around the origin.
- Original triangle vertices: (0, 0), (1, 0), (0.5, 1)
- Rotated triangle vertices: (0, 0), (0.707, -0.707), (1.414, 0.707)
3.6.4. Reflection :Reflection in computer graphics is a transformation that produces a mirror image of an
object. It involves creating a mirrored version of the original object, which can be about the x-axis, y-axis, or
the origin. In reflection, the object is rotated by 180 degrees, essentially creating a mirror image of the original
object. This transformation is crucial in computer graphics for creating symmetrical and visually appealing
designs. The reflected object maintains the same size as the original object, with only its orientation changing
to create the mirror image effect.
example: Reflecting a line across the x-axis.
- Original line equation: y = 2x + 1
- Reflected line equation: y = -2x - 1
3.6.5. Shearing :Shearing in computer graphics is a transformation that distorts the shape of an object by
sliding its layers in one or more directions. In 2D, shearing can occur in the x-direction, y-direction, or both,
leading to a deformation of the object. When shearing is applied in both directions in 2D, the object becomes
distorted. In 3D graphics, shearing can occur in three directions: x, y, and z. This transformation changes the
shape of the object, causing deformation or distortion depending on the direction of shearing.
example:Shearing a rectangle horizontally.
- Original rectangle vertices: (0, 0), (2, 0), (2, 1), (0, 1)
- Sheared rectangle vertices: (0, 0), (2, 0), (3, 1), (1, 1)
43.7. Two-Dimensional Viewing Pipeline :The Two-Dimensional (2D) Viewing Pipeline in computer graphics is
a sequence of steps used to transform 2D objects from their world coordinates to screen coordinates for
display. This pipeline is fundamental to rendering 2D graphics on computer screens, forming the basis for
graphical user interfaces, digital art, and various other applications.Here's a concise overview:
1. **Modeling Transformations**: These transformations involve scaling, rotation, and translation of objects
in a 2D scene.
2. **Viewing Transformations**: This step involves transforming the scene to a standard viewing position,
typically involving transformations like scaling, rotation, and translation to position the objects within the
viewing window.
3. **Clipping**: Clipping removes any objects or parts of objects that lie outside the viewing window or
viewport.
4. **Projection**: In 2D graphics, projection typically involves transforming the 3D coordinates of objects onto
a 2D plane, effectively collapsing the scene onto a flat surface.
5. **Scan Conversion**: This converts the geometric primitives (lines, polygons, etc.) into pixels for display on
the screen. Techniques like scanline algorithms are often used.
6. **Visible Surface Determination**: This step determines which surfaces or parts of surfaces are visible and
need to be rendered. Techniques like depth-buffering or z-buffering are commonly employed.
7. **Rendering**: Finally, the visible primitives are rendered onto the screen using algorithms like
12

rasterization, which colors in the pixels corresponding to the geometric primitives..


After these stages, the 2D objects are ready to be rendered on the screen. Each stage of the pipeline
contributes to transforming the objects from their original coordinates to coordinates that are suitable for
display on a 2D surface.
Unit 4. Three-Dimensional Graphics
Three-dimensional (3D) graphics involve creating, transforming, and rendering objects in a three-dimensional
space for display on a two-dimensional screen. Key steps include modeling objects, applying transformations,
projecting them onto a 2D plane, rendering with shading and lighting effects, and handling visibility and
animation.
4.1. Three-dimensions transformations
4.1.1. Translation :Translation in the context of computer graphics refers to the process of moving an object
from one position to another within a three-dimensional space. It involves shifting all points of the object by a
certain distance along each of the three axes: x, y, and z.
In mathematical terms, translation is represented by adding a constant displacement vector to each point of
the object. For example, if you want to translate an object by (dx, dy, dz) units, where dx represents the
distance to move along the x-axis, dy along the y-axis, and dz along the z-axis, you would add (dx, dy, dz) to
the coordinates of each point.
4.1.2. Scaling Scaling in computer graphics involves resizing an object along one or more axes within a
three-dimensional space. It adjusts the size of the object uniformly or non-uniformly in each direction.
There are two types of scaling:
1. **Uniform Scaling**: This type of scaling maintains the object's proportions, enlarging or shrinking it equally
in all dimensions. For example, if you uniformly scale a cube by a factor of 2, all sides of the cube will double in
length.
2. **Non-uniform Scaling**: This type of scaling changes the size of the object differently along each axis,
allowing for stretching or compressing in various directions independently. For instance, stretching a cylinder
along the x-axis without affecting its dimensions along the y and z axes.
Mathematically, scaling is represented by multiplying each coordinate of the object's vertices by a scaling
factor. For example, to scale an object by (sx, sy, sz) units along the x, y, and z axes respectively, you would
multiply each coordinate by (sx, sy, sz).
4.1.3. Rotation :Rotation in computer graphics involves rotating an object around an axis within a
three-dimensional space. It changes the orientation of the object, allowing it to face different directions or
spin around a specific axis.
There are different types of rotations:
1. **Rotation about the x-axis**: This rotates the object around the x-axis passing through the origin.
2. **Rotation about the y-axis**: This rotates the object around the y-axis passing through the origin.
3. **Rotation about the z-axis**: This rotates the object around the z-axis passing through the origin.
4. **Arbitrary axis rotation**: This rotates the object around an arbitrary axis in 3D space. It involves more
complex mathematical calculations compared to rotations around the principal axes.
Mathematically, rotations are typically represented using rotation matrices or quaternion rotations. These
transformations apply trigonometric functions to calculate the new coordinates of each point after rotation.
Here's a simple example of rotating a point (x, y, z) around the z-axis by an angle θ:
New x = x * cos(θ) - y * sin(θ)
New y = x * sin(θ) + y * cos(θ)
New z = z

4.1.4. Reflection :Reflection in computer graphics involves flipping or mirroring an object across a plane or
axis. It changes the orientation of the object by reversing its position relative to the reflection plane.A
common example is reflection across the xy-plane. In this case, each point (x, y, z) in the object is reflected
to (x, y, -z). This effectively flips the object upside-down.
13

For instance, consider reflecting a point (2, 3, 4) across the xy-plane:


Original point: (2, 3, 4)
Reflected point: (2, 3, -4)
Reflection is used to create symmetrical objects or achieve specific visual effects in computer graphics, such as
creating reflections in water or mirrors.
4.1.5. Shearing :Shearing in computer graphics involves distorting or skewing an object along one or more axes
within a three-dimensional space. It displaces points in a specified direction proportional to their distance from
a reference plane or axis.Shearing is commonly used in computer graphics for various purposes, such as
creating perspective effects, aligning objects, or deforming shapes in animations.
There are different types of shearing:
1. **Parallel Shearing**: This type of shearing moves points along parallel lines, resulting in a uniform
displacement of points in one direction while keeping their relative positions unchanged in other directions.
2. **Non-parallel Shearing**: This type of shearing moves points along non-parallel lines, causing a
differential displacement of points in different directions.
Mathematically, shearing is represented by applying linear transformations to the coordinates of the object's
vertices. These transformations introduce additional terms to the coordinates, causing the distortion or
skewing effect.
For example, shearing a point (x, y, z) along the x-axis by a shear factor "s" results in the new coordinates:
New x = x + s * y
New y = y
New z = z
Similarly, shearing can be applied along the y-axis or z-axis by modifying the appropriate coordinates.
4.2. Three-dimensional Viewing Pipeline :The Three-Dimensional (3D) Viewing Pipeline in computer graphics
is a sequence of steps used to transform 3D objects from their world coordinates to screen coordinates for
display. Here's a concise overview:
1. **Modeling**: Creating or importing 3D models of objects in a virtual scene.
2. **Transformation**: Applying transformations like translation, rotation, and scaling to position and orient
objects within the scene.
3. **Viewing Transformation**: Moving the objects to a standardized viewpoint or camera position, typically
using techniques like world-to-camera transformation.
4. **Projection**: Converting the 3D coordinates of objects into 2D coordinates for rendering on a 2D screen,
usually through perspective projection or orthographic projection.
5. **Clipping**: Removing any parts of objects that lie outside the view frustum or viewing volume to
optimize rendering performance.
6. **Hidden Surface Removal**: Determining which surfaces or parts of surfaces are visible and need to be
rendered, typically using techniques like depth buffering or z-buffering.
7. **Rendering**: Determining the color, shading, and texture of pixels on the screen based on the geometry,
lighting, and materials of the objects. Techniques such as rasterization or ray tracing are commonly used.
This pipeline transforms 3D models into 2D images for display, enabling the creation of immersive and realistic
computer graphics environments.
4.3. Three-dimensions Projections :Three-dimensional projections are techniques used to represent 3D
objects or scenes on a 2D surface, such as a computer screen. There are two primary types of 3D projections:
1. **Perspective Projection**: This type of projection mimics how objects appear in the real world by
simulating the way parallel lines converge towards a vanishing point. In perspective projection, objects that
are farther away appear smaller, and the distance between objects seems to decrease with distance. It's
commonly used in applications like 3D rendering and computer graphics to create realistic scenes.
2. **Orthographic Projection**: In contrast to perspective projection, orthographic projection preserves the
relative sizes of objects regardless of their distance from the viewer. It projects parallel lines from the 3D scene
onto the 2D plane without converging towards a vanishing point. Orthographic projection is often used in
14

technical drawings, engineering, and architectural design to represent objects accurately without distortion.
These projection techniques play a crucial role in converting 3D models or scenes into 2D representations for
display or further processing in various applications, including computer graphics, visualization, and design.
Projection :projection refers to the process of converting three-dimensional (3D) coordinates of objects or
scenes into two-dimensional (2D) coordinates for display on a screen or rendering in an image. 4.3.
Three-dimensions Projections and projections are same.
4.3.2. Projection of 3D Objects onto 2D Display Devices :The projection of 3D objects onto 2D display devices
involves transforming the coordinates of the objects from three-dimensional space to two-dimensional space
for rendering on a screen
The projection of 3D objects onto 2D display devices involves transforming the objects' 3D coordinates to 2D
coordinates for screen rendering. This process includes positioning the objects, projecting them onto the
screen using perspective or orthographic projection, clipping any out-of-view parts, and finally rendering them
on the screen with appropriate colors and textures.
This process transforms the 3D models or scenes into 2D representations suitable for display on screens or
rendering in images, enabling the creation of immersive virtual environments, realistic simulations, and
accurate technical illustrations.

fig : basic render 3D perspective projection onto 2D screen with camera (without opengl).

4.3.3. Three-dimensional Projection Methods


Three-dimensional projection methods are techniques used to represent three-dimensional objects on a
two-dimensional surface, such as a computer screen or a piece of paper. These methods are essential in
fields like computer graphics, architecture, engineering, and art. There are several types of 3D projection
methods, including:
1. **Orthographic Projection**: This method involves projecting the 3D object onto a 2D plane without
considering the perspective. It preserves the relative sizes of objects but doesn't show depth.
2. **Perspective Projection**: In perspective projection, objects appear smaller as they move away from the
viewer, mimicking how we perceive depth in the real world. This method is often used in realistic rendering
and computer graphics.
3. **Axonometric Projection**: Axonometric projection maintains the proportions of the object's sides and
angles while showing all three dimensions. Common types include isometric, dimetric, and trimetric
projections.
4. **Oblique Projection**: Oblique projection combines orthographic and perspective projections, allowing
for a mix of realistic depth and clear object dimensions.

4.3.3.1. Parallel Projection Method


- Parallel projection is a type of projection where all lines remain parallel after projection.
- In this method, objects are projected onto a plane without converging towards a vanishing point.
- There are different types of parallel projections, including orthographic projection and oblique projection.
- Orthographic parallel projection is commonly used in technical drawing and engineering design, where
accurate representation of object dimensions is crucial.
15

- Oblique parallel projection involves projecting the object onto the plane at an angle, often used in
architectural drawings and illustrations.
4.3.3.2. **Perspective Projection Method**:
- Perspective projection is a type of projection that simulates the way objects appear to the human eye in
the real world, where objects appear smaller as they move away from the viewer.
- In perspective projection, lines that are parallel in 3D space converge to a vanishing point on the
projection plane.
- This method is widely used in computer graphics, video games, architectural visualization, and artistic
rendering to create realistic scenes.
- Perspective projection provides a sense of depth and realism, making it suitable for applications where
visual accuracy and immersion are important.
difference between parallel and perspective projection

4.4. Three-dimensional Object Representations :Three-dimensional object representations are ways to


depict objects with width, height, and depth in a two-dimensional space. Here's a concise overview of
common methods:
1. **Wireframe Model**: Basic outlines of object edges.
2. **Surface Rendering**: Adds color, texture, and shading for realism.
3. **Polygon Mesh**: Uses polygons to approximate surfaces.
4. **Voxel Grid**: Divides space into volumetric elements.
5. **Point Cloud**: Collection of points in 3D space.
6. **Implicit Surfaces**: Defined by mathematical functions.
Each method has specific applications in fields like computer graphics, engineering, and medical imaging.
16

Certainly! Here's a brief explanation of Polygon Surfaces and Polygon Tables in computer graphics:

4.4.1. **Polygon Surfaces**:


Polygon surfaces are a fundamental concept in computer graphics used to represent 3D objects. A polygon
surface is formed by connecting vertices (points in 3D space) with straight lines to create flat shapes like
triangles, quadrilaterals (quads), or polygons with more sides. These flat shapes are called faces, and they
collectively form the surface of the 3D object.
Polygon surfaces are widely used because they are relatively simple to render and manipulate
computationally. They are commonly employed in rendering engines for video games, animation software,
architectural visualization, and more.

4.4.2. **Polygon Tables**:


Polygon tables are data structures used to store information about polygonal objects in computer graphics. A
polygon table typically contains data such as the vertices of each polygon, the edges connecting these vertices,
and other attributes like surface normals, texture coordinates, and material properties.
The polygon table helps organize and manage the geometry of polygonal objects, making it easier for
rendering algorithms to process and display them on screen. By storing essential information about each
polygon, including its connectivity to other polygons and its geometric properties, polygon tables enable
efficient rendering and manipulation of complex 3D scenes.

4.5. Introduction to Hidden Line and Hidden Surface Removal Techniques:


Hidden line and hidden surface removal techniques are essential processes in computer graphics for improving
the realism of rendered images. These techniques ensure that only visible portions of objects are displayed,
reducing clutter and improving the overall quality of the scene. **Hidden Line Removal:** In hidden line
removal, lines that are obstructed or hidden by other objects in a scene are identified and not drawn. This
enhances the clarity of the scene by removing unnecessary clutter and improving visibility.examples :Painter's
Algorithm,Z-Buffering (Depth Buffering):
**Hidden Surface Removal:** Hidden surface removal focuses on determining which surfaces of
three-dimensional objects are visible to the viewer and which are obscured by other surfaces. This is crucial for
creating realistic images, as it ensures that only the visible surfaces are rendered, leading to accurate
representations of the scene.examples :Back-Face Culling,Bounding Volume Hierarchies:
Let's delve into the two main methods:
1. **Object Space Method**: In this approach, computations are performed in the object space, which means
they're carried out based on the properties of the objects themselves. The algorithm involves analyzing the
geometric properties of objects to determine which lines or surfaces are hidden from the viewer's perspective.
This method requires transforming objects into a common coordinate system and checking for occlusions.
2. **Image Space Method**: Contrastingly, in the image space method, computations are done in the image
or screen space. This means that visibility is determined by examining the pixels of the final image rather than
the geometric properties of objects. Techniques like depth buffering or z-buffering are commonly used to
achieve hidden surface removal in this method. It involves maintaining a depth buffer for each pixel and
updating it as objects are rendered onto the screen. This allows for efficient removal of hidden surfaces during
the rendering process.
These methods play a crucial role in optimizing rendering performance and ensuring that only the visible
portions of objects are displayed, contributing to the creation of visually appealing and realistic graphics.
4.6. Introduction to Illumination/ Lighting Models
**Illumination**: refers to the overall process of how light interacts with objects and surfaces in a virtual
environment.
Illumination Model: Refers to a specific mathematical model or algorithm used to simulate various aspects of
illumination. These models break down the complex interactions of light into manageable components such as
17

ambient, diffuse, specular, and emissive lighting, among others. Illumination models define how each of these
components contributes to the final appearance of a surface or object in the rendered image.
Examples of illumination models include:
1. **Phong Model**: Combines ambient, diffuse, and specular reflection for pixel color calculation. It's simple
and widely used for visually pleasing results.
2. **Blinn-Phong Model**: Similar to Phong but with a modified specular calculation for softer highlights.
3. **Cook-Torrance Model**: Physically accurate, considers microfacet theory for rough surfaces like metals
and plastics.
4. **Ward's Model**: Considers specular and diffuse reflection, useful for materials with varying glossiness.
5. **Lambertian Model**: Assumes ideal diffuse reflection, scattering light equally in all directions. Common
for matte surfaces.
6. **Oren-Nayar Model**: Extends Lambertian model for rough surfaces with uneven textures.
**Lighting models, are mathematical models or algorithms used to simulate various aspects of illumination.
These models break down the complex interactions of light into manageable components such as ambient,
diffuse, specular, and emissive lighting, among others. Lighting models define how each of these components
contributes to the final appearance of a surface or object in the rendered image. some examples are :
1. **Phong Lighting Model**: Incorporates ambient, diffuse, and specular components to calculate pixel
colors, offering simplicity and visually pleasing results.
2. **Blinn-Phong Lighting Model**: Similar to Phong but adjusts specular calculation for softer, more realistic
highlights.
3. **Cook-Torrance Lighting Model**: Physically-based model considering microfacet theory, ideal for
rendering materials like metals and plastics.
4. **Ward's Reflectance Model**: Considers specular and diffuse reflection along with surface roughness,
suitable for materials with varying levels of glossiness.
5. **Lambertian Reflectance Model**: Assumes perfect diffuse reflection, scattering light uniformly in all
directions, commonly used for matte surfaces.
6. **Oren-Nayar Reflectance Model**: Extends Lambertian model to account for rough surface reflections,
useful for simulating surfaces with uneven textures.
1. **Ambient Model**: This falls under the broader concept of lighting models. The ambient model simulates
the overall ambient light in a scene, which is uniform and doesn't depend on the position or orientation of
objects. It contributes to the basic illumination of all surfaces, even those not directly lit by other light sources.

2. **Diffuse Model**: This also falls under lighting models. The diffuse model simulates how light scatters off
surfaces equally in all directions. It determines the base color and brightness of objects based on the angle
between the incoming light and the surface normal.

3. **Specular Model**: Like the other two, the specular model falls under lighting models. It simulates the
reflective highlights that appear on smooth surfaces, producing glossy or metallic effects. Specular reflection is
more concentrated than diffuse reflection and occurs at specific angles relative to the light source and the
viewer's position.
4.7. Introduction to Shading/ Surface Rendering Models
Shading is a fundamental concept in computer graphics that involves determining the color and brightness of
pixels in a rendered image based on how light interacts with surfaces.
Shading models in computer graphics are algorithms used to determine the color of pixels in a rendered image
based on lighting conditions and surface properties. They can be broadly categorized into two types:
1. **Local Shading Models**: These models determine the color of each pixel based solely on its local
properties, such as its position, orientation, and material properties. Examples include:
- **Flat Shading**: Assigns a single color to each polygon, ignoring lighting variations within the surface.
Constant Shading Model:In the Constant Shading Model, each polygon in the scene is rendered with a single
18

color across its entire surface.


- **Gouraud Shading**: Interpolates vertex colors across polygons to create smoother shading transitions.
- **Phong Shading**: Interpolates normals across polygons to calculate shading at each pixel, providing
smoother and more realistic shading than Gouraud.
2. **Global Shading Models**: These models consider the interaction of light with surfaces across the entire
scene, accounting for effects like shadows, reflections, and refractions. Examples include:
- **Ray Tracing**: Simulates the path of light rays through the scene, accounting for reflections,
refractions, and shadows to produce highly realistic images.
- **Radiosity**: Computes the distribution of light energy across surfaces based on their reflective
properties and interreflection between surfaces, resulting in soft, diffuse lighting effects.
- **Global Illumination**: General term for techniques that simulate indirect lighting in a scene, such as
color bleeding, ambient occlusion, and soft shadows, to enhance realism.
1. **Constant Shading Model (Flat Shading)**:
- In the Constant Shading Model, each polygon in a 3D scene is rendered with a single color, regardless of
its orientation or lighting conditions.
- This means that all pixels within the same polygon are assigned the same color.
- The color usually comes from the polygon's material properties or is assigned uniformly across the
surface.
- Constant shading is computationally efficient but often results in visual artifacts like polygonal edges and
unrealistic shading transitions, especially on curved surfaces.

2. **Gouraud Shading Model**:


- Gouraud shading improves upon constant shading by calculating colors at the vertices of polygons and
then interpolating these colors across the polygon's surface.
- The model calculates vertex normals and colors for each vertex of the polygon.
- It then uses techniques like barycentric interpolation to interpolate these colors across the polygon's
surface.
- Gouraud shading provides smoother shading transitions compared to constant shading but may still
result in noticeable shading artifacts, especially on curved surfaces.
3. **Phong Shading Model**:
- Phong shading enhances shading accuracy by computing lighting calculations at each pixel instead of just
at the vertices.
- The model interpolates normals across the polygon's surface and computes lighting calculations at each
pixel using these interpolated normals.
- This results in more accurate shading and smoother highlights compared to Gouraud shading.
- Phong shading is computationally more intensive compared to Gouraud shading due to the per-pixel
lighting calculations, but it produces more realistic-looking surfaces.
4.7Surface Rendering Models :Surface rendering models refer to the algorithms and techniques used to
depict the surfaces of objects in computer graphics. These models determine how surfaces are represented
and shaded to create realistic or stylized visualizations. Here are some common surface rendering models:
- **Wireframe Rendering**: Displays only object outlines, useful for visualizing complex structures.
- **Polygonal Rendering**: Uses polygons to represent surfaces, common in real-time graphics.
- **Bezier and B-Spline Rendering**: Represents smooth surfaces with precise control.
- **Implicit Surface Rendering**: Defines surfaces with mathematical equations, often in scientific
visualization.
- **Ray Tracing**: Simulates light interactions for highly realistic images.
- **Radiosity Rendering**: Simulates indirect lighting for soft, diffuse effects, common in architectural
visualization.
- **Texture Mapping**: Applies 2D images to surfaces for enhanced detail.
19

- **Procedural Rendering**: Generates surfaces algorithmically for diverse shapes with low memory usage.
Unit 5. Web Graphics Designs and Graphics Design Packages
Web graphic design is the art of creating visual elements for websites to enhance their appearance and
functionality.Web graphics design encompasses creating visual elements for websites. This includes designing
logos, icons, buttons, backgrounds, banners, and other graphical elements that enhance the aesthetic appeal
and user experience of a website. It involves a combination of artistic skills, understanding of design principles,
and proficiency in graphic design software tools to create visually appealing and functional designs that
effectively communicate the intended message or brand identity.
Graphics design packages typically refer to software programs or suites used for creating visual content,
such as logos, illustrations, posters, and digital artwork. Some popular graphics design packages include
Adobe Creative Cloud (which includes software like Photoshop, Illustrator, and InDesign), CorelDRAW Graphics
Suite, Affinity Designer, and Sketch. These packages provide a variety of tools and features for designing and
editing graphics, catering to different needs and preferences of designers.
5.1. Introduction to graphics file formats :Graphics file formats are standardized methods for storing and
transmitting digital images. Each format has its own unique characteristics, advantages, and limitations. Here
are explanations of some common graphics file formats:
JPEG: Widely used for compressing photos online, sacrificing some quality for smaller sizes.
PNG: Ideal for web graphics with transparency, maintaining quality without compression.
GIF: Supports animations and transparency, limited colors, suitable for small graphics.
TIFF: Professional format for high-quality images, supports layers and transparency.
BMP: Simple, uncompressed format for Windows, can result in large file sizes.
SVG: XML-based format for scalable web graphics, resolution-independent.
EPS: Vector format for print design, resizable without quality loss, supports both vector and raster elements.
5.2. Principles of web graphics design – browser safe colors, size, resolution, background, anti-aliasing :
Browser Safe Colors: Palette ensuring consistent display across browsers & OS. Crucial for avoiding color
distortion.
Size: Dimensions of web graphics. Optimize for fast loading, employing compression & resizing techniques.
Resolution: Image detail level, typically 72 PPI for web. Higher resolutions increase file size without enhancing
quality.
Background: Visual backdrop of a webpage. Choose carefully for readability & visual appeal, avoiding
distractions.
Anti-aliasing: Technique to smooth jagged edges of images/text, enhancing visual quality, especially at lower
resolutions.
Contrast: Emphasize important elements with visual differences like color or size.
Consistency: Maintain uniformity in design elements for a predictable user experience.
Accessibility: Ensure all users can access and interact with content, including those with disabilities.
Responsive Design: Graphics should adapt to various devices and screen sizes for a consistent user experience.
Loading Speed: Optimize graphics for fast loading by minimizing file sizes and utilizing caching.
Mobile Optimization: Adapt graphics for mobile devices, including touch-friendly design and fast loading
times.
5.3. Type, purposes and features of graphics packages :
Types:
1. **Raster Graphics Software**: Primarily for editing pixel-based images. Examples include Adobe
Photoshop, GIMP, and Corel PaintShop Pro..//2. **Vector Graphics Software**: Focuses on creating and
editing scalable vector graphics. Adobe Illustrator and CorelDRAW fall into this category..//3. **3D Graphics
Software**: Used for creating three-dimensional models and animations. Popular options include Autodesk
Maya, Blender, and Cinema 4D..//4. **Page Layout Software**: Designed for arranging text and images for
print or digital publication. Adobe InDesign and QuarkXPress are prominent examples..//
Purposes:
20

1. **Image Editing**: Allows users to manipulate and enhance photos and other raster images..//2.
**Illustration**: Enables the creation of vector-based illustrations, logos, icons, and graphics..//3.
**Animation**: Used for creating animated graphics, ranging from simple GIFs to complex 3D animations..//4.
**Layout and Design**: Facilitates the arrangement of text, images, and other elements for print or digital
publication..//5. **3D Modeling and Rendering**: Allows users to create, texture, and render
three-dimensional models and scenes..//6. **Digital Painting**: Graphics software tailored for digital
painting, simulating traditional painting techniques with brushes, textures, and blending tools. Examples
include Corel Painter and Adobe Fresco..//7. **Photo Manipulation**: Specifically designed for advanced
photo editing and manipulation, offering tools for retouching, compositing, and photo restoration. Adobe
Photoshop is the most prominent example..//8. **Prototyping and Wireframing**: Graphics packages used
for creating wireframes and prototypes of websites and mobile apps. These tools often include pre-built UI
components and interactive features for rapid prototyping. Adobe XD and Sketch are popular choices for this
purpose..//9. **Scientific Visualization**: Graphics software specialized in visualizing scientific data and
simulations, such as graphs, charts, and 3D models. Examples include MATLAB, OriginPro, and ParaView..//10.
**Graphic Design for Print**: Dedicated software for designing print materials like brochures, flyers, posters,
and business cards. These tools often include features for color management, prepress checks, and print
output optimization. Adobe InDesign and QuarkXPress are widely used in this domain.
Features:
1. **Layer Support**: Enables users to work with multiple layers, allowing for non-destructive editing and
complex compositions..//2. **Selection Tools**: Tools for selecting and manipulating specific parts of an
image or graphic..//3. **Drawing Tools**: Brushes, pens, shapes, and other tools for creating or editing
graphics..//4. **Filters and Effects**: Pre-defined effects and filters for applying various visual enhancements
to images and graphics..//5. **Color Management**: Tools for adjusting colors, managing color profiles, and
ensuring color accuracy..//6. **Export Options**: Various options for exporting graphics in different file
formats and resolutions..//7. **Integration**: Some packages integrate seamlessly with other software suites
or offer plugins for extended functionality..//8. **Typography Tools**: Tools for working with text, including
font selection, text effects, and layout adjustments..//9. **Masking Tools**: Tools for creating masks to hide
or reveal portions of an image or graphic..//10. **Clipping Paths**: Allows users to create complex shapes or
outlines to clip parts of an image or graphic..//

5.4. Examples of graphics packages :


1. **Adobe Creative Cloud**: A comprehensive suite of software including Photoshop (for raster image
editing), Illustrator (for vector graphics), InDesign (for page layout), and more..//2. **CorelDRAW Graphics
Suite**: A powerful suite for vector illustration, layout, photo editing, and design..//3. **Affinity Designer**:
A professional vector graphics editor with advanced features for illustrations, UI/UX design, and more..//4.
**GIMP (GNU Image Manipulation Program)**: A free and open-source raster graphics editor offering
powerful tools for photo retouching, image composition, and graphic design..//5. **Sketch**: A vector
graphics editor for macOS commonly used for UI/UX design, prototyping, and web graphics..//6. **Blender**:
A free and open-source 3D creation suite for modeling, rigging, animation, simulation, rendering, compositing,
and motion tracking..//7. **Autodesk Maya**: A powerful 3D computer graphics software used for modeling,
simulation, animation, and rendering..//8. **Adobe XD**: A vector-based design tool for UI/UX design,
prototyping, and collaboration, part of the Adobe Creative Cloud..//9. **Inkscape**: An open-source vector
graphics editor similar to Adobe Illustrator, offering a wide range of drawing tools and features..//10.
**Procreate**: A digital painting app for iPad known for its intuitive interface, extensive brush library, and
powerful features for illustration and painting..//
5.4. Examples of graphics package libraries :Graphics package libraries offer pre-built components and
resources to streamline design workflows. Here are some examples:
1. **Fonts**: Google Fonts, Adobe Fonts.//2. **Icons**: Font Awesome, Material Icons.//3. **Images**:
Shutterstock, Adobe Stock, Unsplash.//4. **UI Components**: Bootstrap, Material Design Components,
21

Semantic UI.//5. **Vector Graphics**: Freepik, Vecteezy.//6. **Mockups and Wireframes**: Envato
Elements, Adobe XD Wireframe Kits, Sketch Wireframe Kits.//
These libraries provide designers with ready-to-use assets, saving time and effort in the design process.
Unit 6. Virtual Reality
6.1. Introduction ::Virtual Reality (VR) is a computer-generated simulation of an immersive 3D environment
that users can interact with in a realistic way, typically through specialized headsets or devices. VR
technology aims to provide users with a sense of presence and immersion, allowing them to explore and
interact with virtual environments as if they were physically present.
Examples of Virtual Reality systems and platforms include:
1. **Oculus Rift**: High-quality VR headset offering immersive experiences with a wide range of games and
applications..//2. **HTC Vive**: Known for room-scale tracking and precise motion controllers, offering
diverse VR experiences..//3. **PlayStation VR (PSVR)**: Designed for PlayStation consoles, providing a wide
range of VR games tailored for console gamers..//4. **Samsung Gear VR**: Mobile VR headset using
compatible Samsung smartphones, offering portable VR experiences and access to VR apps..//5. **Google
Cardboard**: Affordable VR platform using a cardboard viewer and smartphone, providing basic VR
experiences and access to VR apps..//6. **HTC Vive Cosmos**: Upgraded version with improved resolution,
comfort, and tracking capabilities, offering premium VR experiences..//7. **Oculus Quest**: Standalone
wireless VR headset providing untethered freedom of movement and access to a growing library of VR games
and experiences.

Here's a brief explanation of each type of Virtual Reality:


6.2.1. **Non-immersive Virtual Reality**: Provides a basic level of VR experience without full immersion.
Users typically interact with VR content through screens or monitors rather than specialized headsets.
Non-immersive VR is commonly used for simulations, training programs, and educational purposes.
6.2.2. **Semi-immersive Virtual Reality**: Offers a more immersive experience than non-immersive VR but
falls short of complete immersion. Users may use headsets or displays to interact with virtual environments,
but the level of immersion is limited compared to fully immersive VR. Semi-immersive VR is often used for
research, visualization, and certain training applications.
6.2.3. **Fully-immersive Virtual Reality**: Provides the highest level of immersion, where users are fully
immersed in virtual environments using specialized headsets and sensory devices. Fully immersive VR offers a
realistic sense of presence and allows users to interact with virtual objects and environments in a natural way.
It is widely used for gaming, entertainment, simulation, and training purposes.
6.2.4. **Augmented Virtual Reality**: Blends virtual elements with the real world, overlaying digital
information onto the user's physical environment. Users typically view augmented reality through
smartphones, tablets, or wearable devices like smart glasses. Augmented VR enhances real-world experiences
with additional digital content, such as information overlays, navigation aids, or interactive visuals.
6.2.5. **Collaborative Virtual Reality**: Involves multiple users interacting with each other in a shared virtual
environment, regardless of their physical locations. Collaborative VR allows users to collaborate, communicate,
and work together on tasks or projects in a virtual space. It is used for remote collaboration, team meetings,
training simulations, and virtual events.
Here are some applications of Virtual Reality:
1. **Gaming**: VR gaming provides immersive experiences, allowing players to interact with virtual
environments and objects in realistic ways..//2. **Education**: VR is used for immersive learning experiences,
providing simulations, virtual field trips, and interactive educational content..//3. **Training and
Simulation**: VR is utilized for training simulations in various industries, including aviation, healthcare,
military, and manufacturing, offering safe and realistic environments for practice and skill development..//4.
**Healthcare**: VR is used for medical training, patient therapy, pain management, surgical simulations, and
exposure therapy for phobias and PTSD..//5. **Architecture and Design**: VR allows architects and designers
to visualize and interact with virtual models of buildings, interior spaces, and products before they are built,
22

facilitating design decisions and client presentations..//6. **Tourism and Virtual Travel**: VR offers virtual
tours of destinations, museums, landmarks, and historical sites, allowing users to explore and experience
places from anywhere in the world..//7. **Entertainment and Media**: VR is used for immersive storytelling,
virtual concerts, live events, 360-degree videos, and interactive experiences in film, music, and theater..//8.
**Corporate Training and Collaboration**: VR is employed for corporate training programs, team-building
exercises, virtual meetings, and remote collaboration, enabling employees to work together in virtual
environments regardless of their physical locations.
9. **Retail and Marketing**: VR is used for virtual shopping experiences, product demonstrations, and
marketing campaigns, allowing customers to explore and interact with products in immersive virtual
environments..//
10. **Therapy and Rehabilitation**: VR is used in physical therapy, occupational therapy, and cognitive
rehabilitation to provide immersive and interactive exercises for patients recovering from injuries or managing
disabilities.

old questions
5. What is animation . explain about animation sequences..
Animation is the process of creating the illusion of motion and change by displaying a sequence of images or
frames in rapid succession. Animation can be achieved through various techniques, including traditional
hand-drawn animation, computer-generated imagery (CGI), stop-motion animation, and more.
Animation sequences refer to the series of frames or images that are arranged and played in a specific order
to create an animated scene or sequence. Each frame typically represents a slight variation in the position,
appearance, or state of objects or characters within the scene. When these frames are played back in
sequence, the changes between them create the illusion of movement and action.
There are several key components to consider when creating animation sequences:
1. **Storyboarding**: Before creating the actual animation, artists often create a storyboard to plan out the
sequence of events, camera angles, and key poses. A storyboard serves as a visual blueprint for the animation,
helping to organize the flow of the story and ensure continuity between scenes.
2. **Keyframes**: In animation, keyframes are the frames where significant changes or poses occur. These
keyframes define the starting and ending points of movements or actions within the animation sequence.
Artists often create keyframes first, and then interpolate or fill in the in-between frames to create smooth
motion.
3. **In-betweening**: Also known as tweening, in-betweening is the process of creating intermediate frames
between keyframes to achieve smooth motion. This process involves interpolating the positions, rotations, or
other attributes of objects or characters to create the illusion of continuous movement.
4. **Timing and Spacing**: The timing and spacing of frames play a crucial role in animation. Timing refers to
the duration of each frame and how long it remains on screen, while spacing refers to the distribution and
spacing of keyframes to create realistic motion. Adjusting the timing and spacing can affect the speed, weight,
and fluidity of the animation.
5. **Playback Speed**: The frame rate at which the animation is played back also influences the perception of
motion. Higher frame rates result in smoother animation, while lower frame rates may create a more stylized
or choppy look.
steps of an animation sequence :
Sure! Here are the steps of an animation sequence in short:
1. **Storyboarding**: Plan out the sequence of events, key poses, and camera angles in a visual
storyboard..//2. **Keyframing**: Define the key poses or keyframes that represent significant moments or
positions in the animation..//3. **In-betweening**: Create intermediate frames or in-betweens to fill in the
motion between keyframes, ensuring smooth transitions..//4. **Timing and Spacing**: Adjust the timing and
spacing of frames to control the speed and rhythm of the animation, ensuring it flows naturally..//5.
**Refining**: Fine-tune the animation by adjusting curves, timing, and easing to enhance realism and polish
23

the final result..//6. **Rendering**: Generate the final frames of the animation using rendering software,
taking into account lighting, shading, and other visual effects..//7. **Playback**: Review the animation to
ensure it meets the desired quality and timing, making any necessary adjustments before finalizing..//8.
**Exporting**: Export the finished animation in the desired format for distribution or integration into a larger
project.

6. Define Graphical User Interface (GUI). Explain about different gaphical interface items.
A Graphical User Interface (GUI) is a visual interface that allows users to interact with electronic devices or
software using graphical elements such as icons, buttons, menus, and windows, rather than text-based
commands. GUIs provide an intuitive and user-friendly way for users to navigate and control computer
systems, applications, and devices.
Different graphical interface items commonly found in GUIs include:
1. **Icons**: Graphical representations of files, folders, applications, or functions, often used as visual
shortcuts for quick access to tasks or content..//2. **Buttons**: Interactive graphical elements that users can
click or tap to perform actions, such as opening a file, submitting a form, or navigating to another screen..//3.
**Menus**: Dropdown or popup lists of options or commands that users can select from to perform specific
actions or access additional features. Menus are often organized hierarchically, with submenus for more
detailed options..//4. **Windows**: Rectangular graphical containers that display content or applications on
the screen. Windows can be resized, moved, minimized, or closed, allowing users to manage multiple
applications or tasks simultaneously..//5. **Dialog Boxes**: Specialized windows that prompt users for input,
display messages, or provide options and settings for configuring applications or performing specific tasks..//6.
**Text Fields**: Areas where users can input text or data, such as search boxes, login forms, or text editors.
Text fields may include features like auto-complete, spell check, or formatting options..//7. **Scrollbars**:
Graphical controls used to navigate through content that exceeds the visible area of a window or screen,
allowing users to scroll up, down, left, or right to view additional content..//8. **Checkboxes and Radio
Buttons**: Interactive controls used to select or toggle options from a list of choices. Checkboxes allow users
to select multiple options, while radio buttons allow users to select only one option from a list..//9. **Sliders
and Progress Bars**: Controls used to adjust settings or indicate the progress of tasks. Sliders allow users to
set values within a range, while progress bars visually represent the completion status of ongoing
processes..//10. **Toolbars**: Horizontal or vertical strips containing buttons or icons that provide quick
access to frequently used commands or functions within an application..//
8. a Explain methods of 3D object representation.Here are some methods of 3D object representation briefly
explained:
1. **Polygon Meshes**: Represent 3D objects using connected polygons like triangles or quads. Versatile and
widely used for real-time rendering..//2. **Parametric Curves and Surfaces**: Define 3D objects with
mathematical equations, offering precise control over geometry but requiring more computational
resources..//3. **Voxel Grids**: Represent objects with a 3D grid of voxels, common in medical imaging and
voxel-based rendering..//4. **Implicit Surfaces**: Describe objects using mathematical functions, offering
flexibility but requiring more computational resources..//5. **Point Clouds**: Represent objects as a
collection of points in 3D space, used in 3D scanning and computer vision..//6. **Hierarchical Models**:
Organize 3D objects hierarchically for efficient representation and manipulation of complex objects.
What is touch pad? Explain its types in brief.
A touchpad, also known as a trackpad, is a pointing device commonly found on laptops, smartphones,
tablets, and other electronic devices. It allows users to control the cursor on a screen by moving their fingers
across a sensitive surface.
Types of touchpads include:
1. **Capacitive Touchpads**: These touchpads detect the presence and movement of fingers through
changes in capacitance. They are sensitive to touch and can recognize multiple points of contact, allowing for
gestures like scrolling, pinching, and swiping. Capacitive touchpads are widely used in modern laptops and
24

mobile devices.
2. **Resistive Touchpads**: These touchpads consist of two flexible layers separated by a small gap. When
pressure is applied to the surface, the layers come into contact, causing a change in resistance that is detected
by sensors. Resistive touchpads are less common today but were used in some older laptops and devices.
3. **Force Touchpads**: Also known as pressure-sensitive touchpads, force touchpads can detect not only the
presence of fingers but also the amount of pressure applied. This allows for additional functionalities such as
pressure-sensitive drawing or varying cursor speeds based on pressure. Force touchpads are found in some
high-end laptops and trackpads for desktop computers.
4. **Optical Touchpads**: These touchpads use optical sensors to track the movement of fingers. Light
emitted by LEDs is reflected off the surface, and changes in reflection patterns caused by finger movement are
detected by sensors. Optical touchpads are less common but offer advantages like durability and resistance to
environmental factors such as moisture or dust.

6. Why GUI in popular than CUI? What are the principles of interactive user design ? explain three of them .
Graphical User Interfaces (GUIs) are more popular than Command-Line User Interfaces (CUIs) for several
reasons:
1. **Intuitiveness**: GUIs use visual elements such as icons, buttons, and menus, making them more intuitive
and easier to learn for users who may not be familiar with command-line syntax or commands..//2.
**Interactivity**: GUIs allow for interactive and dynamic user interactions, enabling users to manipulate
objects directly on the screen through gestures, clicks, and drags, which enhances user engagement and
productivity..//3. **Accessibility**: GUIs are more accessible to a wider range of users, including those with
limited technical knowledge or disabilities, as they provide visual cues and feedback that facilitate navigation
and understanding of the interface..//4. **Multitasking**: GUIs support multitasking by allowing users to
interact with multiple applications or windows simultaneously, making it easier to switch between tasks and
manage complex workflows..//5. **Visual Representation**: GUIs provide visual representations of data,
processes, and system components, which aids in understanding and decision-making, compared to text-based
interfaces that rely solely on written descriptions or commands.
Principles of Interactive User Design:
1. **Consistency**: Ensure that the interface behaves predictably and consistently across different parts of
the system. Consistency in layout, terminology, and interaction patterns helps users navigate the interface
more efficiently and reduces cognitive load.
2. **Feedback**: Provide timely and relevant feedback to users for their actions or inputs. Feedback can be
visual (e.g., change in button color on hover), auditory (e.g., beep when an error occurs), or haptic (e.g.,
vibration on touch devices). Feedback helps users understand the outcome of their actions and confirms that
the system has registered their input.
3. **User Control**: Give users control over the interface and their interactions with it. Allow users to
customize settings, adjust preferences, and undo actions if needed. User control enhances user autonomy and
empowers them to tailor the interface to their preferences and needs
4. **Simplicity**: Keep the interface simple and straightforward, minimizing complexity and unnecessary
elements to improve usability and clarity.//5. **Visibility**: Ensure that important functions and options are
visible and easily accessible to users, reducing the need for memorization and exploration..//6. **Error
Prevention**: Design the interface to prevent errors or provide clear guidance on how to recover from them,
reducing user frustration and confusion..//7. **Flexibility**: Allow for flexibility in interaction styles and
preferences, accommodating different user needs and preferences for input methods, customization, and
workflow..//8. **Progressive Disclosure**: Present information and options gradually, revealing more
advanced features or details as users become more familiar with the interface, reducing cognitive overload.

Explain morphing technique.Morphing is a technique used in computer graphics and animation to smoothly
transform one image or shape into another. It involves creating a sequence of intermediate frames that
25

gradually change from the initial image to the final image, creating the illusion of continuous transformation.
The process of morphing typically involves the following steps:
1. **Point Correspondence**: Identify corresponding points or features between the two images or shapes.
These points serve as anchor points that will guide the morphing process.
2. **Warping**: Deform the initial image or shape to match the positions of the corresponding points in the
final image or shape. This step involves warping or distorting the geometry of the initial image to align with the
target image.
3. **Interpolation**: Generate intermediate frames by smoothly interpolating between the deformed initial
image and the final image. This interpolation is typically done by blending the pixel values of the two images
based on their respective positions and weights.
4. **Temporal Coherence**: Ensure temporal coherence by maintaining consistency between consecutive
frames in the morphing sequence. This involves smoothly transitioning between intermediate frames to create
a seamless and fluid animation.
5. **Rendering**: Render the morphing sequence to generate the final animation. This step involves
compositing the intermediate frames and applying any additional visual effects or enhancements.

5. Explain surface detection technique in brief


Surface detection techniques are methods used in computer graphics and computer vision to identify and
represent surfaces within a 3D scene or image. These techniques play a crucial role in various applications,
including 3D modeling, virtual reality, augmented reality, and object recognition. Here's a brief overview of
surface detection techniques:
1. **Polygonal Meshes**: Surfaces are approximated using interconnected polygons like triangles or quads,
versatile for real-time rendering.
2. **Implicit Surfaces**: Surfaces are described as the zero set of a mathematical function in 3D space,
offering flexibility but computationally expensive.
3. **Point Clouds**: Objects represented as a collection of points in 3D space, obtained from 3D scanning or
photogrammetry, useful for reconstruction and rendering.
4. **Voxel Grids**: Surfaces represented as a 3D grid of voxels, each containing object properties, commonly
used in medical imaging and volume rendering.
5. **Feature-based Methods**: Surfaces detected by identifying key features or points in a scene, used in
techniques like structure-from-motion and object recognition.

Draw and explain the function of windows icons , menus and graphical items found on window[10].
Icons, menus, and graphical elements are essential components of graphical user interfaces (GUIs) in operating
systems like Windows. Here's an explanation of each and their functions:
1. **Icons**:Icons are small graphical representations of files, folders, applications, or actions. They serve
several purposes:
- **Visual Representation**: Icons provide a visual representation of files, folders, or actions, making it
easier for users to identify and interact with them..//- **Quick Access**: They offer a convenient way to
access files, folders, or applications without navigating through multiple layers of directories..//- **Status
Indication**: Icons can also indicate the status of a file or application, such as whether it's open, closed, or
modified..//- **Drag-and-Drop**: Users can often drag icons to perform actions like moving files or creating
shortcuts..//
2. **Menus**:Menus are lists of options or commands that users can choose from. They typically appear as
dropdowns or pop-up windows and serve the following functions:
- **Navigation**: Menus help users navigate through different options and features within an application
or the operating system..// - **Commands**: They provide access to various commands or actions that users
can perform, such as opening a new file, saving a document, or printing..//- **Settings**: Menus often contain
settings or preferences that users can customize according to their needs..// - **Contextual Options**:
26

Depending on the context, menus may change to display relevant options. For example, right-clicking on a file
may bring up a context menu with options specific to that file.
3. **Graphical Items**:Graphical items encompass a wide range of elements, including buttons, checkboxes,
sliders, and dialog boxes. These elements serve various purposes:
- **Interactivity**: Graphical items allow users to interact with the interface by clicking, dragging, or
typing input.// - **Feedback**: They provide visual feedback to users when actions are performed, such as
changing color or appearance when clicked..//- **Controls**: Graphical items often control specific functions
or settings within an application or the operating system, such as adjusting volume with a slider or selecting
options with checkboxes..// - **Dialog Boxes**: These are graphical windows that display information or
prompt users to make decisions. They often contain buttons, text fields, and other graphical elements for user
interaction.
Resolution:Resolution refers to the clarity or detail of an image, video, or display screen, typically measured
in pixels. It determines the number of pixels that can be displayed horizontally and vertically. A higher
resolution means more pixels, resulting in sharper and clearer images.
There are two primary types of resolution:
1. **Screen Resolution**:
- Screen resolution refers to the number of pixels displayed on a screen horizontally by vertically. It's often
expressed as width × height, such as 1920 × 1080 pixels.
- Common screen resolutions include:
- HD (High Definition): 1280 × 720 pixels (720p)
- Full HD: 1920 × 1080 pixels (1080p)
- Quad HD (QHD): 2560 × 1440 pixels
- 4K Ultra HD: 3840 × 2160 pixels (2160p)
- 8K Ultra HD: 7680 × 4320 pixels
- Higher resolutions provide sharper images and more detail, but they may require more processing power
and higher-quality display hardware.
2. **Print Resolution**:Print resolution refers to the number of dots or pixels per inch (dpi) in a printed
image. It determines the level of detail and sharpness achievable in printed materials.
- Common print resolutions for high-quality prints range from 300 to 600 dpi. Lower resolutions may
suffice for large-format prints viewed from a distance, while higher resolutions are necessary for small prints
or those viewed up close.
- Print resolution is crucial for maintaining image quality, especially for text, graphics, and photographs.

You might also like