LECTURE NOTES On Computer Graphics and M
LECTURE NOTES On Computer Graphics and M
LECTURE NOTES On Computer Graphics and M
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
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.
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.
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.
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:
Passive Computer Graphic which has no option for users to interact or use computer
graphics e.g., movies
APPLICATIONS
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
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).
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.
General questions that strike many graphic designers, students, and engineers rushing to
import their illustrations and images into presentations are:
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
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.
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.
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)
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:
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:
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
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
value with L different gray levels is usually referred to as amplitude quantisation or simply
quantisation.
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:
2) Geographic Information Systems (GIS): The most commonly used software is: ArcMap.
Features:
Features:
Features:
Features:
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
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.
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
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.
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.
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
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:
(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.
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.
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.
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.
CAD (or CADD) is an acronym that, depending on who you ask, can stand for:
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
Note:
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.
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
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:
AlphaCAM Canon
Ashlar Vellum Epson
AutoCAD Hewlett Packard
CATIA/CADCAM UMAX
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.
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 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.
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.
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:
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,
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.
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-
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
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.
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
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
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
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 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
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
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.
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.
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 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
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.
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.
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 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
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.
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.
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
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.
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.
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:
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:
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.
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
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).
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)
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.
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:
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.
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
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.
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)
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).
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.
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.
Δ 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.
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
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)
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
X2+y2=r2
Consider 2nd Octant
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)
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
Algorithms:
Write Pixel(x,y)
While(y>x) do //2nd octant condition check
If(d<0) // D<-1/4
d+=2x+3, x+=1
else
d+=2x-2y+5, x+=1, y-=1
end
Write Pixel(x,y)
End while
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
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
d2old=F(M)=F(xp+1/2,yp-1)
d2old =b2(xp+1/2)2+a2(yp-1)2-a2b2
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
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.
So as to understand Scan Line Polygon Fill Algorithm in detail consider 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).
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.
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”.
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.
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
{
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.
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.