Monday 17 June 2013

SOLAR SYSTEM ( GRAPHICS IN C/C++ )

SOLAR SYSTEM
T
his is a program which uses simple C/C++ Graphics Function to show our SOLAR SYSTEM.

View or Download Cpp

/* Praogram Starts Here */

#include"stdio.h"
#include"graphics.h"
#include"conio.h"
#include"dos.h"
#include"math.h"
#include"stdlib.h"


void main()
{
    int gd=DETECT,gm;
    float i=0,j=100,me=75,ve=23,ma=105,ju=175,sa=10,ur=300,ne=200,pl=175,s=0;
    int x,y,k,tri[8],si,sx=random(300),sy=random(400),X,Y,ss;
    unsigned int earth,moon,mercury,venus,mars,jupiter,saturn,uranus,neptune,pluto,
    sunsize,ship,ship2;
    void *ear,*moo,*mer,*ven,*mar,*jup,*sat,*ura,*nep,*plu,*sun,*ships,*ships2;
    x=300;
    y=210;
    initgraph(&gd,&gm,"c:\\tc\\bgi");/*Set the BGI path*/
    setfillstyle(1,10);
    setcolor(2);
    fillellipse(50,50,13,13);
    earth=imagesize(35,35,65,65);
    ear=malloc(earth);
    getimage(35,35,65,65,ear);
    cleardevice();

    setfillstyle(1,15);
    setcolor(15);
    fillellipse(25,25,5,5);
    moon=imagesize(15,15,35,35);
    moo=malloc(moon);
    getimage(15,15,35,35,moo);
    cleardevice();

    setfillstyle(1,4);
    setcolor(4);
    fillellipse(15,15,4,4);
    mercury=imagesize(10,10,20,20);
    mer=malloc(mercury);
    getimage(10,10,20,20,mer);
    cleardevice();


    setfillstyle(1,11);
    setcolor(11);
    fillellipse(15,15,7,7);
    venus=imagesize(7,7,23,23);
    ven=malloc(venus);
    getimage(7,7,23,23,ven);
    cleardevice();


    setfillstyle(1,6);
    setcolor(6);
    fillellipse(20,20,14,14);
    mars=imagesize(5,5,35,35);
    mar=malloc(mars);
    getimage(5,5,35,35,mar);
    cleardevice();


    setfillstyle(1,7);
    setcolor(7);
    fillellipse(25,25,18,18);
    jupiter=imagesize(5,5,45,45);
    jup=malloc(jupiter);
    getimage(5,5,45,45,jup);
    cleardevice();


    setfillstyle(1,8);
    setcolor(8);
    fillellipse(50,50,12,12);
    uranus=imagesize(35,35,65,65);
    ura=malloc(uranus);
    getimage(35,35,65,65,ura);
    cleardevice();

    setfillstyle(1,12);
    setcolor(12);
    fillellipse(50,50,11,11);
    neptune=imagesize(35,35,65,65);
    nep=malloc(neptune);
    getimage(35,35,65,65,nep);
    cleardevice();

    setfillstyle(1,1);
    setcolor(1);
    fillellipse(50,50,8,8);
    pluto=imagesize(35,35,65,65);
    plu=malloc(pluto);
    getimage(35,35,65,65,plu);
    cleardevice();


    setcolor(14);
    setfillstyle(1,14);
    fillellipse(40,40,25,25);
    for(si=0; si<25; si++)
    {
    tri[0]=(40+25*cos(s));
    tri[1]=(40+25*sin(s));
    s=s+0.3;
    tri[2]=(40+25*cos(s));
    tri[3]=(40+25*sin(s));

    tri[4]=(40+40*cos((2*s-0.3)/2));
    tri[5]=(40+40*sin((2*s-0.3)/2));

    tri[6]=tri[0];
    tri[7]=tri[1];

    fillpoly(4,tri);

    }

    sunsize=imagesize(0,0,80,80);
    sun=malloc(sunsize);
    getimage(0,0,80,80,sun);
    cleardevice();

    setfillstyle(1,15);
    setcolor(15);
    fillellipse(40,40,33,16);
    fillellipse(40,25,15,10);
    setfillstyle(1,2);
    fillellipse(14,37,5,5);
    fillellipse(35,40,5,5);
    fillellipse(55,39,5,5);
    setfillstyle(1,4);
    fillellipse(25,39,5,5);
    fillellipse(46,40,5,5);
    fillellipse(65,37,5,5);
    setfillstyle(1,0);
    fillellipse(30,20,2,2);
    fillellipse(35,20,2,2);
    fillellipse(40,20,2,2);
    fillellipse(45,20,2,2);
    fillellipse(50,20,2,2);
    ship=imagesize(0,0,80,80);
    ships=malloc(ship);
    getimage(0,0,80,80,ships);
    cleardevice();

    setfillstyle(1,15);
    setcolor(15);
    fillellipse(40,40,33,16);
    fillellipse(40,25,15,10);
    setfillstyle(1,4);
    fillellipse(14,37,5,5);
    fillellipse(35,40,5,5);
    fillellipse(55,39,5,5);
    setfillstyle(1,2);
    fillellipse(25,39,5,5);
    fillellipse(46,40,5,5);
    fillellipse(65,37,5,5);
    setfillstyle(1,0);
    fillellipse(30,20,2,2);
    fillellipse(35,20,2,2);
    fillellipse(40,20,2,2);
    fillellipse(45,20,2,2);
    fillellipse(50,20,2,2);
    ship2=imagesize(0,0,80,80);
    ships2=malloc(ship2);
    getimage(0,0,80,80,ships2);
    cleardevice();



    setfillstyle(1,9);
    setcolor(9);
    fillellipse(45,45,16,16);
    setcolor(8);
    ellipse(45,45,125,390,20,7);
    setcolor(1);
    ellipse(45,45,120,400,23,8);
    setcolor(4);
    ellipse(45,45,120,400,25,9);
    setcolor(5);
    ellipse(45,45,120,424,28,10);
    setcolor(6);
    ellipse(45,45,115,425,30,11);
    saturn=imagesize(0,0,50,50);
    sat=malloc(saturn);
    getimage(0,0,75,75,sat);
    cleardevice();
    setcolor(15);


    for(i=0; i<1000 && !kbhit(); i++)
    {
        moveto(getmaxx()/2,getmaxy()/2);

lineto(random(600)+random(600)*cos(i),random(600)+random(600)*sin(i));
        delay(10);
    }
    cleardevice();

    delay(300);
    setlinestyle(0,0,3);
    rectangle(0,0,getmaxx(),getmaxy());
    delay(700);
    for(i=0; i<1000; i++)
    {
        putpixel(random(630),random(530),15);
        putpixel(random(630),random(530),11);
        delay(5);
    }
    setlinestyle(3,0,1);
    setlinestyle(0,0,1);
    for(k=0; k<200; k++)
    {
        i=i+0.2;
        j=j+0.7;
        me=me+0.1;
        ve=ve+0.3;
        ma=ma+0.1;
        ju=ju+0.08;
        sa=sa+0.07;
        ur=ur+0.06;
        ne=ne+0.05;
        pl=pl+0.04;
        putpixel(x+100*cos(i)+13,y+80*sin(i)+13,10);
        putpixel(x+(100*cos(i))+(30*cos(j))+5,y+(80*sin(i))+(25*sin(j))+5,1);
        putpixel(x+60*cos(me)+4,y+40*sin(me)+4,4);
        putpixel(x+80*cos(ve)+7,y+60*sin(ve)+7,3);
        putpixel(x+125*cos(ma)+14,y+110*sin(ma)+14,6);
        putpixel(x+165*cos(ju)+18,y+130*sin(ju)+18,7);
        putpixel(x+220*cos(sa)+30+16,y+170*sin(sa)+30+16,9);
        putpixel(x+250*cos(ur)+12,y+200*sin(ur)+12,8);
        putpixel(x+280*cos(ne)+11,y+230*sin(ne)+11,12);
        putpixel(x+310*cos(pl)+8,y+250*sin(pl)+8,1);
    }
        setfillstyle(1,14);
        setcolor(14);
        fillellipse(x,y,25,25);
        delay(250);
        putimage(x-40,y-40,sun,XOR_PUT);
        setlinestyle(0,0,1);
        setfillstyle(1,14);
        setcolor(14);
        fillellipse(x,y,25,25);
        delay(250);
        putimage(x+100*cos(i),y+80*sin(i),ear,XOR_PUT);
        delay(250);
        putimage(x+(100*cos(i))+(30*cos(j)),y+(80*sin(i))+(25*sin(j)),moo,XOR_PUT);
        delay(250);
        putimage(x+60*cos(me),y+40*sin(me),mer,XOR_PUT);
        delay(250);
        putimage(x+80*cos(ve),y+60*sin(ve),ven,XOR_PUT);
        delay(250);
        putimage(x+125*cos(ma),y+110*sin(ma),mar,XOR_PUT);
        delay(250);
        putimage(x+165*cos(ju),y+130*sin(ju),jup,XOR_PUT);
        delay(250);
        putimage(x+220*cos(sa),y+170*sin(sa),sat,XOR_PUT);
        delay(250);
        putimage(x+250*cos(ur),y+200*sin(ur),ura,XOR_PUT);
        delay(250);
        putimage(x+280*cos(ne),y+230*sin(ne),nep,XOR_PUT);
        delay(250);
        putimage(x+310*cos(pl),y+250*sin(pl),plu,XOR_PUT);


        putimage(x-40,y-40,sun,XOR_PUT);
        setlinestyle(0,0,1);
        setfillstyle(1,14);
        setcolor(14);
        fillellipse(x,y,25,25);

        putimage(x+100*cos(i),y+80*sin(i),ear,XOR_PUT);
        putimage(x+(100*cos(i))+(30*cos(j)),y+(80*sin(i))+(25*sin(j)),moo,XOR_PUT);
        putimage(x+60*cos(me),y+40*sin(me),mer,XOR_PUT);
        putimage(x+80*cos(ve),y+60*sin(ve),ven,XOR_PUT);
        putimage(x+125*cos(ma),y+110*sin(ma),mar,XOR_PUT);
        putimage(x+165*cos(ju),y+130*sin(ju),jup,XOR_PUT);
        putimage(x+220*cos(sa),y+170*sin(sa),sat,XOR_PUT);
        putimage(x+250*cos(ur),y+200*sin(ur),ura,XOR_PUT);
        putimage(x+280*cos(ne),y+230*sin(ne),nep,XOR_PUT);
        putimage(x+310*cos(pl),y+250*sin(pl),plu,XOR_PUT);

    for(k=0; k<200; k++)
    {
        i=i+0.2;
        j=j+0.7;
        me=me+0.1;
        ve=ve+0.3;
        ma=ma+0.1;
        ju=ju+0.08;
        sa=sa+0.07;
        ur=ur+0.06;
        ne=ne+0.05;
        pl=pl+0.04;
        putpixel(x+100*cos(i)+13,y+80*sin(i)+13,10);
        putpixel(x+(100*cos(i))+(30*cos(j))+5,y+(80*sin(i))+(25*sin(j))+5,1);
        putpixel(x+60*cos(me)+4,y+40*sin(me)+4,4);
        putpixel(x+80*cos(ve)+7,y+60*sin(ve)+7,3);
        putpixel(x+125*cos(ma)+14,y+110*sin(ma)+14,6);
        putpixel(x+165*cos(ju)+18,y+130*sin(ju)+18,7);
        putpixel(x+220*cos(sa)+30+16,y+170*sin(sa)+30+16,9);
        putpixel(x+250*cos(ur)+12,y+200*sin(ur)+12,8);
        putpixel(x+280*cos(ne)+11,y+230*sin(ne)+11,12);
        putpixel(x+310*cos(pl)+8,y+250*sin(pl)+8,1);
    }
    i=0;j=100;me=75;ve=23;ma=105;ju=175;sa=10;ur=300;ne=200;pl=175;
    while(!kbhit())
    {
        i=i+0.2;
        j=j+0.7;
        me=me+0.1;
        ve=ve+0.3;
        ma=ma+0.1;
        ju=ju+0.08;
        sa=sa+0.07;
        ur=ur+0.06;
        ne=ne+0.05;
        pl=pl+0.04;
        putimage(x-40,y-40,sun,XOR_PUT);
        setlinestyle(0,0,1);
        setfillstyle(1,14);
        setcolor(14);
        fillellipse(x,y,25,25);
        putimage(x+100*cos(i),y+80*sin(i),ear,XOR_PUT);
        putimage(x+(100*cos(i))+(30*cos(j)),y+(80*sin(i))+(25*sin(j)),moo,XOR_PUT);
        putimage(x+60*cos(me),y+40*sin(me),mer,XOR_PUT);
        putimage(x+80*cos(ve),y+60*sin(ve),ven,XOR_PUT);
        putimage(x+125*cos(ma),y+110*sin(ma),mar,XOR_PUT);
        putimage(x+165*cos(ju),y+130*sin(ju),jup,XOR_PUT);
        putimage(x+220*cos(sa),y+170*sin(sa),sat,XOR_PUT);
        putimage(x+250*cos(ur),y+200*sin(ur),ura,XOR_PUT);
        putimage(x+280*cos(ne),y+230*sin(ne),nep,XOR_PUT);
        putimage(x+310*cos(pl),y+250*sin(pl),plu,XOR_PUT);
        for(ss=0; ss<7; ss++)
        {
            X=random(10);
            Y=random(10);

            if(X>3)
                sx=sx+5;
            else
                sx=sx-5;

            if(Y>3)
                sy=sy+5;
            else
                sy=sy-5;

            if(ss%2==0)
            {
                putimage(sx,sy,ships,XOR_PUT);
                delay(100);
                putimage(sx,sy,ships,XOR_PUT);
            }
            else
            {
                putimage(sx,sy,ships2,XOR_PUT);
                delay(100);
                putimage(sx,sy,ships2,XOR_PUT);
            }

        }
        if(sx>getmaxx() || sx<=0)
            sx=random(300);

        if(sy>getmaxy() || sy<=0)
            sy=random(300);
        putimage(x+100*cos(i),y+80*sin(i),ear,XOR_PUT);
        putimage(x+(100*cos(i))+(30*cos(j)),y+(80*sin(i))+(25*sin(j)),moo,XOR_PUT);
        putimage(x+60*cos(me),y+40*sin(me),mer,XOR_PUT);
        putimage(x+80*cos(ve),y+60*sin(ve),ven,XOR_PUT);
        putimage(x+125*cos(ma),y+110*sin(ma),mar,XOR_PUT);
        putimage(x+165*cos(ju),y+130*sin(ju),jup,XOR_PUT);
        putimage(x+220*cos(sa),y+170*sin(sa),sat,XOR_PUT);
        putimage(x+250*cos(ur),y+200*sin(ur),ura,XOR_PUT);
        putimage(x+280*cos(ne),y+230*sin(ne),nep,XOR_PUT);
        putimage(x+310*cos(pl),y+250*sin(pl),plu,XOR_PUT);
    }
    getch();
    closegraph();
}
/* Codetechie.blogspot.com */
/* END */

0 comments: