LECTURE NOTES On Computer Graphics and M

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

LECTURE NOTES on Computer Graphics and Multimedia

Table of Contents
INTRODUCTION ....................................................................................................................................... 3
WHAT IS COMPUTER GRAPHICS? ........................................................................................................... 3
APPLICATIONS ......................................................................................................................................... 4
Presentation Graphics......................................................................................................................... 5
Resolution ....................................................................................................................................... 7
File format ....................................................................................................................................... 7
Painting and Drawing .......................................................................................................................... 8
Scientific Visualisation ...................................................................................................................... 10
Image Processing .............................................................................................................................. 11
Simulations........................................................................................................................................ 14
Animation and Games....................................................................................................................... 16
Education, Training, Entertainment and Computer Aided Design (CAD) ......................................... 19
Input and Output Devices ................................................................................................................. 23
Touch Panels ................................................................................................................................. 23
Light Pen........................................................................................................................................ 24
Graphics Tablet ............................................................................................................................. 25
Plotter ........................................................................................................................................... 28
Refresh CRT ....................................................................................................................................... 29
Basic Operation of CRT.................................................................................................................. 29
Working ......................................................................................................................................... 29
Random-Scan and Raster Scan Monitor ........................................................................................... 32
Raster-Scan Displays ......................................................................................................................... 33
Color CRT Monitors ........................................................................................................................... 34
Beam Penetration Method ........................................................................................................... 34
Shadow Mask Method .................................................................................................................. 34
Direct-View Storage Tubes (DVST) .................................................................................................... 35
Flat-Panel Displays ............................................................................................................................ 36
Light-emitting Diode (LED) ................................................................................................................ 36
Liquid-crystal Displays (LCDs)............................................................................................................ 36
Hard Copy Devices ............................................................................................................................ 37
Introduction .......................................................................................................................................... 39

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 1
LECTURE NOTES on Computer Graphics and Multimedia

Scan-converting a Point ........................................................................................................................ 39


Scan-converting a Straight Line ........................................................................................................ 40
Direct Use of Line Equation........................................................................................................... 41
DDA Algorithm .................................................................................................................................. 41
Bresenham’s Line Algorithm ............................................................................................................. 45
Mid Point Line Algorithms: ............................................................................................................... 49
Midpoint Circle Algorithms: .............................................................................................................. 50
Mid Point ellipse Drawing Algorithms: ............................................................................................. 52
POLYGON FILLING ALGORITHM ............................................................................................................ 54
Scan Line Polygon Fill Algorithm ....................................................................................................... 54
Boundary-Fill Algorithm .................................................................................................................... 57
Flood Fill Algorithms. ........................................................................................................................ 58

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 2
LECTURE NOTES on Computer Graphics and Multimedia

INTRODUCTION

Early man used drawings to communicate even before he learnt to talk, write, or count.
Incidentally, these ancient hieroglyphics (picture-writings) communicate as well today, as
they must have done thousands of years ago, this fully supports the saying that “A picture is
worth a thousand words” and in the era of computers we can add on to it or we may as well
revise the saying to “A computer is worth a million pictures!”; so, you can estimate the
power of a computer as a communication system. Now, with the advances in computer
hardware and software, graphics has come a full circle and, more and more people are
teaching and learning, communicating and sharing their ideas through the medium of
graphics. By graphics, we mean any sketch, drawing, special artwork or other material that
pictorially depict an object or a process or otherwise conveys information, as a supplement
to or instead of written descriptions, and the utilisation of computers to accomplish such
tasks leads to a new discipline of computer graphics. Traditionally, graphics has referred to
engineering drawings of buildings, bridges, machine parts etc. and scientific drawings such
as x-y curves, network and process flowcharts. In recent decades, graphics has ventured into
industrial design, advertising and other artistic endeavours. During the last few years, even
newspapers and periodicals aimed at the common man have begun to utilise graphics to
present quantitative news such as selection results and production statistics. Computer
graphics can do all this and more. In fact, the power and easy availability of computer
graphics have increased the use of pictures to replace and augment words to describe,
educate, or inform a wide variety of audiences, on a wide variety of subjects.

WHAT IS COMPUTER GRAPHICS?

The meaning of the term Graphics is Graphical Tricks. Every image or picture is in fact a
graph and when different mathematical tricks are used to manipulate some change in its
properties like shape, size, motion etc., through the help of computers then, the
representation is nothing but computer graphics, so we can say that “Computer Graphics
(CG) is the field of visual computing, where one utilises computers both to generate visual
images synthetically and to integrate or alter visual and spatial information sampled from
the real world.” OR “Computer Graphics is the pictorial representation manipulation of
data by a computer” OR “Computer Graphics refers to any sketch, drawing, special
artwork or other material generated with the help of computer to pictorially depict an
object or a process or otherwise convey information, as a supplement to or instead of
written descriptions”. Computer Graphics is a complex and diversified field. A Picture is a
fundamental cohesive concept in Computer Graphics. Each picture consists of points called
pixels (Picture- element). If we consider a complex picture, then complex database for pixels
are considered, hence, complex algorithm are required to access them. These complex
databases contain data organised in various data structures such as ring structures, B-tree
etc.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 3
LECTURE NOTES on Computer Graphics and Multimedia

There are many algorithms, which can be materialised to produce graphical effects on the
screen through several graphical tools based on different languages that are available in the
market.

Computer graphics can be broadly divided into the following classes:

 Business Graphics or the broader category of Presentation Graphics, which refers to


graphics, such as bar-charts (also called histograms), pie-charts, pictograms (i.e., scaled
symbols), x-y charts, etc. used to present quantitative information to inform and
convince the audience.
 Scientific Graphics, such as x-y plots, curve-fitting, contour plots, system or program
flowcharts etc.
 Scaled Drawings, such as architectural representations, drawings of buildings, bridges,
and machines.
 Cartoons and artwork, including advertisements.
 Graphics User Interfaces (GUIs) which are the images that appear on almost all
computer screens these days, designed to help the user utilise the software without
having to refer to manuals or read a lot of text on the monitor.

The most familiar and useful class of computer graphics involves movies and video games.
Movies generally need graphics that are indistinguishable from physical reality, whereas
video games need graphics that can be generated quickly enough to be perceived as smooth
motion. These two needs are incompatible, but they define two-ways of communications
between users and computations. In video games, the subject matter of computations is
generally characters chasing and shooting at each other. A more familiar use of computer
graphics exists for interacting with scientific computations apart from movies and games.
This familiarisation of the use of computer graphics has influenced our life, through
simulations, virtual reality, animation; we can extend the scope of education,
entertainment, analysis etc. So, in global terms Computer graphics can be categorised in
two ways:

Interactive Computer Graphics which is interactively used by users e.g., games.

Passive Computer Graphic which has no option for users to interact or use computer
graphics e.g., movies

APPLICATIONS

Research in computer graphics covers a broad range of application including both


photorealistic and non-photorealistic image synthesis, image-based modelling and
rendering and other multi-resolution methods, curve and surface design, range scanning,
surface reconstruction and modelling, motion capture, motion editing, physics-based
Dr. Ankur Pachauri
MCA Department RATM, Mathura Page 4
LECTURE NOTES on Computer Graphics and Multimedia

modelling, animation, interactive 3D user interfaces, image editing and colour reproduction.
Work is going on in various fields but computer vision is a hot topic, where research tackles
the general problem of estimating properties of an object or scene through the processing
of images, both 2D photographs and 3D range maps. Within this broad scope, we
investigate efficient ways to model, capture, manipulate, retrieve, and visualise real-world
objects and environments. Once you get into computer graphics, you’ll hear about all kinds
of applications that do all kinds of things. While working on a project, you may need images,
brochures, a newsletter, a PowerPoint presentation, poster, DVD etc. Thus, the question
arises what software do I need to get my job done. The section will help to straighten all of
that out in your head. Hopefully, if you know what does what, you won’t waste money
duplicating purchases, and when other designers or co-workers are talking shop, you’ll know
what is going on. Graphic design applications are basically broken down on the basis of a
few considerations. The first two considerations are, “Is your project for print, or web”.
When I say web, what I really mean is monitor based publishing. This means that you are
going to see your work on a computer screen, and television, or a big screen projector. So,
as you read through this section, whenever we say “web based”, we mean monitor based.
Beyond print and web, here are the various categories that we can think of that various
applications would fit into; Image Manipulation; Vector Graphics; Page Layout; Web site
development; Presentation Software; Video Editing; DVD Production; Animation and
Interactivity etc. If you are creating, or learning to create graphic design, computer art, or
maybe “Digital Media” is the term that we should use, then it’s a good thing to understand
the function of each application. There are many applications in the market and most of
them are expensive. A few of the various application areas that are influenced by Computer
graphics are:

 Presentation Graphics
 Painting and Drawing
 Photo Editing
 Scientific Visualisation
 Image Processing
 Education, Training, Entertainment and CAD
 Simulations
 Animation and Games

Presentation Graphics

The moment you are going to represent yourself or your company or product or research
paper etc. simply standing and speaking is quite ineffective. Now, in such a situation where
no one stands with you, your ultimate companions are the slides which have some
information either in the form of text, charts, and graphs etc., which make your
presentation effective. If you think more deeply, these are nothing but the ways some

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 5
LECTURE NOTES on Computer Graphics and Multimedia

curves (text/graph/charts) which are used in some sequence and to create such things,
graphics is the ultimate option, this application of graphics is known as presentation
graphics, which can be done very effectively through computers now-a-days. There are
some software which helps you present you and you’re concerned effectively. Such
application software is known as Presentation Graphics software – which is software that
shows information in the form of a slide show (A slideshow is a display of a series of chosen
images, which is done for artistic or instructional purposes. Slideshows are conducted by a
presenter using an apparatus which could be a computer or a projector).

Three major functions of presentation graphics are:

 An editor that allows text to be inserted and formatted.


 A method for inserting and manipulating graphic images.
 A slide-show system to display the content.

The program that helps users to create presentations such as visual aids, handouts, and
overhead slides to process artwork, graphics, and text and produce a series of ‘slides’–
which help speakers get their message across are presentation graphics software.

Example programs include some software like Apple’s Keynote, Openoffice’s (Star Office-by
Sun Microsystems) Impress, and Microsoft PowerPoint (for multimedia presentations,
incorporating moving pictures, and sounds). Custom graphics can also be created in other
programs such as Adobe Photoshop or Adobe Illustrator and then imported. With the
growth of video and digital photography, many programs that handle these types of media
also include presentation functions for displaying them in a similar “slide show” format.
Similar to programming extensions for an Operating system or web browser, “add-on” or
plug-in for presentation programs can be used to enhance their capabilities. For example, it
would be useful to export a PowerPoint presentation as a Flash animation or PDF document.
This would make delivery through removable media or sharing over the Internet easier.
Since PDF files are designed to be shared regardless of platform and most web browsers
already have the plug-in to view Flash files, these formats would allow presentations to be
more widely accessible. We may say that Presentation graphics is more than just power
point presentation because it includes any type of slide presentation, bar chart, pie chart,
graphs and multimedia presentation. The key advantage of this software is that it helps you
show abstracts of representation of work.

Note: There are some software like canvas that improves the presentation created through
PowerPoint or keynote software. Although these software packages contain a lot of handy
features, they lack many vector and image creation capabilities, therefore, creating a need
for a graphic/illustration program. Scientists, engineers, and other technically-oriented
professionals often call upon Canvas and its host of vector, image editing, and text features
to create the exciting visual components for their presentation projects.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 6
LECTURE NOTES on Computer Graphics and Multimedia

General questions that strike many graphic designers, students, and engineers rushing to
import their illustrations and images into presentations are:

 What resolution should be used?


 Which file format is best?
 How do I keep the file size down?

Let us discuss in brief the suitability of the technique (Vector or Bitmap), and the file format
appropriate to the creation of a better presentation.

Resolution

Graphic illustrations are used in presentations to help convey an idea or express a mood,
two kinds of illustration graphics are:

1. Vector
2. Bitmap.

You may wonder which one of these is a better format when exporting to some software
PowerPoint or Keynote or impress. The truth is that there are different situations that call
for different methods, but here are some things to look out for.

For instance, vectors are objects that are defined by anchor points and paths, while
bitmapped graphics are digital images composed of pixels. The advantage of using vector
graphics is that they are size independent, meaning that they could be resized with no loss
in quality. Bitmapped graphics, on the other hand, provide a richer depth of colour but are
size dependent and appear at the stated 72 dpi size.

File format

Say, we want an image of a Fly. The wings are partially transparent and to represent that in
our presentation what be problematic if proper file format is not there. This choice of file
format is hidden in the software that you may be using. Two cases for the same situation
are discussed below:

 The right file format that will allow us to create a transparent background in
Keynote presentation. Even though Keynote could import all common file formats
such as GIF, JPG, and BMP, there is one format that will work particularly well which
is .PSD. Using .PSD (Photoshop format) we are able to easily place a transparent
image, even partially transparent sections of the image, such as the wings of the fly,
as well as retain their properties.
 The right file format that will allow us to create a transparent background in
PowerPoint. Even though PowerPoint could import all common file formats such as
GIF, JPG, and BMP, there are two particular file formats that will work exceptionally

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 7
LECTURE NOTES on Computer Graphics and Multimedia

well: TIFF and PNG. Using TIFF (Tagged-Image File Format) or PNG (Portable Network
Graphic), we could easily remove the unwanted background quickly and easily in
PowerPoint, a feature not available to the other mentioned file formats.

Note: TIFF or PNG: TIFF has been around longer than PNG, which was originally
designed to replace GIF on the Web. PowerPoint works well with both these files when
creating transparent backgrounds but generally PNG creates smaller file sizes with no loss of
quality.

Painting and Drawing

When we talk about graphics, we mean pictures, and pictures can be either illustrations or
photographs. If you want to get graphics into a Web page or multimedia presentation, you
either have to create them in some kind of graphics application by drawing or painting them
right there in the application, or bringing them into the application via a digital camera or
scanner, and then editing and saving them in a form suitable to your medium. Many
software applications offer a variety of features for creating and editing pictures on the
computer. Even multimedia authoring and word processing programs include some simple
features for drawing on the computer. So, painting and drawing application in computer
graphics allows the user to pick and edit any object at any time. The basic difference is as
follows:

Drawing: in a software application means using tools that create “objects,” such as squares,
circles, lines or text, which the program treats as discrete units. If you draw a square in
PowerPoint, for example, you can click anywhere on the square and move it around or
resize it. It’s an object, just like typing the letter “e” in a word processor. i.e., a drawing
program allows a user to position standard shape (also called symbols, templates, or
objects) which can be edited by translation, rotations and scaling operations on these
shapes.

Painting: functions, on the other hand, don’t create objects. If you look at a computer
screen, you’ll see that it’s made up of millions of tiny dots called pixels. You’ll see the same
thing in a simpler form if you look at the colour comics in the Sunday newspaper — lots of
dots of different colour ink that form a picture. Unlike a drawing function, a paint function
changes the colour of individual pixels based on the tools you choose. In a photograph of a
person’s face, for example, the colours change gradually because of light, shadow and
complexion. You need a paint function to create this kind of effect; there’s no object that
you can select or move the way you can with the drawn square i.e., a painting program
allows the user to paint arbitrary swaths using brushes of various sizes, shapes, colour and
pattern. More painting program allows placement of such predefined shapes as rectangles,
polygon and canvas. Any part of the canvas can be edited at pixel level.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 8
LECTURE NOTES on Computer Graphics and Multimedia

The reason why the differences are important is that, as noted earlier, many different kinds
of programs offer different kinds of graphics features at different levels of sophistication,
but they tend to specialise in one or the other. For example:

1) Many word processors, like Word, offer a handful of simple drawing functions. They
aren’t that powerful, but if all you need is a basic illustration made up of simple shapes to
clarify a point, they’re fine.

2) Some programs specialise in graphics creation. Of these, some are all-purpose programs,
like KidPix, which offers both drawing and painting functions. KidPix is targeted specifically
at children; it has a simplified interface and lacks the sophisticated functions a professional
artist might want. Other programs, like Adobe Photoshop, specialise in painting functions,
even though they may include drawing functions as well. Painter is a paint-oriented program
that offers highly sophisticated, “natural media” functions that approximate the effects of
watercolours or drawing with charcoal on textured paper. Other graphics programs, such as
Adobe Illustrator, specialise in drawing for professional artists and designers; AutoCAD is
used mainly for technical and engineering drawing.

3) Page layout, presentation, multimedia authoring and Web development programs usually
contain a variety of graphics functions ranging from the simple to the complex, but their
main purpose is composition, not image creation or editing. That is, they allow you to create
or import text and graphics and, perhaps, sound, animation and video. Most of the graphics
features in these types of programs are limited to drawing functions because they assume
that you will do more complex work in a program dedicated to other functions (e.g., writing
in a word processor, editing photos in a paint program), then import your work to arrange
the different pieces in the composition program. (Some multimedia authoring systems,
however, also offer painting and drawing functions.) By the way, the differences in
composition programs are mainly in the form of their output: Page layout programs, such as
PageMaker and QuarkXPress, are for composing printed pages; presentation and
multimedia authoring programs, such as PowerPoint and HyperStudio, are for slide shows
and computer displays; and Web development applications, like Netscape Composer, are
for, well, Web pages.

4) What if you are going to make a magazine, newspaper, book or maybe a multipage menu
for a restaurant. In that case, we need a page layout program. The well known software in
page layout are:

 Quark Express
 Page Maker (Adobe)
 Indesign (Adobe)
 Publisher (Microsoft)

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 9
LECTURE NOTES on Computer Graphics and Multimedia

The Queen of Page Layout is Quark Express, owned by Quark Express and Indesign is the
King owned by Adobe and finally there is Microsoft Publisher, which is very easy to use.

5) To create posters, brochures, business cards, stationary, coffee mug design, cereal boxes,
candy wrappers, half gallon jugs of orange juice, cups, or anything else you see in print,
most designers are going to use vectorised programs to make these things come to life.
Vectors are wonderful because they print extremely well, and you can scale them up to
make them large, or scale them down to make them small, and there is no distortion. Adobe
Illustrator is the King of Vector Programs, hands down. In Adobe Illustrator, you can create a
12 foot, by 12 foot document. If we are going to make anything that is going to be printed,
we are doing it in Illustrator. Anything that you create in Illustrator, and the text you use,
will come out great. The thing is, Illustrator is hard to learn. It is not an intuitive program at
all. This is because vectors use control points called paths and anchor points. To someone
new, they are hard to understand, find, and control. That’s another story. If you are making
a poster, you would make your logo, artwork and text in Illustrator. You would still
manipulate your images in Photoshop, and then, “place” them to the Illustrator.

Scientific Visualisation

It is difficult for the human brain to make sense out of the large volume of numbers
produced by a scientific computation. Numerical and statistical methods are useful for
solving this problem. Visualisation techniques are another approach for interpreting large
data sets, providing insights that might be missed by statistical methods. The pictures they
provide are a vehicle for thinking about the data. As the volume of data accumulated from
computations or from recorded measurements increases, it becomes more important that
we be able to make sense out of such data quickly. Scientific visualisation, using computer
graphics, is one way to do this. Scientific visualisation involves interdisciplinary research into
robust and effective computer science and visualisation tools for solving problems in
biology, aeronautics, medical imaging, and other disciplines. The profound impact of
scientific computing upon virtually every area of science and engineering has been well
established. The increasing complexity of the underlying mathematical models has also
highlighted the critical role to be played by scientific visualisation. It, therefore, comes as no
surprise that Scientific visualisation is one of the most active and exciting areas of
Mathematics and Computing Science, and indeed one which is only beginning to mature.
Scientific visualisation is a technology which helps to explore and understand scientific
phenomena visually, objectively, and quantitatively. Scientific visualisation allows scientists
to think about the unthinkable and visualise the unviable. Through this we are seeking to
understand data. We can generate beautiful pictures and graphs; we can add scientific
information (temperature, exhaust emission or velocity) to an existing object thus becoming
a scientific visualisation product. Thus, we can say scientific visualisation is a scientist’s tool
kit, which helps to simulate insight and understanding of any scientific issue, thus, helping
not only in solving or analysing the same but also producing appropriate presentations of
Dr. Ankur Pachauri
MCA Department RATM, Mathura Page 10
LECTURE NOTES on Computer Graphics and Multimedia

the same. This concept of scientific visualisation fits well with modelling and simulation. The
Figure below describes steps for visualisation of any scientific problem under consideration;
these steps are followed recursively to visualize any complex situation.

Hence, computer graphics has become an important part of scientific computing. A large
number of software packages now exist to aid the scientist in developing graphical
representations of their data. Some of the tools or packages used to express the graphical
result for modelling and simulation of any scientific visualisation are:

 Matlab (by The Math Works Inc.)


 Mathematica or Maple (graphical computer algebra system)
 Stella (models dynamic systems)
 IDS (Interactive Data Systems) by Research System Inc.
 AVS (Application Visualisation System) by Advance visual System Inc.
 Excel.

Image Processing

Modern digital technology has made it possible for the manipulation of multidimensional
signals with systems that range from simple digital circuits to advanced parallel computers.
The goal of this manipulation can be divided into three categories:

1. Image Processing image in -> image out


2. Image Analysis image in -> measurements out
3. Image Understanding image in -> high-level description out

We will focus on the fundamental concepts of image processing. We can only make a few
introductory remarks about image analysis here, as to go into details would be beyond the
scope of this unit. Image understanding requires an approach that differs fundamentally
from the theme of this section. Further, we will restrict ourselves to two-dimensional (2D)
image processing although, most of the concepts and techniques that are to be described
can be extended easily to three or more dimensions. We begin with certain basic
definitions. An image defined in the “real world” is considered to be a function of two real

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 11
LECTURE NOTES on Computer Graphics and Multimedia

variables, for example, a(x,y) with a as the amplitude (e.g., brightness) of the image at the
real coordinate position (x,y). An image may be considered to contain sub-images
sometimes referred to as regions-of-interest, ROIs, or simply regions. This concept reflects
the fact that images frequently contain collections of objects each of which can be the basis
for a region. In a sophisticated image processing system it should be possible to apply
specific image processing operations to selected regions. Thus, one part of an image (region)
might be processed to suppress motion blur while another part might be processed to
improve colour rendition. The amplitudes of a given image will almost always be either real
numbers or integer numbers. The latter is usually a result of a quantisation process that
converts a continuous range (say, between 0 and 100%) to a discrete number of levels. In
certain image-forming processes, however, the signal may involve photon counting which
implies that the amplitude would be inherently quantised. In other image forming
procedures, such as magnetic resonance imaging, the direct physical measurement yields a
complex number in the form of a real magnitude and a real phase.

A digital image a [m,n] described in a 2D discrete space is derived from an analog image
a(x,y) in a 2D continuous space through a sampling process that is frequently referred to as
digitisation. Let us discuss details of digitization. The 2D continuous image a(x,y) is divided
into N rows and M columns. The intersection of a row and a column is termed a pixel. The
value assigned to the integer coordinates [m,n] with {m=0,1,2,...,M –1} and {n=0,1,2,...,N –1}
is a[m,n]. In fact, in most cases a(x,y) – which we might consider to be the physical signal
that impinges on the face of a 2D sensor – is actually a function of many variables including
depth (z), colour ( ), and time (t). The effect of digitisation is shown in Figure below.

The image shown in Figure above has been divided into N = 30 rows and M = 30 columns for
digitisation of a continuous image. The value assigned to every pixel (pixel at coordinates
[m=10, n=3]) is the average brightness in the pixel rounded to the nearest integer value. The
process of representing the amplitude of the 2D signal at a given coordinate as an integer

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 12
LECTURE NOTES on Computer Graphics and Multimedia

value with L different gray levels is usually referred to as amplitude quantisation or simply
quantisation.

Example Tools and Software for Image Processing

Certain tools are central to the processing of digital images. These include mathematical
tools such as convolution, Fourier analysis, and statistical descriptions, and manipulative
tools such as chain codes and run codes. But these tools are worked with at very core levels,
in general we use some software to process the image with the help of computers. Some of
the categories of image processing software with their respective examples and features are
listed below:

1) Graphics Image Processing: The most commonly used software is: Photoshop.

Features:

 Most common image processing software.


 Focuses on creating a pretty picture.
 Usually limited to popular graphics formats such as: TIFF, JPEG, GIF
 Best suited for working with RGB (3-band) images.
 Does not treat an image as a “map”.

2) Geographic Information Systems (GIS): The most commonly used software is: ArcMap.

Features:

 Works within a geographic context.


 Great for overlaying multiple vector and raster layers.
 It has a somewhat limited analysis although capability, these limitations are being
reduced.
 More common than remote sensing software.

3) Remote Sensing Packages: Commonly used software example is: ERDAS

Features:

 Best suited for satellite imagery.


 Uses geo-spatial information.
 Easily works with multi-spectral data.
 Provides analysis functions commonly used for remote sensing applications.
 Often easy to use but it helps to be familiar with remote sensing.

4) Numerical Analysis Packages: Commonly used software is: MatLab.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 13
LECTURE NOTES on Computer Graphics and Multimedia

Features:

 Focus usually on numeric processing.


 Programming or mathematical skills usually helpful.
 Used to build more user-friendly applications.

5) Web-based Services: Commonly used software is: Protected Area Archive.

Features:

 Image display, roam, zoom.


 Image enhancement.
 Simple image processing.
 Distance and area measurement.
 Comparison of old and new images.
 Image annotation (adding text, lines, etc).
 Overlaying vector layers.

Note:

1) Images are the final product of most processes in computer graphics. The ISO
(International Standards Organization) defines computer graphics as the sum total of
methods and techniques for concerning data for a graphics device by computer, it
summarise computer graphics as converting data into images, also called visualisation

2) Computer graphics concerns the pictorial synthesis of real or imaginary objects from their
computer-based models; whereas the related field of image progressing treats the converse
process, analysing and reconstruction of sciences. Images processing has sub-areas image
enhancement, pattern detection and recognition. This one is used to improve the quality of
images by using pattern detection and recognition. OCR is one of example.

Simulations

Computer simulation is the discipline of designing a model of an actual or theoretical


physical system, executing the model on a digital computer, and analysing the execution
output. Simulation embodies the principle of “learning by doing” – to learn about the
system we must first build a model of some sort and then operate the model. The use of
simulation is an activity that is as natural as a child who role plays. Children understand the
world around them by simulating (with toys and figures) most of their interactions with
other people, animals and objects. As adults, we lose some of this childlike behaviour but
recapture it later on through computer simulation. To understand reality and all of its
complexity, we must build artificial objects and dynamically act our roles with them.
Computer simulation is the electronic equivalent of this type of role playing and it serves to

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 14
LECTURE NOTES on Computer Graphics and Multimedia

drive synthetic environments and virtual world. Within the overall task of simulation, there
are three primary sub-fields: model design, model execution and model analysis (Figure
below).

To simulate something physical, you will first need to create a mathematical model, which
represents that physical object. Models can take many forms including declarative,
functional, constraint, spatial or multimodal. A multimodal is a model containing multiple
integrated models each of which represents a level of granularity for the physical system.
The next task, once a model has been developed, is to execute the model on a computer,
that is, you need to create a computer program which steps through time while updating
the state and event variables in your mathematical model. There are many ways to “step
through time”. You can, for instance, leap through time using event scheduling or you can
employ small time increments using time slicing. You can also execute (i.e., simulate) the
program on a massively parallel computer. This is called parallel and distributed simulation.
For many large-scale models, this is the only feasible way of getting answers back in a
reasonable amount of time. You may want to know why to do simulation? Is there any other
way to do the tasks? To discuss these issues lets briefly discuss the cases in which simulation
is essential. There are many methods of modelling systems which do not involve simulation
but which involve the solution of a closed-form system (such as a system of linear
equations). Let us not go into these issues, as they are not part of our current discussion.

Simulation is often essential in the following cases:

1. The model is very complex with many variables and interacting components;
2. The underlying variables relationships are nonlinear;
3. The model contains random variants;
4. The model output is to be visual as in a 3D computer animation.

The Advantage of Simulation is that – even for easily solvable linear systems – a uniform
model execution technique can be used to solve a large variety of systems without resorting

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 15
LECTURE NOTES on Computer Graphics and Multimedia

to a “bag of tricks” where one must choose special-purpose and sometimes arcane solution
methods to avoid simulation. Another important aspect of the simulation technique is that
one builds a simulation model to replicate the actual system. When one uses the closed-
form approach, the model is sometimes twisted to suit the closed-form nature of the
solution method rather than to accurately represent the physical system. A harmonious
compromise is to tackle system modelling with a hybrid approach using both closed-form
methods and simulation. For example, we might begin to model a system with closed-form
analysis and then proceed later with a simulation. This evolutionary procedure is often very
effective.

Pitfalls in computer simulation

Although generally ignored in computer simulations, in strict logic the rules governing
floating point arithmetic still apply. For example, the probabilistic risk analysis of factors
determining the success of an oilfield exploration program involves combining samples from
a variety of statistical distributions using the Monte Carlo methods. These include normal,
lognormal, uniform and the triangular distributions. However, a sample from a distribution
cannot sustain more significant figures than were present in the data or estimates that
established those distributions. Thus, abiding by the rules of significant arithmetic, no result
of a simulation can sustain more significant figures than were present in the input
parameter with the least number of significant figures. If, for instance the net/gross ratio of
oil-bearing strata is known to only one significant figure, then the result of the simulation
cannot be more precise than one significant figure, although it may be presented as having
three or four significant figures.

Note: Monte Carlo methods are a widely used class of computational algorithm for
simulating the behaviour of various physical and mathematical systems. They are
distinguished from other simulation methods (such as molecular dynamics) by being
stochastic, that is non-deterministic in some manner – usually by using random number – as
opposed to deterministic algorithms. Because of the repetition of algorithms and the large
number of calculations involved, Monte Carlo is a method suited to calculation using a
computer, utilising many techniques of computer simulation. Further, Monte Carlo
algorithm is a numerical Monte Carlo method used to find solutions to mathematical
problems (which may have many variables) that cannot easily be solved, for example, by
integral calculus, or other numerical methods. For many types of problems, its efficiency
relative to other numerical methods increases as the dimensions of the problem increases.

Animation and Games

In our childhood, we have all seen the flip books of cricketers which came free along with
some soft drink, where several pictures of the same person in different batting or bowling
actions are sequentially arranged on separate pages, such that when we flip the pages of

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 16
LECTURE NOTES on Computer Graphics and Multimedia

the book the picture appears to be in motion. This was a flipbook (several papers of the
same size with an individual drawing on each paper so the viewer could flip through them).
It is a simple application of the basic principle of physics called persistence of vision. This
low tech animation was quite popular in the 1800s when the persistence of vision (which is
1/16th of a second) was discovered. This discovery led to some more interesting low tech
animation devices like the zoetrope, wheel of life, etc. Later, depending on many basic
mathematics and physics principles, several researches were conducted which allowed us to
generate 2d/3d animations. Further we will study the transformations involved in computer
graphics but you will notice that all transformations are related to space and not to time.
Here lies the basic difference between animation and graphics. The difference is that
animation adds to graphics the dimension of time which vastly increases the amount of
information to be transmitted, so some methods are used to handle this vast information
and these methods are known as animation methods which are classified as:

First Method: In this method, the artist creates a succession of cartoon frames, which are
then combined into a film.

Second Method: Here, the physical models are positioned to the image to be recorded. On
completion, the model moves to the next image for recording and this process is continued.
Thus the historical approach of animation has classified computer animation into two main
categories:

(a) Computer-Assisted Animation usually refers to 2d systems that computerise the


traditional animation process. Here, the technique used is interpolation between key shapes
which is the only algorithmic use of the computer in the production of this type of
animation equation, curve morphing (key frames, interpolation, velocity control), image
morphing.

(b) Computer Generated Animation is the animation presented via film or video, which is
again based on the concept of persistence of vision because the eyebrain assembles a
sequence of images and interprets them as a continuous movement and if the rate of
change of pictures is quite fast then it induces the sensation of continuous motion.

This motion specification for computer-generated animation is further divided into 2


categories:

Low Level Techniques (Motion Specific) techniques are used to control the motion of any
graphic object in any animation scene fully. Such techniques are also referred as motion
specific techniques because we can specify the motion of any graphic object in the scene.
Techniques such as interpolation, approximation etc., are used in motion specification of
any graphic object. Low level techniques are used when animator usually has a fairly specific
idea of the exact motion that s/he wants.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 17
LECTURE NOTES on Computer Graphics and Multimedia

High Level Techniques (Motion Generalised) are techniques used to describe the general
motion behaviour of any graphic object. These techniques are algorithms or models used to
generate motion using a set of rules or constraints. The animator sets up the rules of the
model, or chooses an appropriate algorithm, and selects initial values or boundary values.
The system is then set into motion and the motion of the objects is controlled by the
algorithm or model. This approach often relies on fairly sophisticated computation such as,
vector algebra and numerical techniques among others.

So, the animation concept can be defined as: A time based phenomenon for imparting visual
changes in any scene according to any time sequence. The visual changes could be
incorporated through the Translation of the object, scaling of the object, or change in colour,
transparency, surface texture etc.

Note: It is to be noted that computer animation can also be generated by changing camera
parameters such as its position, orientation, focal length etc. plus changes in the light effects
and other parameters associated with illumination and rendering can produce computer
animation too. Before the advent of computer animation, all animation was done by hand,
which involved an enormous amount of work. You may have an idea of the amount of work
by considering that each second of animation film contains 24 frames (film). Then, one can
imagine the amount of work in creating even the shortest of animated films. Without going
into details of traditional methods let us categorise computer animation technique.
Computer animation can be categorised in two ways:

Interactive Computer Animation which is interactively used by users e.g., games. Sprite
animation is interactive and used widely in Computer games. In its simplest form it is a 2D
graphic object that moves across the display. Sprites often have transparent areas. Sprites
are not restricted to rectangular shapes. Sprite animation lends itself well to interactivity.
The position of each sprite is controlled by the user or by an application program (or by
both). It is called “external” animation. We refer to animated objects (sprites or movies) as
“animobs”. In games and in many multimedia applications, the animations should adapt
themselves to the environment, the program status or the user activity. That is, animation
should be interactive. To make the animations more event driven, one can embed a script, a
small executable program, in every animob. Every time an animob touches another animob
or when an animob gets clicked, the script is activated. The script then decides how to react
to the event (if at all).

Passive Computer Animations: which has no option for users to use computer graphics
today is largely interactive e.g., movies. Frame animation is non-interactive animation and is
generally used in generating Cartoon movies. This is an “internal” animation method, i.e., it
is animation inside a rectangular frame. It is similar to cartoon movies: a sequence of frames
that follow each other at a fast rate, fast enough to convey fluent motion. It is typically pre-
compiled and non-interactive. The frame is typically rectangular and non-transparent.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 18
LECTURE NOTES on Computer Graphics and Multimedia

Frame animation with transparency information is also referred to as “cel” animation. In


traditional animation, a cel is a sheet of transparent acetate on which a single object (or
character) is drawn.

There are various software which are used to generate computer animations. Some of them
are:

Flash: Learning MacroMedia’s Flash can be quite complex, but you can do almost anything
with it. You can develop presentations, websites, portions of websites, games, or full-length
feature, animated cartoons. You can import just about anything into Flash. You can drop in
images of almost any file format, video clips, sounds and more. It is generally a 2D program.

Poser: Poser by Curious Labs Creates 3D complex models that you can view, from any angle,
distance or perspective. You can make the model look like anybody you want it to. For
instance, if you wanted to make a model that looks just like your Grandmother, you would
do it in Poser (the learning curve is vast). Taking that to another level, you could then
animate your Grandmother and make her run down a picture of a beach.

Education, Training, Entertainment and Computer Aided Design (CAD)

CAD (or CADD) is an acronym that, depending on who you ask, can stand for:

 Computer Aided Design.


 Computer Aided Drafting.
 Computer Assisted Design.
 Computer Assisted Drafting.
 Computer Assisted Design and Drafting.
 Computer Aided Design and Drafting.

In general acronym for CAD is Computer-Aided Design. In CAD interactive graphics is used to
design components and systems of mechanical, electrical, and electronic devices. Actually
CAD system is a combination of hardware and software that enables engineers and
architects to design everything from furniture to airplanes. In addition to the software, CAD
systems require a high-quality graphics monitor; a mouse, light pen or digitised tablets for
drawing; and a special printer or plotter for printing design specifications. CAD systems
allow an engineer to view a design from any angle with the push of a button and to zoom in
or out for close-ups and long-distance views. In addition, the computer keeps track of design
dependencies so that when the engineer changes one value, all other values that depend on
it are automatically changed accordingly. Generally we use CAD as a tool for imparting
education and training to the engineers, so that, they can produce beautifully carved and
engineered pieces in bulk with the same amount of finishing and perfection. Generally a few
terms are used repeatedly with CAD and they are CAM and CNC. Let us discuss “What are
CAD/CAM and CAD/CNC(or NC)”?
Dr. Ankur Pachauri
MCA Department RATM, Mathura Page 19
LECTURE NOTES on Computer Graphics and Multimedia

The term CAD/CAM is a shortening of Computer-Aided Design (CAD) and Computer-Aided


Manufacturing (CAM). The term CAD/NC (Numerical Control) is equivalent in some
industries. CAD/CAM software uses CAD drawing tools to describe geometries used by the
CAM portion of the program to define a tool path that will direct the motion of a machine
tool to machine the exact shape that is to be drawn on the computer. Let us discuss the
terms in brief.

Note:

Numerically-Controlled Machines: Before the development of Computer-aided design, the


manufacturing world adopted tools controlled by numbers and letters to fill the need for
manufacturing complex shapes in an accurate and repeatable manner. During the 1950s
these Numerically-Controlled machines used the existing technology of paper tapes with
regularly spaced holes punched in them (think of the paper roll that makes an old-fashioned
player piano work, but only one inch wide) to feed numbers into controller machines that
were wired to the motors positioning the work on machine tools. The electro-mechanical
nature of the controllers allowed digital technologies to be easily incorporated as they were
developed. NC tools immediately raised automation of manufacturing to a new level once
feedback loops were incorporated (the tool tells the computer where it is, while the
computer tells it where it should be). What finally made NC technology enormously
successful was the development of the universal NC programming language called APT
(Automatically Programmed Tools). Announced at MIT in 1962, APT allowed programmers
to develop postprocessors specific to each type of NC tool so that, the output from the APT
program could be shared among different parties with different manufacturing capabilities.

Now-a-days many new machine tools incorporate CNC technologies. These tools are used in
every conceivable manufacturing sector, like CNC technology is related to Computer
Integrated Manufacturing (CIM), Computer Aided Process Planning (CAPP) and other
technologies such as Group Technology (GT) and Cellular Manufacturing. Flexible
Manufacturing Systems (FMS) and Just-In- Time Production (JIT) are made possible by
Numerically-Controlled Machines.

CAD and CAM

The development of Computer-aided design had little effect on CNC initially due to the
different capabilities and file formats used by drawing and machining programs. However,
as CAD applications such as SolidWorks and AutoCad incorporate CAM intelligence, and as
CAM applications such as MasterCam adopt sophisticated CAD tools, both designers and
manufacturers are now enjoying an increasing variety of capable CAD/CAM software. Most
CAD/CAM software was developed for product development and the design and
manufacturing of components and moulds, but they are being used by architects with
greater frequency. Thus, a CAD program introduces the concept of real-world

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 20
LECTURE NOTES on Computer Graphics and Multimedia

measurement. For example, a car or building can be drawn as if it were life-size, and later
arranged into sheets and printed on paper at any desired scale.

Note:

1) CAD (or CADD) stands for Computer-Aided Design and Drafting. It differs from both
“paint” and “draw” programs in that (i.e., CAD) measurement is central to its abilities.
Whereas a “paint” program lets you manipulate each pixel in an array of pixels that
make up an image, and a “draw” program goes a step further – it is composed of
separate entities or objects, such as circles, lines, etc. It may provide facilities to group
these into any object.
2) Is CAD only useful for design drawings? No. While true-scale, structurally valid drawings
are the reason for CAD’s existence; its use is as diverse as our customer’s imaginations.
For instance, it may be used for:
a) page layout, web graphics (when scaling and relationships are important to an
image, making the image in CAD and exporting it as a bitmap for touch-up and
conversion can be very productive),
b) visually accessed databases (imagine a map with detail where you can zoom into
an area and edit textual information “in place” and you can then see what other
items of interest are “in the neighbourhood” - our program’s ability to work very
rapidly with large drawings is a real plus here),
c) sign layout, laser-cutting patterns for garment factories, schematic design (where
CAD’s symbol library capabilities come in handy), and printed-circuit board layout
(This was the application that our first CAD program, created in 1977).

Software packages for CAD applications typically provide designer with a multiwindow
environment. Animations are often used in CAD application; Real-time animations using
wire frame displays on a video monitor are useful for testing the performances of a vehicle
or a system. The inter frame system allows the user to study the interior of the vehicle and
its behaviour. When the study of behaviour is completed, realistic visualising models,
surface rendering are used for background scenes and realistic display. There are many CAD
software applications. Some of them with their respective vendors are listed below:

CAD Applications Scanner Vendor: Desktop

 AlphaCAM Canon
 Ashlar Vellum Epson
 AutoCAD Hewlett Packard
 CATIA/CADCAM UMAX

CAD Applications Scanner Vendor: Large Format

 Eagle point Action Imaging


Dr. Ankur Pachauri
MCA Department RATM, Mathura Page 21
LECTURE NOTES on Computer Graphics and Multimedia

 FastCAD Contex
 Pro/E Xerox
 FelixCAD Kip
 IntelliCAD Ricoh
 MasterCAM Vidar
 MasterStation Widecom

There are many more applications not listed in the list given above. These applications
replicate the old drafting board as a means to draw and create designs. As CAD applications
run on computers they provide a great deal more functionality than a drafting board, and a
great deal more complexity. The lines and text created in CAD are vectors. This means that
their shapes and positions are described in mathematical terms. These vectors are stored
on computer systems in CAD files. There are a great many different file formats for CAD.
Most CAD applications produce their own proprietary file format. The CAD applications from
AutoDesk Inc. are used widely. As a result their DWG format is very common. Many other
CAD applications from other vendors can produce and open DWG files, as well as their own
proprietary formats. CAD data is often exchanged using DXF format.

Note: The DWG file format is a CAD vector format developed by the Autodesk and created
by their AutoCAD application. DXF is also a CAD vector format. It is designed to allow the
exchange of vector information between different CAD applications. Most CAD applications
can save to and read from DXF format. When CAD drawings are sent to printers the format
commonly used is HPGL. HPGL files typically have the extension .plt.

Note: The HPGL file format is a vector format developed by Hewlett Packard for driving
plotters. The file extensions used include .plt, .hpg, .hp2, .pl2 and sometimes .prn. However,
the use of the .prn extension is not an absolute indicator that the file contains HPGL code.
They are often referred to as ‘plot files’. Trix Systems offers several options for handling
HPGL and the later HPGL2 file formats.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 22
LECTURE NOTES on Computer Graphics and Multimedia

GRAPHICS HARDWARE
No matter with which advance graphic software you are working with, if your output device
is not good, or hardware handling that software is not good, then ultimate result will be not
good, as it could be. We want to say, hardware also dominate the world of graphics. So, let
us discuss some hardware devices which help us to work with graphic packages.

Input and Output Devices

Input and Output devices are quite important for any software because an inappropriate
selection of the concerned hardware may produce some erroneous results or may process
data of some other format. So, in the following sections we have planned to discuss some of
the input and output devices such as:

 Touch Panel
 Light Pens
 Graphics Tablet
 Plotters

Touch Panels

Touch panels allow displayed object or screen positions to be selected with the touch of the
finger and is also known as Touch Sensitive Screens (TSS). A typical application of touch
panels is for the selection of processing options that are represented with graphical icons.
Optical touch panels employ a line of infrared LEDS (light emitting diodes) along one vertical
edge and along one horizontal edge of frame. The opposite vertical and horizontal edges
contain light detection. These detections are used to record the beams that may have been
interrupted when the panel was touched. Two crossing beams that are interrupted identify
the horizontal and vertical coordinates of screen position selected. An electrical touch panel
is constructed with two transparent plates separated by a short distance. One of the plates
is coated with a conducting material and the other is resistive material. When the outer
plate is touched, it is forced into contact with the inner plate. The contact creates a voltage
drop that is converted to a coordinate value of the selected screen position. They are not
too reliable or accurate, but are easy to use. Four types are commonly in use.

They are as follows:

1. Electrical TSS: Wire grid or other conductive coating is utilised to indicate a voltage
drop at the point touched point, from which the position may be determined.
2. Electro-Mechanical TSS: A glass or plastic sheet with strain gages placed around the
edges records the position by the relative magnitude of the deformation of the
slightly bent plate.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 23
LECTURE NOTES on Computer Graphics and Multimedia

3. Optical TSS: Infrared light from light-emitting diodes (LED) along two perpendicular
edges of the screen and detectors along the opposite edges provide an (invisible)
optical grid, with reference to which the finger’s position is determined.
4. Acoustic TSS: Inaudible high-frequency sound waves are emitted along two
perpendicular edges and reflected to the emitters by the finger; the echo interval is
used as a measure of the distances from the edges.

Light Pen

Light pen is a pointing device. It has a light sensitive tip which is excited when the light is
emitted and an illuminated point on the screen comes in its field of view. Unlike other
devices which have associated hardware to track the device and determine x and y values,
the light pen needs software support (some kind of tracking program). Pointing operations
are easily programmed for light pens. Figure below shows two typical applications of a light
pen. It has a light sensitive tip and a photocell mounted in a pen-like case. If the light pen is
pointed at an item on the screen it generates information from which the item can be
identified by the program. When the light pen senses an illuminated phosphor, it interrupts
the display processor’s interpreting of the file display. The processor’s instruction register
tells which instruction in the display file was being executed. By identifying the instruction
responsible for the illuminated point, the machine can discover which object the pen is
pointing to.

A light pen is an event driven device. The processor has to wait till it comes across an
illuminated point on the screen to obtain any information. The keyboard is another typical
example of an event driven device. The processor has to wait for a key to be pressed before
it can determine what the user wants to input. Event driven devices can be handled in two
ways as follows:

a) Polling: The status of each device is periodically checked in a repetitive manner by a


polling loop. When an event occurs, the loop is exited and the corresponding event is

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 24
LECTURE NOTES on Computer Graphics and Multimedia

handled by executing some special event-handling routine or task. Again the polling
continues. The disadvantage is that the processor has to wait in an idle state until
some event occurs. Data entered can be lost if an event occurs at a time when the
main program is not in its polling loop.
b) Interrupts: An alternative to polling is the interrupt feature. The device sends an
interrupt signal to the processor when an event occurs. The processor breaks from
its normal execution and executes some special interrupt-handling routine or task.
After the task is complete the control returns to the main program. To handle
situations when more than one event occurs, different priorities are assigned to
tasks so that higher priority tasks may interrupt tasks of lower priority.

Several events may occur before the program is ready for them. When more than one event
occurs, the associate information is entered into the event queue. A polling loop can be
employed to check the status of the event queue. The event queue can then pass input data
from the polling task to the main program in the correct order. The main program takes
events off the head of the queue and invokes the appropriate process. The devices need not
be checked repeatedly for occurrence of events. Devices can interrupt even with the
processor being unaware of it.

Two kinds of light pen interrupts may occur. If the user points the pen at an item on the
screen to select it, as in Figure (a) above, a selection interrupt occurs. If the user is
positioning with the pen, as in Figure (b) above a pattern called tracking pattern in displayed
along the pen’s movement and tracking interrupts occur when the pen sees the tracking
pattern. Modified versions of the light pen may also be used to draw lines, read barcodes, or
do transformation operations on objects on the screen (or on a tablet).

Graphics Tablet

Before going into details on the graphic tablet, we need to know what we mean by tablet in
computer terminology because, in other disciplines, the word tablet carries different
meanings. In terms of computer science “Tablet is a special flat surface with a mechanism
for indicating positions on it, normally used as a locator”. This small digitiser is used for
interactive work on a graphics workstation. Actually this device is essential when someone
wants to do free hand drawing or to trace any solid geometrical shape. So a graphic tablet
is a drawing tablet used for sketching new images or tracing old ones. Or we may say that
a graphics tablet is a computer input device that allows one to hand-draw images and
graphics, similar to the way one draws images with a pencil on paper. Or a Graphics tablet
is a computer peripheral device that allows one to hand images directly to a computer,
generally through an imaging program.

Graphics tablets consists of a flat surface upon which the user may ‘draw’ an image using an
attached pen-like drawing apparatus using which the user contacts the surface of the tablet,

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 25
LECTURE NOTES on Computer Graphics and Multimedia

this apparatus is categorised into two types known as pen (or stylus) and puck (a flat block
with cross-hairs and some switch keys), which may be wired or wireless. Often mistakenly
called a mouse, the puck is officially the “tablet cursor”. The image drawn or traced
generally does not appear on the tablet itself but rather is displayed on the computer
monitor. The tablet and a hand-held pointer in the form of a stylus (pen) or puck can serve
one or more of these three functions:

a) For selecting positions (on a drawing or on a menu) on the screen by moving the
stylus on the tablet, in a sense using the stylus and tablet as pen on paper.
b) For issuing a command or to input a parameter by pressing the stylus at specified
pre-programmed locations of a menu on the tablet.
c) For digitising the location on a drawing or map placed on the tablet with the stylus or
puck.

This device is more accurate and efficient than a light pen. These are two types in use:

(a) Voltage or Electro-Magnetic Field Tablet and Pointer: This has a grid of wires,
embedded in the tablet surface, with different voltages or magnetic fields
corresponding to different coordinates. Intermediate positions within a cell can
also be interpolated.
(b) Acoustic or Sonic (Radio-Wave) Tablet and Pointer: The sound of a spark at the
tip of the stylus is picked up by strip microphones along two edges of the tablet.
From the arrival time of the sound pulse at the microphones, the perpendicular
distances of the stylus tip from the two axes are known. The acoustic method
suffers from its inherent noisiness as well as its susceptibility to interference
from other noise.

A combination of electric pulses and time-delay detection by a sensor in the stylus, called
Electro-acoustic Table is also available.

When drawing or tracing on the tablet, a series of x-y coordinates (vector graphics) are
created, either as a continuous stream of coordinates, or as end points. Further the
drawings created or traced on tablets are stored as mathematical line segments; and these
features of tablets help to produce, tablet computers, tablet PCs and pen tablets.

Note: Objects are drawn with a pen (or stylus) or puck, but are traced with the puck only.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 26
LECTURE NOTES on Computer Graphics and Multimedia

Tablet Computer: A complete computer contained in a touch screen. Tablet computers can
be specialised for only Internet use or be full-blown, general-purpose PCs with all the bells
and whistles of a desktop unit. The distinguishing characteristic is the use of the screen as

an input device using a stylus or finger. In 2000, Microsoft began to promote a version of
Windows XP for tablet computers, branding them “Tablet PCs”.

Pen Tablet: A digitiser tablet that is specialised for handwriting and hand marking. LCD-

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 27
LECTURE NOTES on Computer Graphics and Multimedia

based tablets emulate the flow of ink as the tip touches the surface and pressure is applied.
Non-display tablets display the handwriting on a separate computer screen.

Plotter

A plotter is a vector graphics-printing device that connects to a computer. Now-a-days, we


use the plotter right from the field of engineering, to media and advertising. Even in our
day-to-day lives we see a large number of computer designed hoardings as publicity
material. This fine output is achieved by using plotters with computers. But the printer may
also be connected to the computer. The question then arises, as to how they differ from
each other. So let us discuss the differences between them.

1) Plotters print their output by moving a pen across the surface of a piece of paper.
This means that plotters are restricted to line art, rather than raster graphics as with
other printers. They can draw complex line art, including text, but do so very slowly
because of the mechanical movement of the pen.
2) Another difference between the plotter and the printer is that, the printer is aimed
primarily at printing text. Thus, the printer is enough to generate a page of output,
but this is not the case with the line art of the plotter.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 28
LECTURE NOTES on Computer Graphics and Multimedia

Display Devices
The principle of producing images as collections of discrete points set to appropriate colours
is now widespread throughout all fields of image production. The most common graphics
output device is the video monitor which is based on the standard cathode ray tube (CRT)
design, but several other technologies exist and solid state monitors may eventually
predominate.

Refresh CRT
Basic Operation of CRT

Figure below illustrates the basic operation of a CRT. A beam of electrons (cathode rays)
emitted by an electron gun, passes through focusing and deflection systems that direct the
beam toward specified positions on the phosphor-coated screen. The phosphor then emits a
small spot of light at each position contacted by the electron beam. Because the light
emitted by the phosphor fades very rapidly, some method is needed for maintaining the
screen picture. One Way to keep the phosphor glowing is to redraw the picture repeatedly
by quickly directing the electron beam back over the same points. This type of display is
called a refresh CRT.

Working

Beam passes between two pairs of metal plates, one vertical and other horizontal. A voltage
difference is applied to each pair of plates according to the amount that the beam is to be
deflected in each direction. As the electron beam passes between each pair of plates, it is
bent towards the plate with the higher positive voltage. In figure below the beam is first

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 29
LECTURE NOTES on Computer Graphics and Multimedia

deflected towards one side of the screen. Then, as the beam passes through the horizontal
plates, it is deflected towards, the top or bottom of the screen. To get the proper deflection,
adjust the current through coils placed around the outside of the CRT loop. The primary
components of an electron gun in a CRT are the heated metal cathode and a control grid.
Heat is supplied to the cathode by directing a current through a coil of wire, called the
filament, inside the cylindrical cathode structure. This causes electrons to be "boiled off" the
hot cathode surface. In the vacuum inside the CRT envelope, the free, negatively charged
electrons are then accelerated toward the phosphor coating by a high positive voltage. The
accelerating voltage can be generated with a positively charged metal coating on the in- side
of the CRT envelope near the phosphor screen, or an accelerating anode can be used, as in
Fig. below. Sometimes the electron gun is built to contain the accelerating anode and
focusing system within the same unit.

The focusing system in a CRT is needed to force the electron beam to converge into a small
spot as it strikes the phosphor. Otherwise, the electrons would repel each other, and the
beam would spread out as it approaches the screen. Focusing is accomplished with either
electric or magnetic fields. Electrostatic focusing is commonly used in television and
computer graphics monitors. With electrostatic focusing, the electron beam passes through
a positively charged metal cylinder that forms an electrostatic lens, as shown in Fig. below.
The action of the electrostatic lens focuses the electron beam at the centre of the screen, in
exactly the same way that an optical lens focuses a beam of light at a particular focal
distance. Similar lens focusing effects can be accomplished with a magnetic field set up by a
coil mounted around the outside of the CRT envelope. Magnetic lens focusing produces the
smallest spot size on the screen and is used in special-purpose devices.

As with focusing, deflection of the electron beam can be controlled either with electric fields
or with magnetic fields. Cathode-ray tubes are now commonly constructed with magnetic

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 30
LECTURE NOTES on Computer Graphics and Multimedia

deflection coils mounted on the outside of the CRT envelope, as illustrated in first Figure.
Two pairs of coils are used, with the coils in each pair mounted on opposite sides of the
neck of the CRT envelope. One pair is mounted on the top and bottom of the neck and the
other pair is mounted on opposite sides of the neck. The magnetic field produced by each
pair of coils results in a transverse deflection force that is perpendicular both to the
direction of the magnetic field and to the direction of travel of the electron beam.
Horizontal deflection is accomplished with one pair of coils, and vertical deflection by the
other pair. The proper deflection amounts are attained by adjusting the current through the
coils. When electrostatic deflection is used, two pairs of parallel plates are mounted inside
the CRT envelope. One pair of plates is mounted horizontally to control the vertical
deflection, and the other pair is mounted vertically to control horizontal deflection (Fig.
below).

Spots of light are produced on the screen by the transfer of the CRT beam energy to the
phosphor. When the electrons in the beam collide with the phosphor coating, they are
stopped and their kinetic energy is absorbed by the phosphor. Part of the beam energy is
converted by friction into heat energy, and the remainder causes electrons in the phosphor
atoms to move up to higher quantum-energy levels. After a short time, the "excited"
phosphor electrons begin dropping back to their stable ground state, giving up their extra
energy as small quantum of light energy. What we see on the screen is the combined effect
of all the electron light emissions: a glowing spot that quickly fades after all the excited
phosphor electrons have returned to their ground energy level. The frequency (or colour) of the light
emitted by the phosphor is proportional to the energy difference between the excited quantum
state and the ground state.

Figure sidewise shows the intensity distribution of a spot on the screen. The intensity is
greatest at the centre of the spot, and
decreases with a Gaussian
distribution out to the edges of the

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 31
LECTURE NOTES on Computer Graphics and Multimedia

spot. This distribution corresponds to the cross-sectional electron density distribution of the
CRT beam.

Resolution

The maximum number of points that can be displayed without overlap on a CRT is referred
to as the resolution. A more precise definition of resolution is the number of points per
centimeter that can be plotted horizontally and vertically, although it is often simply stated
as the total number of points in each direction. This depends on the type of phosphor used
and the focusing and deflection system.

Aspect Ratio

Another property of video monitors is aspect ratio. This number gives the ratio of vertical
points to horizontal points necessary to produce equal-length lines in both directions on
the screen. (Sometimes aspect ratio is stated in terms of the ratio of horizontal to vertical
points.) An aspect ratio of 3/4 means that a vertical line plotted with three points has the
same length as a horizontal line plotted with four points.

Random-Scan and Raster Scan Monitor

Random scan system uses an electron beam which operates like a pencil to create a line
image on the CRT. The image is constructed out of a sequence of straight line segments.
Each line segment is drawn on the screen by directing the beam to move from one point on
screen to the next, where each point is defined by its X and Y coordinates. After drawing the
picture, the system cycles back to the first line and design all the lines of the picture 30 to 60
time each second. When operated as a random-scan display unit, a CRT has the electron
beam directed only to the parts of the screen where a picture is to be drawn. Random-scan
monitors draw a picture one line at a time and for this reason are also referred to as vector
displays (or stroke-writing or calligraphic displays) Figure below A pen plotter operates in a
similar way and is an
example of a random-scan,
hard-copy device. Refresh
rate on a random-scan
system depends on the
number of lines to be
displayed. Picture definition
is now stored as a set of
line-drawing commands in
an area of memory referred
to as the refresh display file.
Random-scan systems are

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 32
LECTURE NOTES on Computer Graphics and Multimedia

designed for line-drawing applications and can-not display realistic shaded scenes. Since
picture definition is stored as a set of line-drawing instructions and not as a set of intensity
values for all screen points, vector displays generally have higher resolution than raster
systems. Also, vector displays produce smooth line drawings because the CRT beam directly
follows the line path.

Raster-Scan Displays

In raster scan approach, the viewing screen is divided into a large number of discrete
phosphor picture elements, called pixels. The matrix of pixels constitutes the raster. The
number of separate pixels in the raster
display might typically range from
256X256 to 1024X1024. Each pixel on
the screen can be made to glow with a
different brightness. Colour screen
provide for the pixels to have different
colours as well as brightness. In a
raster-scan system, the electron beam
is swept across the screen, one row at
a time from top to bottom. As the
electron beam moves across each row,
the beam intensity is turned on and
off to create a pattern of illuminated spots. Picture definition is stored in a memory area
called the refresh buffer or frame buffer. This memory area holds the set of intensity values
for all the screen points. Stored intensity values are then retrieved from the refresh buffer
and "painted" on the screen one row (scan line) at a time (Figure above). Each screen point
is referred to as a pixel or pel (shortened forms of picture element). The capability of a
raster-scan system
to store intensity
information for each
screen point makes
it well suited for the
realistic display of
scenes containing
subtle shading and
color patterns.
Home television sets
and printers are
examples of other
systems using raster-scan methods. Intensity range for pixel positions depends on the
capability of the raster system. In a simple black-and-white system, each screen point is

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 33
LECTURE NOTES on Computer Graphics and Multimedia

either on or off, so only one bit per pixel is needed to control the intensity of screen
positions. For a bi-level system, a bit value of 1 indicates that the electron beam is to be
turned on at that position, and a value of 0 indicates that the beam intensity is to be off.
Additional bits are needed when color and intensity variations can be displayed. On some
raster-scan systems (and in TV sets), each frame is displayed in two passes using an
interlaced refresh procedure. In the first pass, the beam sweeps across every other scan line
from top to bottom. Then after the vertical re- trace, the beam sweeps out the remaining
scan lines. Interlacing of the scan lines in this way allows us to see the entire screen
displayed in one-half the time it would have taken to sweep across all the lines at once from
top to bottom. Interlacing is primarily used with slower refreshing rates. On an older, 30
frame- per-seconds, noninterlaced display, for instance, some flicker is noticeable. But with
interlacing, each of the two passes can be accomplished in l/60th of a second, which brings
the refresh rate nearer to 60 frames per second. This is an effective technique for avoiding
flicker, providing that adjacent scan lines contain similar display information.

Color CRT Monitors

To display colour pictures, combination of phosphorus is used that emits different coloured
light. There are two different techniques for producing colour displays with a CRT.

 Beam Penetration Method


 Shadow Mask Method

Beam Penetration Method

The beam-penetration method for displaying color pictures has been used with random-
scan monitors. Two layers of phosphor, usually red and green, are coated onto the inside of
the CRT screen, and the displayed color depends on how far the electron beam penetrates
into the phosphor layers. A beam of slow electrons excites only the outer red layer. A beam
of very fast electrons penetrates through the red layer and excites the inner green layer. At
intermediate beam speeds, combinations of red and green light are emitted to show two
additional colors, orange and yellow. The speed of the electrons, and hence the screen color
at any point, is controlled by the beam-acceleration voltage. Beam penetration has been an
inexpensive way to produce color in random-scan monitors, but only four colors are
possible, and the quality of pictures is not as good as with other methods.

Shadow Mask Method

Shadow-mask methods are commonly used in raster-scan systems (including color TV)
because they produce a much wider range of colors than the beam-penetration method. A
shadow-mask CRT has three phosphor color dots at each pixel position. One phosphor dot
emits a red light, another emits a green light, and the third emits a blue light. This type of
CRT has three electron guns, one for each color dot, and a shadow-mask grid just behind the

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 34
LECTURE NOTES on Computer Graphics and Multimedia

phosphor-coated screen. Figure below illustrates the delta-delta shadow-mask method,


commonly used in color CRT- systems. The three electron beams are deflected and focused
as a group onto the shadow mask, which contains a series of holes aligned with the
phosphor-dot patterns. When the three beams passes through a hole 'in the shadow mask,
they activate a dot triangle, which appears as a small color spot on the screen. The
phosphor dots in the triangles are arranged so that each electron beam can activate only its
corresponding color dot when it passes through the shadow mask. Another configuration
for the three electron guns is an in-line arrangement in which the three electron guns, and
the. Corresponding red-green-blue color dots on the screen are aligned along one scan line
instead of in a triangular pattern. This in-line arrangement of electron guns is easier to keep
in alignment and is commonly used in high-resolution color CRTs.

We obtain color variations in a


shadow-mask CRT by varying
the intensity levels of the
three electron beams. By
turning off the red and green
guns, we get only the color
coming from the blue
phosphor. Other combinations
of beam intensities produce a
small light spot for each pixel
position, since our eyes tend
to merge the three colors into
one composite. The color we see depends on the amount of excitation of the red, green,
and blue phosphors. A white (or gray) area is the result of activating all three dots with
equal intensity. Yellow is produced with the green and red dots only, magenta is produced
with the blue and red dots, and cyan shows up when blue and green are activated equally.
In some low-cost systems, the electron beam can only be set to on or off, limiting displays to
eight colors. More sophisticated systems can set intermediate intensity levels for the
electron beams, allowing several million different colors to be generated.

Direct-View Storage Tubes (DVST)

This is an alternative method to monitor a screen image, as it sores the picture information
inside the CRT, instead of refreshing the screen. A direct-view storage tube (DVST) stores
the picture information as a charge distribution just behind the phosphor-coated screen.
Two electron guns are used in a DVST. One, the primary gun, is used to store the picture
pattern; the second, the flood gun, maintains the picture display. A DVST monitor has both
disadvantages and advantages compared to the refresh CRT. Because no refreshing is
needed, very complex pictures can be displayed at very high resolutions without flicker.
Disadvantages of DVST systems are that they ordinarily do not display color and that
Dr. Ankur Pachauri
MCA Department RATM, Mathura Page 35
LECTURE NOTES on Computer Graphics and Multimedia

selected parts of a picture cannot be erased. To eliminate a picture section, the entire
screen must be erased and the modified picture redrawn. The erasing and redrawing
process can take several seconds for a complex picture. For these reasons, storage displays
have been largely replaced by raster systems.

Flat-Panel Displays

The term flat panel display refers to a class of video device that have reduced volume,
weight and power requirement compared to a CRT. A significant feature of flat-panel
displays is that they are thinner than CRTs, and we can hang them on walls or wear them on
our wrists. Since we can even write on some flat-panel displays, they will soon be available
as pocket notepads. Current uses for flat-panel displays include small TV monitors,
calculators, pocket video games, laptop computers, armrest viewing of movies on airlines,
as advertisement boards in elevators, and as graphics displays in applications requiring
rugged, portable monitors.

We can separate flat-panel displays into two categories:

 Emissive displays
 Nonemissive displays.

The emissive displays (or emitters) are devices that convert electrical energy into light.
Plasma panels, thin-film electroluminescent displays, and- light-emitting diodes are
examples of emissive displays. Flat CRTs have also been devised, in which electron beams
are accelerated parallel to the screen, then deflected 90° to the screen. But flat CRTs have
not proved to be as successful as other emissive devices.

Nonemmissive displays (or nonemitters) use optical effects to convert sunlight or light from
some other source into graphics patterns. The most important example of a nonemissive
flat-panel display is a liquid-crystal device.

Light-emitting Diode (LED)

In LED, a matrix of diodes is arranged to form the pixel positions in the display and picture
definition is stored in a refresh buffer. Information is read from the refresh buffer and
converted to voltage levels that are applied to the diodes to produce the light patterns in
the display.

Liquid-crystal Displays (LCDs)

Liquid crystal displays are the devices that produce a picture by passing polarized light
from the surroundings or from an internal light source through a liquid crystal material
that transmit the light. Liquid-crystal displays (LCDs) are commonly used in small systems,
such as calculators and portable, laptop computers. These non-emissive devices produce a

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 36
LECTURE NOTES on Computer Graphics and Multimedia

picture by passing polarized light from the surroundings or from an internal light source
through a liquid-crystal material that can be aligned to either block or transmit the light.

The term liquid crystal refers to the fact that these compounds have a crystalline
arrangement of molecules, yet
they flow like a liquid. Flat-
panel displays commonly use
Nematic (threadlike) liquid-
crystal compounds that tend
to keep the long axes of the
rod-shaped molecules aligned.
A flat-panel display can then
be constructed with a nematic
liquid crystal, as demonstrated
in Figure here. Two glass
plates, each containing a light
polarizer at right angles to the
other plate, sandwich the
liquid-crystal material. Rows
of horizontal transparent
conductors are built into one
glass plate, and columns of
vertical conductors are put into the other plate. The intersection of two conductors defines
a pixel position. Normally, the molecules are aligned as shown in the "on state" of Figure
above Polarized light passing through the material is twisted so that it will pass through the
opposite polarizer. The light is then reflected back to the viewer. To turn off the pixel, we
apply a voltage to the two intersecting conductors to align the molecules so that the light is
not twisted. This type of flat-panel device is referred to as a passive-matrix LCD. Picture
definitions are stored in a refresh buffer, and the screen is refreshed at the rate of 60
frames per second, as in the emissive devices. Back lighting is also commonly applied using
solid-state electronic devices, so that the system is not completely dependent on outside
light sources. Colors can be displayed by using different materials or dyes and by placing a
triad of color pixels at each screen location. Another method for constructing LCDs is to
place a transistor at each pixel location, using thin-film transistor technology. The transistors
are used to control the voltage at pixel locations and to prevent charge from gradually
leaking out of the liquid-crystal cells. These devices are called active-matrix displays.

Hard Copy Devices

The printer is an important accessory of any computing system. In a graphics system, it is


the quality of printed output which is one of the key factors necessary to convince both the

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 37
LECTURE NOTES on Computer Graphics and Multimedia

user and the customer. The major factors which control the quality of a printer are
individual dot size on the paper and the number of dots per inch.

We can obtain hard-copy output for our images in several formats. For presentations or
archiving, we can send image files to devices or service bureaus that will produce 35-mm
slides or overhead transparencies. To put images on film, we can simply photograph a scene
displayed on a video monitor. And we can put our pictures on paper by directing graphics
output to a printer or plotter.

Printers produce output by either impact or nonimpact methods. Impact printers press
formed character faces against an inked ribbon onto the paper. A line printer is an example
of an impact device, with the typefaces mounted on bands, chains, drums, or wheels.
Nonimpact printers and plotters use laser techniques, ink-jet sprays, xerographic processes
(as used in photocopying machines), electrostatic methods, and electrothermal methods to
get images onto paper.

In a laser device, a laser beam creates a charge distribution on a rotating drum coated with
a photoelectric material, such as selenium. Toner is applied to the drum and then
transferred to paper. Ink-jet methods produce output by squirting ink in horizontal rows
across a roll of paper wrapped on a drum. The electrically charged ink stream is deflected by
an electric field to produce dot-matrix patterns.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 38
LECTURE NOTES on Computer Graphics and Multimedia

Scan Conversion
Introduction

We have studied various display devices. It is clear that these devices need special
procedures for displaying any graphic object: line, circle, curves, and even characters.
Irrespective of the procedures used, the system can generate the images on these raster
devices by turning the pixels on or off. The process in which the object is represented as the
collection of discrete pixels is called scan conversion. The video output circuitry of a
computer is capable of converting binary values stored in its display memory into pixel-on,
pixel-off information that can be used by a raster output device to display a point. This
ability allows graphics computers to display models composed of discrete dots. Almost any
model can be reproduced with a sufficiently dense matrix of dots (pointillism), most human
operators generally think in terms of more complex graphics objects such as points, lines,
circles and ellipses. Since the inception of computer graphics, many algorithms have been
developed to provide human users with fast, memory-efficient routines that generate
higher-level objects of this kind. However, regardless of what routines are developed, the
computer can produce images on raster devices only by turning the appropriate pixels on or
off. Many scan-conversion algorithms are implemented in computer hardware or firmware.
However, a specific graphics algorithm, the scan-conversion algorithm can be implemented
in software. The most commonly used graphics objects are the line, the sector, the arc, the
ellipse, the rectangle and the polygon.

Scan-converting a Point

We have already defined that a pixel is collection of number of points. Thus it does not
represent any mathematical point. Suppose we wish to display a point C(5.4, 6.5). It means
that we wish to illuminate that pixel, which contains this point C. What happens if we try to
display C’(5.3, 6.4)? Well, it also corresponding to the same pixel as that of C(5.4, 6.5).Thus
we can say that point C(x, y) is represented by an integer part of X and integer part of Y. So,
we can use the command as

Putpixel(int x, int y);

We will now look into the actual process of plotting a point.

We normally use right handed Cartesian coordinate system. The origin in this system starts
at the bottom. However in case of computer system, due to the memory organization, the
system turns out to left handed Cartesian system. Thus there is a difference in the actual
representation and the way in which we work with the points.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 39
LECTURE NOTES on Computer Graphics and Multimedia

The basic steps involved in converting Cartesian coordinate system to the system
understandable points are:

Step 1: Identify the starting address corresponding to the line on which the point is
to be displayed.
Step 2: Find the byte address in which the point is to be displayed.
Step 3: Compute the value for the byte that represents the point.
Step 4: Logically OR the calculated value with the present value of the byte.
Step 5: Store the value found in step 4 in the byte found in steps 1 and 2.
Step 6: Stop.

Scan-converting a Straight Line

A scan conversion of line locates the coordinates of the pixels lie on or near an ideal straight
line impaired on 2D raster grid. Before discussing the various methods, let us see what the
characteristics of line are. One expects the following features of line:

1. The line should appear straight line.


2. The line should have equal brightness throughout their length.
3. The line must be drawn rapidly.

Even though the rasterization tries to generate a completely straight line, yet in few cases
we may not get equal brightness. Basically, the lines which are horizontal or vertical or
oriented by 450, have equal brightness. But for the lines with larger length and different
orientations, we need to have complex computations in our algorithms. This may reduce the
speed of generation of line. Thus we make some sort of compromise while generating the
lines, such as:

1. Calculate only the approximate line length.


2. Make use of simple arithmetic computations, preferably integer arithmetic.
3. Implement result in hardware or firmware.

A straight line may be defined by two endpoints and an equation. The two endpoints are
described by (x1, y1) and (x2, y2). The equation of the line is used to describe the x, y
coordinates of all the points that lie between these two endpoints. Using the equation of a
straight line, y = mx + b where m = Δy/Δx and b = y intercept, we can find values of y by
incrementing x = x1 to x = x2. By scan-converting these calculated x = x2. By scan-converting
these calculated x, y values, we represent the line as a sequence on pixels.

While this method of scan-converting a straight line is adequate for many graphics
applications, interactive graphics systems require a much faster response than the method
described above can provide. Interactive graphics is a graphics system in which the user
dynamically controls the presentation of graphics models on a computer display.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 40
LECTURE NOTES on Computer Graphics and Multimedia

Direct Use of Line Equation

A simple approach to scan-converting a line is to first scan-convert P1 and P2 to pixel


coordinates (x’1, y’1) and (x’2, y’2), respectively; then set m = (y’2 - y’1)/ (x’2 - x’1) and b = y’1 –
mx’1. If [m] then for every integer value of x between and excluding x’,1≤ 1 and x’2, calculate
the corresponding value of y using the equation and scan-convert (x, y). If [m] > 1, then for
every integer value of y between and excluding y’1 and y’2 calculate the corresponding value
of x using the equation and scan-convert (x, y).

While this approach is mathematically sound, it involves floating-point computation


(multiplication and addition) in every step that uses the line equation since m and b are
generally real numbers. The challenge is to find a way to achieve the same goal as quickly as
possible.

DDA Algorithm

This algorithm works on the principle of obtaining the successive pixel values based on the
differential equation governing the line. Since screen pixels are referred with integer values,
or plotted positions, which may only approximate the calculated coordinates – i.e., pixels
which are intensified are those which lie very close to the line path if not exactly on the line
path which in this case are perfectly horizontal, vertical or 45° lines only. Standard
algorithms are available to determine which pixels provide the best approximation to the
desired line, one such algorithm is the DDA (Digital Differential Analyser) algorithm. Before
going to the details of the algorithm, let us discuss some general appearances of the line
segment, because the respective appearance decides which pixels are to be intensified. It is
also obvious that only those pixels that lie very close to the line path are to be intensified
because they are the ones which best approximate the line. Apart from the exact situation

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 41
LECTURE NOTES on Computer Graphics and Multimedia

of the line path, which in this case are perfectly horizontal, vertical or 45° lines (i.e., slope
zero, infinite, one) only. We may also face a situation where the slope of the line is >1 or <1.
Which is the case shown in Figure above.

In Figure, there are two lines. Line 1 (slope<1) and line 2 (slope>1). Now let us discuss the
general mechanism of construction of these two lines with the DDA algorithm. As the slope
of the line is a crucial factor in its construction, let us consider the algorithm in two cases
depending on the slope of the line whether it is > 1 or < 1.

Case 1: slope (m) of line is < 1 (i.e., line 1): In this case to plot the line we have to move the
direction of pixel in x by 1 unit every time and then hunt for the pixel value of the y direction
which best suits the line and lighten that pixel in order to plot the line.

So, in Case 1 i.e., 0 < m < 1 where x is to be increased then by 1 unit every time and proper
y is approximated.

Case 2: slope (m) of line is > 1 (i.e., line 2) if m > 1 i.e., case of line 2, then the most
appropriate strategy would be to move towards the y direction by 1 unit every time and
determine the pixel in x direction which best suits the line and get that pixel lightened to
plot the line.

So, in Case 2, i.e., (infinity) > m > 1 where y is to be increased by 1 unit every time and
proper x is approximated.

Assumption: The line generation through DDA is discussed only for the Ist Quadrant, if the
line lies in any other quadrant then apply respective transformation (generally reflection
transformation), such that it lies in Ist Quadrant and then proceed with the algorithm, also
make intercept Zero by translational transformation such that (xi, yi) resolves to (xi, mxi + c)
or (xi, mxi) and similar simplification occurs for other cases of line generation.

Note:

1) If in case 1, we plot the line the other way round i.e., moving in y direction by 1 unit every
time and then hunting for x direction pixel which best suits the line. In this case, every time
we look for the x pixel, it will provide more than one choice of pixel and thus enhances the
defect of the stair case effect in line generation. Additionally, from the Figure above, you
may notice that in the other way round strategy for plotting line 1, the vertical span is quite
less in comparison to the horizontal span. Thus, a lesser number of pixels are to be made
ON, and will be available if we increase Y in unit step and approximate X. But more pixels
will be available if we increase X in unit steps and approximate Y (this choice will also reduce
staircase effect distortion in line generation) (therefore more motion is to be made along x-
axis).

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 42
LECTURE NOTES on Computer Graphics and Multimedia

2) Consider a line to be generated from (X0, Y0) to (X1, Y1). If (X1 – X0 > Y1 – Y0 ) and X1 – X0 > 0
then slope (m) of line is < 1 hence case 1 for line generation is applicable otherwise case 2,
i.e., If (X1 – X0 < Y1 – Y0 ) and X1-X0 < 0 then slope m > 1 and case 2 of line generation is
applicable.

Important: Assume that X1>X0 is true else swap (X0, Y0) and (X1, Y1)

3) When 0 < m < 1: increment X in unit steps and approximate Y

Unit increment should be iterative ⇒ xi = (xi – 1) + 1 such that (xi, yi) resolves to (xi,
mxi + c) or (xi, mxi). It is to be noted that while calculating yi , if yi turned out to be a
floating number then we round its value to select the approximating pixel. This
rounding off feature contributes to the staircase effect.

When (infinity) > m > 1 increment Y in unit steps and approximate X, simplify (xi, yi)
accordingly.

Case 1: slope (m) of line is < 1 (or 0 < m < 1)

Consider a line to be generated from (X0, Y0) to (X1, Y1) , Assume that X1>X0 is true else swap
(X0, Y0) and (X1, Y1). Now, if (X1 – X0 > Y1 – Y0) that means slope (m) of line is < 1 hence, case
1 for line generation is applicable. Thus, we need to increment X in unit steps and
approximate Y. So, from X0 to X1 , xi is incremented in unit steps in the horizontal direction,
now for these unit steps the satisfying value of Y can be estimated by the general equation
of line y = mx + c. Similarly, for case 2, let us sum up our discussion on DDA algorithm for
both cases. We will examine each case separately.

Sum up:

For instance, in a given


line the end points are
(X0, Y0) and (X1, Y1). Using
these end points we find
the slope (m = Y1 – Y0/ X1
– X0) and check that the
value of m lies between
0 and 1 or is > 1. If 0 < m
< 1 then case 1 applies, else, case 2 applies. For case 1, increase x by one Unit every time,
for case 2 increase y by one Unit every time and approximate respective values of y and x.

We assume equation of line is y = mx+c


At x = xi we have yi = mxi+c
Similarly at x = xi + 1 we have yi + 1 = mxi + 1 +c

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 43
LECTURE NOTES on Computer Graphics and Multimedia

(xi = x0 x1 x2 x3------------------- xn = X1)


(x0, y0)
(x1, y1)
Case 1: Slope (m) of line is 0 < m1 (i.e., line 1)
Since x is to be increase by 1 unit each time
⇒ xi + 1 = xi + 1 ----------- (1)
So by using equation of line y = mx+c we have
yi + 1 = m (xi + 1) +c
= mxi +c + m
= yi + m ------------ (2)

Equations (1) and (2) imply that to approximate line for case 1 we have to move along x
direction by 1 unit to have next value of x and we have to add slope m to initial y value to
get next value of y. Now, using the starting point (x0, y0) in the above equations (1) and (2)
we go for xi and yi (i = 1, 2, ……n) and put colour to the pixel to be lightened.

It is assumed that X0 < X1 ∴the algorithm goes like:

x ← X0
y ← Y0
m ← (Y1 – Y0)/ (X1 – X0)
while (x < = X1) do
{
put-pixel (x, round (y), color)
(new x-value) x ← (old x-value) x + 1
(new y-axis) y ← (old y-value) y + m
}
Sample execution of algorithm case 1:
at (x0, y0) : put-pixel (x0, y0, colour)
x1 = x0 + 1; y1 = y0 + m
at (x1, y1) = put pixel (x1, y1, colour)
similarly, x2 = x1 + 1; y2 = y1 + m
at (x2, y2) : put pixel (x2, y2, colour) and so on.
Case 2: slope (m) of line is > 1 (i.e., line 2): Same as case 1 but, this time, the y component is
increased by one unit each time and appropriate x component is to be selected. To do the
task of appropriate selection of x component we use the equation of Line: y = mx+c.
Unit increment should be iterative ⇒ yi+1 = yi + 1 ; for this yi+1 we find corresponding xi+1 by
using equation of line y = mx + c and hence get next points
(xi+1, yi+1).
⇒ yi + 1 – yi = m (xi + 1 – xi) ----------- (3)
as y is to be increase by unit steps

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 44
LECTURE NOTES on Computer Graphics and Multimedia

∴yi + 1 – yi = 1 ----------- (4)


using equation (4) in (3) we get
⇒ l = m (xi + 1 – xi) ----------- (5)
rearranging (5) we get
⇒ 1/m = (xi + 1 – xi)
xi + 1 = xi +(1/m)

So, procedure as a whole for Case 2 is summed up as Algorithm case 2:


Assuming Y0 < Y1 the algorithm goes like
Algorithm for case 2:
x ← X 0;
y ← Y0;
m ← (Y1 – Y0)/ (X1 – X0);
m1 ← 1/m;
while (y < Y1) do
{
put-pixel (round (x), y, colour)
y ← y + 1;
x ← x + m1;
X
}

Bresenham’s Line Algorithm

Bresenham's line-drawing algorithm uses an iterative scheme. A pixel is plotted at the


starting coordinate of the line, and each iteration of the algorithm increments the pixel one
unit along the major, or x-axis. The pixel is incremented along the minor, or y-axis, only
when a decision variable (based on the slope of the line) changes sign. A key feature of the
algorithm is that it
requires only integer data
and simple arithmetic.
This makes the algorithm
very efficient and fast.
This algorithm scan
converts lines using only
incremental integer
calculations and these
calculations can also be
adopted to display circles
and other curves.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 45
LECTURE NOTES on Computer Graphics and Multimedia

Sampling at Unit x distance in above Figure, we need to decide which of the two possible
pixel position is closer to the line path at each sample step. In l1: we need to decide that at
next sample position whether to plot the pixel at position (11, 11) or at (11, 12). Similarly, In
l2: the next pixel has to be (11, 13) or (11, 12) or what choice of pixel is to be made to draw
a line is given by Bresenham, by testing the sign of the integer parameter whose value is
proportional to the difference between the separation of the two pixel positions from actual
line path. We will discuss the Bresenham line drawing algorithm for +Ve slope (0<m<1). If
the slope is negative then, use reflection transformation to transform the line segment with
negative slope to line segment with positive slope. Now, let us discuss the generation of line
again in two situations as in the case of DDA line generation.

Case 1: Scan Conversion of Line with the slope (0 < m < 1)

Here the pixel positions along the line path are determined by sampling at Unit x intervals
i.e., starting from the initial point. (x0, y0) of a given line we step to each successive column.
(i.e., x-position) and plot
the pixel whose scanline y
value is closest to the line
path. Assume we proceed
in this fashion up to the kth
step. The process is shown
in Figure. Assuming we
have determined the pixel
at (xk, yk). We need to
decide which pixel is to be
plotted in column xk+ 1. Our
choices are either (xk +1, yk) or (xk + 1, yk + 1).

At sampling position Xk + 1 the vertical pixel (or scan line) separation from mathematical line
(y = mx + c) is say d1 and d2.

Now, the y coordinate on the mathematical line at pixel column position Xk + 1 is:
y = m (xk + 1) + c ---------------------(1)
by Figure: d1 = y – yk ---------------------(2)
d1 = m (xk + 1) + c – yk ---------------------(3) (using (1))
similarly, d2 = (yk + 1) – y = yk + 1 – m (xk + 1) - c ---------------------(4)
using (3) and (4) we find d1 – d2
d1 – d2 = [m (xk + 1) + c – yk]–[yk + 1 – m (xk + 1) – c] = [m (xk + 1) + c – yk] – [yk + 1 – m (xk + 1) – c]
= mxk + m + c – yk – yk - 1 + mxk + m + c
= 2m (xk + 1) – 2yk + 2c – 1 ---------------------(5)
Say, decision parameter p for kth step i.e., pk is given by
pk = Δx(d1 – d2) ---------------------(6)

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 46
LECTURE NOTES on Computer Graphics and Multimedia

Now, a decision parameter pk for the kth step in the line algorithm can be obtained by
rearranging (5) such that it involves only integer calculations. To accomplish this substitute
m = Δy/Δx where, Δy and Δx ⇒ vertical and horizontal separations of the end point
positions.
pk = Δx (d1 – d2) = Δ x [2m (xk + 1) – 2yk + 2c – 1]
= Δx [2(Δy/Δx) (xk + 1) – 2yk + 2c – 1]
= 2 Δy (xk + 1) – 2 Δxyk + 2 Δxc – Δx
= 2 Δy xk – 2 Δx yk + [2 Δy + Δx (2c – 1)]
pk = 2 Δy xk – 2Δxyk + b -------------------- (7)
Where b is constant with value b = 2Δy + Δx (2c – 1) ---------------------(8)

Note: sign of pk is same as sign of d1 – d2 since it is assumed that Δx > 0 [As in Figure above,
d1 < d2 i.e. (d1 – d2) is –Ve i.e., pk is –Ve so pixel Ti is more appropriate choice otherwise pixel
Si is the appropriate choice. i.e., (1) if pk < 0 choose Ti , so next pixel choice after (xk, yk) is (xk
+ 1, yk) else (2) if pk > 0 choose Si , so next pixel choice after (xk , yk ) is (xk + 1, yk + 1).

At step k + 1 the decision parameter is evaluated by writing (7) as:


pk + 1 = 2Δy xk + 1 – 2Δx yk + 1 + b ---------------------(9)

Subtracting (7) from (9) we get

pk + 1 – pk = 2Δy( xk + 1 – xk ) – 2Δx ( yk + 1 – yk ) =2Δy – 2Δx (yk + 1 – yk)


xk + 1 – xk = 1 and yk + 1 – yk = 0 or 1

This recursive calculation of decision parameter is preformed at each integer position,


beginning with the left coordinate end point of line. This first parameter p0 is determined by
using equation (7), and (8) at the starting pixel position (x0, y0) with m evaluated as Δy /Δx
(i.e., intercept c = 0)

p0 = 0 – 0 + b = 2Δy + Δx (2 * 0 – 1) = 2Δy – Δx
p0 = 2Δy – Δx

Summary:

(Bresenham line drawing algorithm for +ve slope ( 0 < m < 1).
 If slope is negative then use reflection transformation to transform the line segment
with negative slope to line segment with a positive slope.
 Calculate constants 2Δy, 2Δy – 2Δx, Δy, Δx at once for each line to be scan
converted, so the arithmetic involves only integer addition/subtraction of these
constants.

Remark: The algorithm will be exactly the same if we assume | m | < 1

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 47
LECTURE NOTES on Computer Graphics and Multimedia

Algorithm | m | < 1:

a) Input two line end points and store left end point in (x0, y0)
b) Load (x0, y0) on frame buffer i.e., plot the first point.
c) Calculate Δx, Δy, 2Δy, 2Δy – 2Δx and obtain the starting value of decision
parameter as p0 = 2Δy – Δx
d) At each xk along the line, starting at k = 0, perform following test: if pk < 0, the next plot
is (xk + 1, yk) and pk + 1 = pk + 2Δy else next plot is (xk + 1 , yk + 1) and pk + 1 = pk + 2(Δy – Δx)
e) Repeat step (d) Δx times.

Bresenham Line Generation Algorithm (| m | < 1)

Δ x ← x1 – x0
Δ y ← y1 – y0
p0 ← 2Δy – Δx
while (x0 < = x1) do
{
puton (x0, y0)
if (pi > 0) then
{
x0 ← x0 + 1;
y0 ← y0 + 1;
pi + 1 ← pi + 2 (Δy – Δx);
}
if (pi < 0) then
{
x0 ← x0 + 1
y0 ← y0
pi + 1 ← pi + 2 Δy
}
}
Note:
 Bresenhams algorithm is generalised to lines with arbitrary slopes by considering the
symmetry between the various octants and quadrants of the coordinate system.
 For line with +ve slope (m) such that m > 1, then we interchange the roles of x and y
direction i.e., we step along y directions in unit steps and calculate successive x values
nearest the line path.
 for –ve slopes the procedures are similar except that now, one coordinate decreases as
the other increases.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 48
LECTURE NOTES on Computer Graphics and Multimedia

Mid Point Line Algorithms:

Let 0<m<1 consider line y=dy/dx(x)+B


F(x,y)=0 :(x,y)On the line
F(x,y)>0 :(x,y) Before the line
F(x,y)<0 :(x,y) Above the line
So y=dy/dx(x)+B

