PRINT A TEXT USING GRAPHIC FUNCTIONS
#include<stdio.h>
#include<conio.h>
#include<graphics.h>
#include<dos.h>
void main()
{
int gd=DETECT,gm,errorcode;
int y=0,x=0;
int i;
char msg[80];
initgraph(&gd,&gm,"");
errorcode=graphresult();
if(errorcode!=grOk)
{
printf("Graphics error %s\n",grapherrormsg(errorcode));
printf("Press any key to halt");
getch();
exit(1);
}
for(i=1;i<=6;i++)
{
settextstyle(TRIPLEX_FONT,HORIZ_DIR,i);
sprintf(msg,"Text");
outtextxy(x,y,msg);
y+=textheight(msg);
x+=textwidth(msg);
}
getch();
closegraph();
}
OUTPUT:-
Text
Text
Text
Text
Text
Text
DRAW A HOUSE USING GRAPHIC FUNCTIONS
#include <graphics.h>
#include <stdlib.h>
#include <stdio.h>
#include <conio.h>
void main()
{
/* request auto detection */
int gdriver = DETECT, gmode, errorcode;
int xmax, ymax;
int midx, midy;
int radius = 10;
/* initialize graphics and local variables */
initgraph(&gdriver, &gmode, "");
/* read result of initialization */
errorcode = graphresult();
/* an error occurred */
if (errorcode != grOk)
{
printf("Graphics error: %s\n", grapherrormsg(errorcode));
printf("Press any key to halt:");
getch();
exit(1);
}
setcolor(getmaxcolor());
xmax = getmaxx();
ymax = getmaxy();
/* draw a diagonal line */
line(150,150,400,150);
line(150,300,400,300);
line(150,150,150,300);
line(400,150,400,300);
line(150,150,275,50);
line(400,150,275,50);
line(275,50,500,50);
line(400,150,625,150);
line(500,50,625,150);
line(625,150,625,300);
line(400,300,625,300);
//door
line(250,300,250,250);
line(300,300,300,250);
line(250,250,300,250);
line(250,300,275,290);
line(250,250,275,260);
line(275,290,275,260);
//window
line(450,200,550,200);
line(450,250,550,250);
line(450,200,450,250);
line(550,200,550,250);
line(450,225,550,225);
line(500,200,500,250);
circle(275,100,15);
/* clean up */
getch();
closegraph();
}
OUTPUT:-
DRAW A BOAT USING GRAPHIC FUNCTIONS
#include<stdio.h>
#include<conio.h>
#include<graphics.h>
#include<dos.h>
void main()
{
int gd,gm;
int x1=100,y1=250,x2=150,y2=400,x3=400,y3=400,x4=450,y4=250;
int a1=150,b1=100,a2=180,b2=250;
int c1=180,d1=120,c2=210,d2=120,c3=180,d3=150;
int e1=180,f=300,e2=275,e3=370;
int i,j=10,r=10;
clrscr();
detectgraph(&gd,&gm);
initgraph(&gd,&gm,"");
line(x1,y1,x2,y2);
line(x2,y2,x3,y3);
line(x3,y3,x4,y4);
line(x4,y4,x1,y1);
rectangle(a1,b1,a2,b2);
line(c1,d1,c2,d2);
line(c2,d2,c3,d3);
circle(e1,f,r);
circle(e2,f,r);
circle(e3,f,r);
printf("Press any key to make the boat moving");
getch();
for(i=1;i<=10;i++)
{
cleardevice();
line(x1+j,y1,x2+j,y2);
line(x2+j,y2,x3+j,y3);
line(x3+j,y3,x4+j,y4);
line(x4+j,y4,x1+j,y1);
rectangle(a1+j,b1,a2+j,b2);
line(c1+j,d1,c2+j,d2);
line(c2+j,d2,c3+j,d3);
circle(e1+j,f,r);
circle(e2+j,f,r);
circle(e3+j,f,r);
delay(500);
j=j+10;
}
getch();
closegraph();
}
OUTPUT:-
Press any key to move the boat
DRAW A LINE USING DDA ALGORITHM
#include <graphics.h>
#include <stdlib.h>
#include <stdio.h>
#include <conio.h>
#include<dos.h>
#define ROUND(a)((int)(a+0.5))
int main(void)
{
/* request auto detection */
int gdriver = DETECT, gmode, errorcode;
int xa,xb,ya,yb;
// int y=0,x=0,i;
char msg[25];
/* initialize graphics and local variables */
initgraph(&gdriver, &gmode, "");
/* read result of initialization */
errorcode = graphresult();
/* an error occurred */
if (errorcode != grOk)
{
printf("Graphics error: %s\n", grapherrormsg(errorcode));
printf("Press any key to halt:");
getch();
exit(1);
}
printf("Enter the value for x1,y1:\n");
scanf("%d%d",&xa,&ya);
printf("Enter the value for x2,y2:\n");
scanf("%d%d",&xb,&yb);
linedda(xa,ya,xb,yb);
getch();
closegraph();
return 0;
}
void linedda(int xa,int ya,int xb,int yb)
{
int dx=xb-xa,dy=yb-ya,steps,k;
float xincr,yincr,x=xa,y=ya;
if(abs(dx)>abs(dy))
steps=abs(dy);
else
steps=abs(dy);
xincr=dx/(float)steps;
yincr=dy/(float)steps;
putpixel(ROUND(x),ROUND(y),GREEN);
for(k=0;k<steps;k++)
{
x+=xincr;
y+=yincr;
putpixel(ROUND(x),ROUND(y),GREEN);
}
}
OUTPUT:-
Enter the value for x1,y1:
100
100
Enter the value for x2,y2:
250
300
DRAW A LINE USING BRESENHAM ALGORITHM
#include <graphics.h>
#include <stdlib.h>
#include <stdio.h>
#include <conio.h>
#include<dos.h>
void main()
{
/* request auto detection */
int gdriver = DETECT, gmode, errorcode;
int xa,xb,ya,yb,x,y;
char msg[25];
/* initialize graphics and local variables */
initgraph(&gdriver, &gmode, "");
/* read result of initialization */
errorcode = graphresult();
/* an error occurred */
if (errorcode != grOk)
{
printf("Graphics error: %s\n", grapherrormsg(errorcode));
printf("Press any key to halt:");
getch();
exit(1);
}
printf("Enter the x1 and y1 value:\n");
scanf("%d%d",&xa,&ya);
printf("Enter the x2 and y2 value:\n");
scanf("%d%d",&xb,&yb);
linebres(xa,ya,xb,yb);
getch();
closegraph();
}
void linebres(int xa,int ya,int xb,int yb)
{
int dx=abs(xa-xb),dy=abs(ya-yb);
int p=2*dy-dx;
int twody=2*dy,twodxdy=2*(dy-dx);
int x,y,xend;
if(xa>xb)
{
x=xb;y=yb;xend=xa;
}
else
{
x=xa;y=ya;xend=xb;
}
putpixel(x,y,YELLOW);
while(x<xend)
{
x++;
if(p<0)
p+=twody;
else
{
y++;
p+=twodxdy;
}
putpixel(x,y,YELLOW);
}
}
OUTPUT:-
Enter the x1 and y1 value:
100
100
Enter the x2 and y2value:
250
300
DRAW A CIRCLE USING MIDPOINT ALGORITHM
#include <graphics.h>
#include <stdlib.h>
#include <stdio.h>
#include <conio.h>
#include<dos.h>
void main()
{
/* request auto detection */
int gdriver = DETECT, gmode, errorcode;
int x1,x2,x3,x4,xc,yc,r,y1,y2;
char msg[15];
/* initialize graphics and local variables */
initgraph(&gdriver, &gmode, "");
/* read result of initialization */
errorcode = graphresult();
/* an error occurred */
if (errorcode != grOk)
{
printf("Graphics error: %s\n", grapherrormsg(errorcode));
printf("Press any key to halt:");
getch();
exit(1);
}
printf("Enter the value for xc,yc,r:");
scanf("%d%d%d",&xc,&yc,&r);
circlemidpoint(xc,yc,r);
getch();
closegraph();
}
void circlemidpoint(int xc,int yc,int r)
{
int x=0,y=r,p=1-r;
void circleplotpoints(int,int,int,int);
circleplotpoints(xc,yc,x,y);
while(x<y)
{
x++;
if(p<0)
p+=2*x+1;
else
{
y--;
p+=2*(x-y)+1;
}
circleplotpoints(xc,yc,x,y);
}
}
void circleplotpoints(int xc,int yc,int x,int y)
{
putpixel(xc+x,yc+y,YELLOW);
putpixel(xc-x,yc+y,YELLOW);
putpixel(xc+x,yc-y,GREEN);
putpixel(xc-x,yc-y,GREEN);
putpixel(xc+y,yc+x,GREEN);
putpixel(xc-y,yc+x,RED);
putpixel(xc+y,yc-x,RED);
putpixel(xc-y,yc-x,RED);
}
OUTPUT:-
Enter the value for xc, yc, r:
250
150
125
LINE CLIPPING USING COHEN SUTHERLAND ALGORITHM
#include<stdio.h>
#include<conio.h>
#include<graphics.h>
#define FALSE 0
#define TRUE 1
#define LEFTEDGE 0x1
#define RIGHTEDGE 0x2
#define TOPEDGE 0x8
#define BOTTOMEDGE 0x4
#define INSIDE(a) (!a)
#define REJECT(a,b) (a&b)
#define ACCEPT(a,b) (!(a|b))
unsigned char encode(int x,int y,int minx,int maxx,int miny,int maxy)
{
unsigned char code=0X00;
if(x<minx)
code=code|LEFTEDGE;
if(x>maxx)
code=code|RIGHTEDGE;
if(y<miny)
code=code|BOTTOMEDGE;
if(y>maxy)
code=code|TOPEDGE;
return(code);
}
void swappts(int *x1,int *y1,int *x2,int *y2)
{
int tx,ty;
tx=*x1;
ty=*y1;
*x1=*x2;
*y1=*y2;
*x2=tx;
*y2=ty;
}
void swapcode(unsigned char *c1,unsigned char *c2)
{
unsigned char temp;
temp=*c1;
*c1=*c2;
*c2=temp;
}
void clipline(int minx,int maxx,int miny,int maxy,int x1,int y1,int x2,int y2)
{
unsigned char code1,code2;
int done=FALSE;
int draw=FALSE;
float m;
while(!done)
{
code1=encode(x1,y1,minx,maxx,miny,maxy);
code2=encode(x2,y2,minx,maxx,miny,maxy);
if(ACCEPT(code1,code2))
{
done=TRUE;
draw=TRUE;
}
else if(REJECT(code1,code2))
done=TRUE;
else
{
if(INSIDE(code1))
{
swappts(&x1,&y1,&x2,&y2);
swapcode(&code1,&code2);
}
if(x2!=x1)
m=(y2-y1)/(x2-x1);
if(code1&LEFTEDGE)
{
y1+=(minx-x1)*m;
x1=minx;
}
else if(code1&RIGHTEDGE)
{
y1+=(maxx-x1)*m;
x1=maxx;
}
else if(code1&BOTTOMEDGE)
{
if(x2!=x1)
x1+=(miny-y1)/m;
y1=miny;
}
else if(code1&TOPEDGE)
{
if(x2!=x1)
x1+=(maxy-y1)/m;
y1=maxy;
}
}
}
if(draw)
line(x1,y1,x2,y2);
}
void main()
{
int x1,x2,y1,y2,minx,miny,maxx,maxy;
int gd=DETECT,gm;
initgraph(&gd,&gm,"");
printf("Enter the minimum and maximum values of x:");
scanf("%d%d",&minx,&maxx);
printf("Enter the minimum and maximum values of y: ");
scanf("%d%d",&miny,&maxy);
printf("Enter the first enpoint of line: ");
scanf("%d%d",&x1,&y1);
printf("Enter the second endpoint of line: ");
scanf("%d%d",&x2,&y2);
printf("BEFORE CLIPPING");
rectangle(minx,maxy,maxx,miny);
line(x1,y1,x2,y2);
getch();
clrscr();
printf("AFTER CLIPPING");
rectangle(minx,maxy,maxx,miny);
clipline(minx,maxx,miny,maxy,x1,y1,x2,y2);
getch();
closegraph();
}
OUTPUT:-
Enter the minimum and maximum values of x: 300 400
Enter the minimum and maximum values of y: 300 400
Enter the first endpoint of line: 275 300
Enter the second endpoint of line: 350 420
BEFORE CLIPPING
AFTER CLIPPING
LINE CLIPPING USING LIANG BARSKY ALGORITHM
#include<stdio.h>
#include<conio.h>
#include<graphics.h>
#include<dos.h>
#define ROUND(a)((int)(a+0.5))
int cliptest(float p,float q,float *u1,float *u2)
{
float r;
int retval=1;
if(p<0.0)
{
r=q/p;
if(r>*u2)
retval=0;
if(r>*u1)
*u1=r;
}
else if(p>0.0)
{
r=q/p;
if(r<*u1)
retval=0;
if(r<*u2)
*u2=r;
}
else if(q<0.0)
retval=0;
return(retval);
}
void clipline(int minx,int miny,int maxx,int maxy,int x1,int y1,int x2,int y2)
{
float u1=0.0,u2=1.0,dx=x2-x1,dy;
if(cliptest(-dx,x1-minx,&u1,&u2))
if(cliptest(dx,maxx-x1,&u1,&u2))
{
dy=y2-y1;
if(cliptest(-dy,y1-miny,&u1,&u2))
if(cliptest(dy,maxy-y1,&u1,&u2))
{
if(u2<1.0)
{
x2=x1+u2*dx;
y2=y1+u2*dy;
}
if(u1>0.0)
{
x1+=u1*dx;
y1+=u1*dy;
}
line(x1,y1,x2,y2);
}
}
}
void main()
{
int gdriver=DETECT,gmode,x1,y1,x2,y2,minx,miny,maxx,maxy;
initgraph(&gdriver,&gmode,"");
clrscr();
printf("Enter the min & max x values: ");
scanf("%d %d",&minx,&maxx);
printf("Enter the min & max y values: ");
scanf("%d %d",&miny,&maxy);
printf("Enter the first endpoint: ");
scanf("%d %d",&x1,&y1);
printf("Enter the second endpoint: ");
scanf("%d %d",&x2,&y2);
clrscr();
printf("Before Clipping");
line(x1,y1,x2,y2);
rectangle(minx,maxy,maxx,miny);
getch();
clrscr();
printf("After Clipping");
clipline(minx,miny,maxx,maxy,x1,y1,x2,y2);
rectangle(minx,maxy,maxx,miny);
getch();
}
OUTPUT:-
Enter the min & max x values:: 300 400
Enter the min & max x values:: 300 400
Enter the first endpoint : 275 300
Enter the second endpoint : 350 420
Before Clipping
After Clipping
2 DIMENSIONAL ROTATION
#include<math.h>
#include<stdlib.h>
#include<stdio.h>
#include<conio.h>
#include<graphics.h>
float px[10],py[10],tx[10],ty[10];
void disp1();
void disp2();
void translation();
void scaling();
void rotation();
int vertices;
void main()
{
int gd=DETECT,gm,i;
initgraph(&gd,&gm,"");
if(graphresult()!=grOk)
{
printf("Graphics error");
getch();
return;
}
printf("Enter number of vertices : ");
scanf("%d",&vertices);
printf("Enter the x and y coordinates : ");
for(i=0;i<vertices;i++)
{
scanf("%f%f",&px[i],&py[i]);
}
disp1();
rotation();
disp2();
getch();
return;
}
void disp1()
{
int i;
for(i=0;i<vertices-1;i++)
{
line(px[i],py[i],px[i+1],py[i+1]);
line(px[vertices-1],py[vertices-1],px[0],py[0]);
}
}
void disp2()
{
int i;
for(i=0;i<vertices-1;i++)
{
line(tx[i],ty[i],tx[i+1],ty[i+1]);
line(tx[vertices-1],ty[vertices-1],tx[0],ty[0]);
}
}
void rotation()
{
float a,rx,ry,dir,s;
int i;
printf("Enter the rotation angle : ");
scanf("%f",&a);
printf("Enter the rotation point coordinates : ");
scanf("%f%f",&rx,&ry);
printf("Enter the direction of rotation 1 for clockwise and 2 for anticlockwise:");
scanf("%f",&dir);
if(dir==1)
s=1;
else
s=-1;
for(i=0;i<vertices;i++)
{
tx[i]=(rx + (px[i]-rx)*cos(a) - (py[i]-ry)*sin(a)*s);
ty[i]=(ry + (px[i]-rx)*sin(a)*s + (py[i]-ry)*cos(a));
}
getch();
}
2 DIMENSIONAL ROTATION
OUTPUT:-
Enter the number of vertices:3
Enter the coordinate 1: 100 200
Enter the coordinate 2: 200 200
Enter the coordinate 3: 200 200
Enter the rotation angle: 90
Enter the rotation point: 200 200
Enter the direction (1.Clockwise 2.Anti Clockwise) : 1
2 DIMENSIONAL SCALING
#include<conio.h>
#include<graphics.h>
#include<stdlib.h>
int px[10],py[10],tx[10],ty[10];
void disp1();
void disp2();
void scaling();
int i,n=0;
void main()
{
/*reqest auto detection */
int gdriver = DETECT, gmode, errorcode;
/* initialize graphics and local variables */
initgraph(&gdriver, &gmode, "");
/* read result of initialization */
errorcode = graphresult();
/* an error occurred */
if (errorcode != grOk)
{
printf("Graphics error: %s\n", grapherrormsg(errorcode));
printf("Press any key to halt:");
getch();
exit(1);
}
setcolor(getmaxcolor());
printf("\n\n Enter the no of vertics:");
scanf("%d",&n );
printf("\n\nEnter the value for coordinate:");
for(i=0;i<n;i++)
{
scanf("%d",&px[i]);
scanf("%d",&py[i]);
}
clrscr();
disp1();
scaling();
clrscr();
disp2();
getch();
closegraph();
}
void disp1()
{
for(i=0;i<n-1;i++)
line(px[i],py[i],px[i+1],py[i+1]);
line(px[n-1],py[n-1],px[0],py[0]);
getch();
}
void disp2()
{
for(i=0;i<n-1;i++)
line(tx[i],ty[i],tx[i+1],ty[i+1]);
line(tx[n-1],ty[n-1],tx[0],ty[0]);
getch();
}
void scaling()
{
int sx,sy;
printf("Enter the scaling vector:");
scanf("%d %d",&sx,&sy);
for(i=0;i<n;i++)
{
tx[i]=px[i]*sx;
ty[i]=py[i]*sy;
}
}
2-DIMENSIONAL SCALING
OUTPUT:
Enter the number of vertices: 3
Enter the x and y coordinates : 100
150
150
150
150
100
Enter scale factors (2 values ) :
2
2
2 DIMENSIONAL TRANSLATION
#include<stdio.h>
#include<conio.h>
#include<graphics.h>
#include<stdlib.h>
int px[10],py[10],tx[10],ty[10];
void disp1();
void disp2();
void translation();
int i,n=0;
void main()
{
/*reqest auto detection */
int gdriver = DETECT, gmode, errorcode;
/* initialize graphics and local variables */
initgraph(&gdriver, &gmode, "");
/* read result of initialization */
errorcode = graphresult();
/* an error occurred */
if (errorcode != grOk)
{
printf("Graphics error: %s\n", grapherrormsg(errorcode));
printf("Press any key to halt:");
getch();
exit(1);
}
setcolor(getmaxcolor());
printf("\n\n Enter the no of vertics:");
scanf("%d",&n );
printf("\n\nEnter the value for coordinate:");
for(i=0;i<n;i++)
{
scanf("%d",&px[i]);
scanf("%d",&py[i]);
}
clrscr();
disp1();
translation();
clrscr();
disp2();
getch();
closegraph();
}
void disp1()
{
for(i=0;i<n-1;i++)
line(px[i],py[i],px[i+1],py[i+1]);
line(px[n-1],py[n-1],px[0],py[0]);
getch();
}
void disp2()
{
for(i=0;i<n-1;i++)
line(tx[i],ty[i],tx[i+1],ty[i+1]);
line(tx[n-1],ty[n-1],tx[0],ty[0]);
getch();
}
void translation()
{
int dx,dy;
printf("Enter the translation vector:");
scanf("%d %d",&dx,&dy);
for(i=0;i<n;i++)
{
tx[i]=px[i]+dx;
ty[i]=py[i]+dy;
}
}
2 DIMENSIONAL TRANSLATION
OUTPUT:-
Enter the number of vertices:3
Enter the coordinate 1: 100 200
Enter the coordinate 2: 200 200
Enter the coordinate 3: 200 200
Enter the translation vector: 50 50
3 DIMENSIONAL TRANSLATION
#include<stdio.h>
#include<conio.h>
#include<graphics.h>
#include<math.h>
float px[10],py[10],tx[10],ty[10],tx2[10],ty2[10],px2[10],py2[10];
void disp1();
void disp2();
void translation();
float depth,vertices;
void main()
{
int gd=DETECT,gm,i;
initgraph(&gd,&gm,"");
if(graphresult()!=grOk)
{
printf("Graphics error");
getch();
return;
}
printf("Enter number of vertices : ");
scanf("%f",&vertices);
printf("Enter the depth value : ");
scanf("%f",&depth);
printf("Enter the x and y coordinates : ");
for(i=0;i<vertices;i++)
{
scanf("%f%f",&px[i],&py[i]);
px2[i]=px[i]+depth;
py2[i]=py[i]+depth;
}
disp1();
translation();
disp2();
getch();
}
void disp1()
{
int i;
for(i=0;i<vertices-1;i++)
{
line(px[i],py[i],px[i+1],py[i+1]);
line(px2[i],py2[i],px2[i+1],py2[i+1]);
}
line(px[vertices-1],py[vertices-1],px[0],py[0]);
line(px2[vertices-1],py2[vertices-1],px2[0],py2[0]);
for(i=0;i<vertices;i++)
line(px[i],py[i],px2[i],py2[i]);
}
void disp2()
{
int i;
for(i=0;i<vertices-1;i++)
{
line(tx[i],ty[i],tx[i+1],ty[i+1]);
line(tx2[i],ty2[i],tx2[i+1],ty2[i+1]);
}
line(tx[vertices-1],ty[vertices-1],tx[0],ty[0]);
line(tx2[vertices-1],ty2[vertices-1],tx2[0],ty2[0]);
for(i=0;i<vertices;i++)
line(tx[i],ty[i],tx2[i],ty2[i]);
return;
}
void translation()
{
float dx,dy,i;
printf("Enter the translation value ( 2 values ) : ");
scanf("%f%f",&dx,&dy);
for(i=0;i<vertices;i++)
{
tx[i]=px[i]+dx;
ty[i]=py[i]+dy;
tx2[i]=dx+px2[i];
ty2[i]=dy+py2[i];
}
}
3-DIMENSIONAL TRANSLATION
OUTPUT:
Enter the number of vertices: 3
Enter the depth value : 10
Enter the x and y coordinates : 100
200
200
200
200
100
3 DIMENSIONAL SCALING
#include<stdio.h>
#include<conio.h>
#include<graphics.h>
#include<math.h>
float px[10],py[10],tx[10],ty[10],tx2[10],ty2[10],px2[10],py2[10];
void disp1();
void disp2();
void scaling();
float depth,vertices;
void main()
{
int gd=DETECT,gm,i;
initgraph(&gd,&gm,"");
if(graphresult()!=grOk)
{
printf("Graphics error");
getch();
return;
}
printf("Enter number of vertices : ");
scanf("%f",&vertices);
printf("Enter the depth value : ");
scanf("%f",&depth);
printf("Enter the x and y coordinates : ");
for(i=0;i<vertices;i++)
{
scanf("%f%f",&px[i],&py[i]);
px2[i]=px[i]+depth;
py2[i]=py[i]+depth;
}
disp1();
scaling();
disp2();
getch();
return;
}
void disp1()
{
int i;
for(i=0;i<vertices-1;i++)
{
line(px[i],py[i],px[i+1],py[i+1]);
line(px2[i],py2[i],px2[i+1],py2[i+1]);
}
line(px[vertices-1],py[vertices-1],px[0],py[0]);
line(px2[vertices-1],py2[vertices-1],px2[0],py2[0]);
for(i=0;i<vertices;i++)
line(px[i],py[i],px2[i],py2[i]);
}
void disp2()
{
int i;
for(i=0;i<vertices-1;i++)
{
line(tx[i],ty[i],tx[i+1],ty[i+1]);
line(tx2[i],ty2[i],tx2[i+1],ty2[i+1]);
}
line(tx[vertices-1],ty[vertices-1],tx[0],ty[0]);
line(tx2[vertices-1],ty2[vertices-1],tx2[0],ty2[0]);
for(i=0;i<vertices;i++)
line(tx[i],ty[i],tx2[i],ty2[i]);
return;
}
void scaling()
{
float sx,sy,sz,i,dep;
printf("Enter the scale factors(3 values): ");
scanf("%f%f%f",&sx,&sy,&sz);
for(i=0;i<vertices;i++)
{
tx[i]=px[i]*sx;
ty[i]=py[i]*sy;
dep=depth*sz;
tx2[i]=tx[i]+dep;
ty2[i]=ty[i]+dep;
}
}
3-DIMENSIONAL SCALING
OUTPUT:
Enter the number of vertices: 3
Enter the depth value : 15
Enter the x and y coordinates : 100
50
50
50
50
100
Enter the scale factors ( 3 values ) : 2
2
2
3 DIMENSIONAL ROTATION
#include<stdio.h>
#include<conio.h>
#include<graphics.h>
#include<math.h>
float px[10],py[10],tx[10],ty[10],tx2[10],ty2[10],px2[10],py2[10];
void disp1();
void disp2();
void rotation();
float depth,vertices;
void main()
{
int gd=DETECT,gm,i;
initgraph(&gd,&gm,"");
if(graphresult()!=grOk)
{
printf("Graphics error");
getch();
return;
}
printf("Enter number of vertices : ");
scanf("%f",&vertices);
printf("Enter the depth value : ");
scanf("%f",&depth);
printf("Enter the x and y coordinates : ");
for(i=0;i<vertices;i++)
{
scanf("%f%f",&px[i],&py[i]);
px2[i]=px[i]+depth;
py2[i]=py[i]+depth;
}
disp1();
rotation();
disp2();
getch();
}
void disp1()
{
int i;
for(i=0;i<vertices-1;i++)
{
line(px[i],py[i],px[i+1],py[i+1]);
line(px2[i],py2[i],px2[i+1],py2[i+1]);
}
line(px[vertices-1],py[vertices-1],px[0],py[0]);
line(px2[vertices-1],py2[vertices-1],px2[0],py2[0]);
for(i=0;i<vertices;i++)
line(px[i],py[i],px2[i],py2[i]);
}
void disp2()
{
int i;
for(i=0;i<vertices-1;i++)
{
line(tx[i],ty[i],tx[i+1],ty[i+1]);
line(tx2[i],ty2[i],tx2[i+1],ty2[i+1]);
}
line(tx[vertices-1],ty[vertices-1],tx[0],ty[0]);
line(tx2[vertices-1],ty2[vertices-1],tx2[0],ty2[0]);
for(i=0;i<vertices;i++)
line(tx[i],ty[i],tx2[i],ty2[i]);
}
void rotation()
{
float i,an,rx,ry,dir,s,a;
printf("Enter the rotation angle : ");
scanf("%f",&an);
printf("Enter the rotation point : ");
scanf("%f%f",&rx,&ry);
printf("Enter the dircetion of rotation [1 for clockwise / 2 for anticlockwise] : ");
scanf("%f",&dir);
if(dir==1)
s=1;
else
s=-1;
a=an*3.14/180;
for(i=0;i<vertices;i++)
{
tx[i]=rx+(px[i]-rx)*cos(a) - (py[i]-ry)*sin(a)*s;
ty[i]=ry+(px[i]-rx)*sin(a)*s + (py[i]-ry)*cos(a);
tx2[i]=rx+(px2[i]-rx)*cos(a) - (py2[i]-ry)*sin(a)*s;
ty2[i]=ry+(px2[i]-rx)*sin(a)*s + (py2[i]-ry)*cos(a);
}
}
3-DIMENSIONAL ROTATION
OUTPUT:
Enter the number of vertices: 3
Enter the depth value : 20
Enter the x and y coordinates : 100
150
150
150
150
100
Enter the rotation angle: 30
Enter the rotation point : 50
50
Enter the direction of rotation (1-Clockwise, 2-Anticlockwise) : 1
DEVELOPING AN ANIMATION USING GUIDE LAYER TECHNIQUE
Step 1 : Create a new Flash document
Step 2 : Choose View > Grid > Show Grid
Step 3 : In the Timeline, select Frame 1
Step 4 : In Frame 1, use the oval tool to create a circle that represents a ball
Step 5 : In the timeline, select Frame 20, and choose Insert > Frame
Step 6 : In the Timeline, select Frame 1
Step 7 : Choose Insert > Create Motion Tween
Step 8 : In the timeline, position in Frame 5, drag the ball to a new position
Step 9 : Do the same for Frame 10, 15 and 20
Step 10 : At the bottom of the timeline, click the add guide layer button
Step 11 : With the motion guide layer selected, use the pencil tool to draw a line on the stage showing the path
Step 12 : In Frame 1, drag the circle to position over the beginning of the motion path
Step 13 : In Frame 20, drag the circle to reposition it over the end of the motion path
Step 14 : Select the first and select Control > Play
Step 15 : Stop
DEVELOPING AN ANIMATION USING ONION SKIN TECHNIQUE
Step 1 : Create a new Flash document
Step 2 : Choose View > Grid > Show Grid
Step 3 : In the Timeline, select Frame 1
Step 4 : In the Tool Box, select the oval tool
Step 5 : Near the top of the edge, draw a circle
Step 6 : In the Timeline, select Frame 2
Step 7 : Choose Insert > Timeline > Key frame
Step 8 : Select the ball and reposition it at the bottom of the previous ball
Step 9 : Similarly create some more key frames and do the same in such a way that balls are positioned in a wave form
Step 10 : In the status bar of the timeline, check the onion skin button
Step 11 : In the timeline, check and modify onion marker button. Select Onion 2, Onion 5 or Onion all
Step 12 : Select Control > Play
Step 13 : Stop
OUTPUT:-
DEVELOPING AN ANIMATION USING MASKING OF LAYER
Step 1 : Create a new Flash document
Step 2 : Insert one more layer, rather than the default layer.
Step 3 : Rename the top layer to "Mask" and the layer below that to "background".
Step 4 : Import your picture to the "background" layer.
Step 5 : Using Oval tool from your tool box, draw a circle in your "Mask" layer and delete it's border.
Step 6 : Drag the circle to one end of your picture.
Step 7 : Now go to"frame 40" of your "Mask" layer and press "F6" to insert a new keyframe.
Step 8 : Now go to "frame 40" of your "background" layer and press "F5" to insert frames, so that your background image is available all through your mask.
Step 9 : Select "frame 40" of your "Mask" layer, that is your new keyframe, Keeping the playhead on "frame 40" of "Mask" layer, drag the circle to other end of your picture.
Step 10 : Now go back to "frame 1" of your "Mask" layer, keeping the playhead on "frame 1" of your "Mask" layer, select Shape tween in your properties window.
Step 11 : Right click on the "Mask" layer (the area where you named the layer not where the frames exist) and select Mask.
Step 12 : select Control > Play
Step 13 : Stop
OUTPUT:-
IMAGE EDITING USING CROPING
Step 1 : Create a new Photoshop document
Step 2 : Import a picture on to the document
Step 3 : Select the Crop tool
Step 4 : Drag over the part of the image you want to keep to create a marquee.
Step 5 : To complete the crop, press Enter or double-click inside the cropping marquee.
Step 6 : Stop
OUTPUT:-
IMAGE EDITING USING CLONING
Step 1 : Create a new Photoshop document
Step 2 : Import a picture on to the document
Step 3 : Select the Clone Stamp Tool from the toolbox.
Step 4 : On the Options bar across the top of the screen, select the brush size and type of brush you want to use
Step 5 : Move the cursor over the image to the area you would like to reproduce elsewhere.
Step 6 : Hold down the Alt key and click to select the area to clone from.
Step 7 : When you release the mouse, the brush will appear on the image in the shape of the brush selected. Crosshairs will appear over the area to be reproduced and move with the brush.
Step 8 : Click repeatedly or drag the mouse to reproduce the pattern.
Step 9 : Stop
OUTPUT:-
No comments:
Post a Comment