We Consider

F(x,y)=ax+by+c=0

=xdy-ydx+Bdx=0
=a=dy,b=-dx,c=Bdx
F(M)=F(xp+1,yp+1/2)=d
d=a(xp+1)+b(yp+1/2)+c
if d>0, M is before the line(chose Upper Pixel)
if d<0, M is above the line(chose lower Pixel)

Moving Forward

When E

dnew=F(M’)=F(xp+2,yp+1/2)

dnew=a(xp+2)+b(yp+1/2)+c
dold=a(xp+1)+b(yp+1/2)+c
DE=dnew-dold=a=dy

When NE

dnew=F(m”)=F(xp+2,yp+3/2)

dnew=a(xp+2)+b(yp+3/2)+c
dold=a(xp+1)+b(yp+1/2)+c
DNE=dnew-dold=a+b=dy-dx

At start (initial point)

dstart=F(x0+1,y0+1/2)=a(x0+1)+b(y0+1/2)+c
dstart=ax0+by0+c+a+b/2 [x0,y0 lies on line so F(x,y)=0]
dstart=a+b/2=dy-dx/2(Diversion)
F(x,y)=2(ax+by+c)

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 49
LECTURE NOTES on Computer Graphics and Multimedia

Algorithms:

dx=x2-x1, dy=y2-y1
d=2dy-dx, DE=2dy,DNE=2(dy-dx)
x=x1 , y=y1
Write Pixel(x,y)
While(x<x2)
{
If d<=0
{
d+=DE;
x+=1
}

Else
{
d+=DNE
x+=1
y+=1
}
Write Pixel(x,y)
} end while

Midpoint Circle Algorithms:

X2+y2=r2
Consider 2nd Octant

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 50
LECTURE NOTES on Computer Graphics and Multimedia

F(x,y)=x2+y2-r2
For a given point (x,y)
F(x,y)=0(x,y) On the circle
F(x,y)>0(x,y):Outside the circle
F(x,y)=<0 (x,y):Inside the circle

Evaluate F (M)

It < 0(M inside circle)


Choose E
It >0(M outside circle)
Choose SE

When E

dold=F(m)=F(xp+1,yp-1/2)

=(xp+1)2+(yp-1/2)2-r2

When E(dold<0)

dnew=F(M’)=F(xp+2,yp-1/2)
=(xp+2)2+(yp-1/2)2-r2
DE= dnew-dold=2xp+3

When SE (dold>=0)

dnew=F(M”)=F(xp+2,yp-3/2)

=(xp+2)2+(yp-3/2)2-r2
DES=dnew-dold=2xp-2yp+S

Initial condition

(0,R) start point

Next mid point=(1,R-1/2)


F(1,R-1/2)=S/4-R

Algorithms:

x0=0, y=R, d=3/4-R (D=1-R)

Write Pixel(x,y)
While(y>x) do //2nd octant condition check
If(d<0) // D<-1/4

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 51
LECTURE NOTES on Computer Graphics and Multimedia

d+=2x+3, x+=1
else
d+=2x-2y+5, x+=1, y-=1
end
Write Pixel(x,y)
End while

Mid Point ellipse Drawing Algorithms:

F(x,y)=b2x2+a2y2-a2b2
F(x,y)=0 (x,y):on the Boundary Ellipse
F(x,y)<0 (x,y): Is inside Ellipse
F(x,y)>0 (x,y): is Outside Ellipse
dy/dx=-2b2x/2a2y

In Region One (1)


When E
d’old =F(xp+1,yp-1/2)
=b2(xp+1)2+a2(yp-
1/2)2-a2b2

When EF(M’)

d’new= F(xp+2,yp-1/2)
= b2(xp+2)2+a2(yp-1/2)2-a2b2

When SE

d’new=F(M”)=F(x+2),(yp-3/2)
= b2(xp+2)2+a2(yp-3/2)2-a2b2
DSE= d’new - d’old =2b2(xp+1)+b2-(2a2yp-3/2)
DE= d’new - d’old =2b2(xp+1)+b2

Initial condition (a,b) start point


New Mid Point (1,b-1/2) so
F(1,b-1/2)=b2-a2b+1/2a2

In Region Two (2)

d2old=F(M)=F(xp+1/2,yp-1)
d2old =b2(xp+1/2)2+a2(yp-1)2-a2b2

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 52
LECTURE NOTES on Computer Graphics and Multimedia

When S F(M’) (When d2old>0)

d2old =F(M’)
=F(xp+3/2)+y(k)
=b2(xp+3/2)a2ypk-a2b2

When SE F(M”)(d2old<=0)

D2new=F(M”)=F[(xp+3/2),(yp+1/2)]
=b2(xp+3/2)2+a2(yp+1)2-b2a2
DES=2b2(xp+1)-2a2(yp+1)+a2
DE=d2new-d2old
=-2a2(yp+1)+a2
Initial condition is the initial position is the last position of region One(1)

F(x0+1/2,y0-1)=b2(x0+1/2)+a2(y0-1)2-a2b2
}
Repeat until 2b2x >= 2a2y

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 53
LECTURE NOTES on Computer Graphics and Multimedia

POLYGON FILLING ALGORITHM

In many graphics displays, it becomes necessary to distinguish between various regions by


filling them with different colour or at least by different shades of gray. There are various
methods of filling a closed region with a specified colour or equivalent gray scale. The most
general classification appears to be through following algorithms:

 Scan Line polygon fill algorithm.


 Seed fill algorithm./Flood fill algorithm which are further classified as:
o Boundary fill algorithm
o Interior fill algorithm

Scan Line Polygon Fill Algorithm

In this, the information for a solid body is stored in the frame buffer and using that
information all pixels i.e., of both boundary and interior region are identified and, are hence
plotted. Here we are going to do scan
conversion of solid areas where the
region is bounded by polygonal lines.
Pixels are identified for the interior of
the polygonal region, and are then filled
plotted with the predefined colour. Let
us discuss the algorithm briefly, and then
we will go into details on the same.

This algorithm checks and alters the


attributes (i.e., characteristics and parameters) of the pixels along the current raster scan
line. As soon as it crosses over from the outside to the inside of a boundary of the specified
polygon it starts resetting the colour (or gray) attribute. In effect filling the region along that
scan line. It changes back to the original attribute when it crosses the boundary again.
Figure above shows variations of this basic idea.

So as to understand Scan Line Polygon Fill Algorithm in detail consider Figure below

Here, in Figure below,

 yk, yk – 1,….. → are scan lines from top to bottom (value of y at top or scan line at top
has maximum value and the scan line at bottom has minimum y value).

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 54
LECTURE NOTES on Computer Graphics and Multimedia

 xk, xk + 1…..→are consecutive pixels on a scan line i.e., (xk,yk), (xk+1,yk ),…………⇒ a sea
of pixels for scan lines yk,
yk – 1, yk – 2, ….., yi and for
the chosen scan line we
find pixels satisfying the
condition as mentioned
above.
 For a given scan line, let
us assume that it
intersects edges of the
given polygonal region at
the points P1, P2, …, Pk.
Sort these points P1, P2,
…, Pk in terms of the X-coordinates in increasing order.

Now, for a chosen scan line there are three cases:

 Scan line passes through the edges in between shown by point “a” in Figure below.
 Scan line passes through the vertex of the polygon whose neighbouring vertices lie
completely on one side of the scan line (point “b”, point “c” in Figure below).
 Scan line passes through some bottom vertex of polygon whose neighbouring
vertices lie on both sides of the scan line.

In case a, i.e., when a scan line intersects an edge at a point but not a vertex point of the
edge (as in case of point 1, 2, 3, 4) then that point of intersection is considered as a single
point and it is taken as ON/OFF point depending on the requirement. Therefore, in this case
the intersection points are taken as 1234. Colour of the pixels between the intersection
points 1 and 2 is replaced with the filling colour but the colour of the pixels between the
Dr. Ankur Pachauri
MCA Department RATM, Mathura Page 55
LECTURE NOTES on Computer Graphics and Multimedia

points 2 and 3 are left unchanged. Again the colour of the pixels between 3 and 4 are
changed by the filling colour.

In case b and c, case c i.e., when a scan line intersects an edge E1 at a vertex V1 i.e., a vertex
point of the edge E1 whose y coordinate is greater (or less ) than the y coordinate values of
the other two vertex points V2 and V3 where, for example, edge E1 has end vertex points
V1, V2 and edge E2 having end vertex points V1, V3. That is the vertices V2 and V3 will lie
either completely above V1 or both V2 and V3 will lie completely below the vertex V1. In
this case, the point of intersection, i.e., E1, will be counted two times. For example, the
vertices 1’ and 2’ are such that their y-coordinate values are greater than the y-coordinate
values of their neighbouring vertices and therefore they are counted twice.1’1’ 2’2’ i.e. the
colour of the pixels between 1’, 1’ is replaced with the filling colour but the colour of the
pixels between 1’,2’ is left unchanged. Again the colour of the pixels between 2’, 2’ is
changed.

Assume that the scan line passes through a vertex point V1 of the polygonal region having
neighbouring vertices V0 and V2., i.e. let E1 and E2 be two edges of the polygon so that V0,
V1 and V1, V2 be respectively their end vertices. Suppose we assume that the vertex V1 is
such that the y-coordinate for the neighbouring vertex V0 is greater than the y-coordinate
for V1 but the y-coordinate for the neighbouring vertex

V2 is less than the y-coordinate for V1. In this case, the intersection vertex point V0 will be
taken as a single point and the algorithm will remain the same as above.

The point of intersection is to be considered two times, i.e., 1”′ 2”′ 2” 3”. 1” 2” ⇒ make
pixels ON from 1” to 2”, 2” 2” don’t make pixel ON, 2”, 3”⇒ make pixels ON from 2” to 3”.

Now, the requirements for scanning an image are:

1. Determine the point of


intersection of an edge
and scan line
2. Sort the points on scan
line w.r.t x value. Get
the respective pixels ON.

Sum up: To fill a polygonal image we have to identify all edges and vertices of intersections
while moving from scan line ymax to ymin, for each scan line. Then check for the case and
perform the algorithm accordingly.

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 56
LECTURE NOTES on Computer Graphics and Multimedia

Recursive way to scan a figure

For a scan line y = yi


identify the edges and
use the data of the point
of intersection (xi ,yi.).
Say x0 is point on scan
line y0 and x1 is point
on scan line y1. Now
between (x0, y0) and
(x1, y1) we find slope
(this all is to find
recursive way to scan a
figure).

Using yi + 1 and xi + 1 expression we can find consecutive points. x for respective scan lines yi .
If xi comes out to be real then round the value to integer values.

Boundary-Fill Algorithm

This algorithm starts at a point inside a region and paint the interior outward towards the
boundary.

This is a simple method but not efficient as it is recursive method which may occupy a large
stack size in the main memory.
Dr. Ankur Pachauri
MCA Department RATM, Mathura Page 57
LECTURE NOTES on Computer Graphics and Multimedia

void BoundaryFill(int x, int y, COLOR fill, COLOR boundary)

{
COLOR current; current=GetPixel(x,y);
if (current<>boundary) and (current<>fill) then
{
SetPixel(x,y,fill);
BoundaryFill(x+1,y,fill,boundary);
BoundaryFill(x-1,y,fill,boundary);
BoundaryFill(x,y+1,fill,boundary);
BoundaryFill(x,y-1,fill,boundary);
}
}

More efficient methods fill horizontal pixel spans across scan lines, instead of proceeding to
neighbouring points.

Flood Fill Algorithms.

The algorithm starts with the coordinates


of a specified point (known as the “seed”
pixel) inside the polygon to be filled, and
proceeds outwards from it, testing the
adjacent pixels around it in orderly
fashion until the spreading wave reaches
the boundary in every direction, as
suggested in Figure below.

To economise in storage and memory

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 58
LECTURE NOTES on Computer Graphics and Multimedia

management, a combination of the two techniques may be used. Starting from an interior
seed, first the scan-line through the seed is painted until the left and right boundaries are
reached, then the line above and below are similarly covered. The procedure is repeated
until the entire region is filled. Filling may be solid (painted with a single colour), or it may be
patterned or tiled (filled with different patterns). Fill options in standard packages such as
MS-Word are grouped generally under the heads: (a) Gradient, variations from light to dark
of specified colour in specified directions; (b) Texture; (c) Pattern (i.e., Hatching); and (d)
Picture, of the user’s choice. Some of these will be discussed later.

Flood-Fill is similar to Boundary-Fill. The difference is that Flood-Fill is to fill an area which I
not defined by a single boundary color.

void FloodFill(int x, int y, COLOR fill, COLOR old_color)


{
if (GetPixel(x,y)== old_color)
{
SetPixel(x,y,fill);
FloodFill (x+1,y,fill,boundary);
FloodFill (x-1,y,fill,boundary);
FloodFill (x,y+1,fill,boundary);
FloodFill (x,y-1,fill,boundary);
}
}

Dr. Ankur Pachauri


MCA Department RATM, Mathura Page 59

You might also like