Tuesday, October 26, 2010

online animation tutorial ‘Pencil2Pixels‘

Kolkata based Virtualinfocom (VIC) has launched online tutorial called ‘Pencil2Pixels‘ to help aspiring students understand and learn the basic skill sets of animation. A 20 page version of it is available online free of cost to give an idea on how animations are done and how you can create characters, shadow balance etc.
The original tutorial is a book of 135 pages which would be made available online topic wise in the due course of time. The book would be available at a cost of arount INR 350 in a month‘s time. Virtualinfocom has it cartoon character ‘Chankey‘ who trains the users on how to create animations and how to draw.Speaking to AnimationXpress.comVirtualinfocom CEO Arijit Bhattacharyya said "Pencil2Pixels is created for the people who want to draw and want to be a part of Animations and Gaming Industry. This online tutorial will help a new comer or a professional to create good animations and make good comics with proper knowledge. It is basically created to encourage people to come into animation and gaming field as there is a dearth of really talented people in this field."

Virtualinfocom is also coming up with game developments tutorial for online medium and are now creating mobile based animations and mobile based games for different clients as well coming up with mobile based comics.Various topic are covered in the tutorial such as creating diagrams, basic drawing, drawing shapes, drawing human faces, trick stuff, solid with round and rectangle, the divided ball and plane method, comic heads, methods of checking, drawing a female body, figure in action, animated figures, digital drawing, bit-map images, vector images, three-dimensional images, Indian style animations, color composition, animate the characters, the perspective view for any animation, case study for a story board, lights - camera - animate, the basic film making setup, how to choose between formats and many more.

Tuesday, July 20, 2010

how to make scripts for games

Part 3– Making stuff random


This tutorial should take around 10 minutes to complete

or this tut, we'll have a look at the random function, object positioning and also

do some more loops for practice.



For this tut, we'll have a look at the random function, object positioning and also

do some more loops for practice.



Intro

Here is our hypothetical scenario. We want to build a fence across a

field. We have made an array of tall boxes - 20 of them - for fence

posts unfortunately they look really uniform and CG like. What to

do? Maxscript to the rescue.





The Random Function

Open the listener and type in the following command:



random 1.0 35.0



Maxscript will return a float number between 1 and 35. Notice how putting .0 after the


number

made maxscript realise that we wanted it to generate floats and not integers.



Now we'll make a variable with a random integer between 1 and 6



diceThrow = random 1 6



Now whenever we access the diceThrow variable we made, it will contain the number that it

randomly chose when we first created the variable.

Randomizing post heights

Create an array of about 20 boxes. They should have their pivot on the ground and be 10 x


10 by

100 high. Make the spacing about 150 units.



I'm sure that you have a rough idea in your head by now of how we will go about this. Here


is the

code:



for obj in $ do

(

randHeight = random 90.0 110.0

obj.height = randHeight

)



We have the same loop as last time. For all the objects in the selection, execute the


following code:



randHeight = random 90.0 110.0 - Make a variable with a random float between 90 and 110 in


it.

obj.height = randHeight - Assign that variable to the objects height.



Select all your fencepost boxes and run the code. Now all the posts should have slightly


different

heights!



Position

Create a sphere in the scene and select it.



The way Maxscript accesses the position of objects is with the .position (or .pos)


property.



If you type:



$.pos



Maxscript should return: [12.3434,34.6446,0] or similar. You exact results will depend on


where

you made the sphere in your scene.

Point 3 Data type

This result is a special type of data type called a Point3 data type. It contains X Y and


Z values

always in that order. If we assign one to a variable:



ourPoint3variable = [5,4,1]



and then type this:



ourPoint3variable.y



Max will return 4 which is the Y component of our Point3. If we just type:



ourPoint3variable



Maxscript will return all the values - [5,4,1]

Position (and many other things) in 3D often needs 3 values, X, Y and Z so a Point3 is a


very

useful data type.



Moving Objects



Back to setting an objects position.

We could type the following:



$.pos = [0,0,0]



that will move our selected sphere to the center of the world. We are giving the sphere


explicit co-

ordinates to go to. What if we want to move it relative to where it is now?

maxscript provides a move function to do just that.





move $ [3,2,0]



That is simply saying "Move the selected object +3 units in X, +2 units in Y and 0 units


in Z"

type:



$.pos



Now maxscript will return the position as [3,2,0]

Execute the move line again:



move $ [3,2,0]



Then ask the position:



$.pos



You'll see that it is now at [6,4,0]

Delete the sphere. (if you want to be fancy, type: delete $)



Now we want to randomise the position of all the posts slightly.



Randomizing Position





Select all the posts again.



Here is the code we are going to use.



for obj in $ do

(

randX = random -5.0 5.0

randY = random -5.0 5.0

move obj [randX,randY,0]

)



Lets step through it.

For each object in our current selection do:

Create a random float between -5 and 5 and assign it to the variable randX

Create a random float between -5 and 5 and assign it to the variable randY

move the current object according to the following Point3. Where it says randX in the


point3,

maxscript will substitute in the random number it generated earlier. The same goes for the


randY.

we don't want the posts to move vertically so we have just put in a 0.



Highlight the code and run it.

Thursday, May 27, 2010

creating a chess game on C++

Source code to create chess game using C++
#include
#include
#include
#include
#include

#define White 0
#define Black 1

void draw_piece(int);
int marker(int,short);
int valid_move(int,int);
int previous_move_pick=0,previous_move_put=0;
void chessboard();
void pawn(int,float,float);
void rook(int,float,float);
void knight(int,float,float);
void bishop(int,float,float);
void queen(int,float,float);
void king(int,float,float);

int dx,dy;
union REGS i,o;

int Square_Color[64]= {  1,0,1,0,1,0,1,0,
             0,1,0,1,0,1,0,1,
             1,0,1,0,1,0,1,0,
             0,1,0,1,0,1,0,1,
             1,0,1,0,1,0,1,0,
             0,1,0,1,0,1,0,1,
             1,0,1,0,1,0,1,0,
             0,1,0,1,0,1,0,1  };

int Board[64]= {15,12,13,17,19,13,12,15,
             11,11,11,11,11,11,11,11,
             0,0,0,0,0,0,0,0,
             0,0,0,0,0,0,0,0,
             0,0,0,0,0,0,0,0,
             0,0,0,0,0,0,0,0,
             1,1,1,1,1,1,1,1,
             5,2,3,7,9,3,2,5       };


void main()
{

int driver=DETECT,mode;
int x,y;
union REGS ii,oo;

initgraph(&driver,&mode,"");

x=getmaxx()/2;
y=getmaxy()/2;


chessboard();

struct palettetype pal;
getpalette(&pal);
setrgbpalette(pal.colors[6],35,33,25);

setfillstyle(SOLID_FILL,6);
floodfill(x+250,y,15);

for(int b=0;b<64;b++)
draw_piece(b);

int Marker=56;
marker(Marker,1);

int pick_up,Mode=0,put_down;
int turn=White;
int checker;

while(1)
{

        if(kbhit())
        {
            ii.h.ah=0;
            int86(22,&ii,&oo);
            if(oo.h.ah==1)
            {
                closegraph();
                exit(0);
            }
            if(oo.h.ah==77)
             {

                if((Marker+1)%8!=0)
                {
                marker(Marker,0);
                Marker++;
                marker(Marker,1);
                }

             }

            if(oo.h.ah==75)
             {

                if(Marker%8!=0)
                {
                marker(Marker,0);
                Marker--;
                marker(Marker,1);
                }

             }

            if(oo.h.ah==72)
             {

                if(Marker>7)
                {
                marker(Marker,0);
                Marker-=8;
                marker(Marker,1);
                }

             }
            if(oo.h.ah==80)
             {

                if(Marker<56)
                {
                marker(Marker,0);
                Marker+=8;
                marker(Marker,1);
                }
             }
            if(oo.h.ah==28)
             {
                if(Mode==0)
                {
                 if(turn==White) {
                 if(Board[Marker]!=0&&Board[Marker]<10)
                 {
                 pick_up=Marker;
                 marker(Marker,3);
                 Mode=1;
                 } }
                 else if(turn==Black) {
                 if(Board[Marker]!=0&&Board[Marker]>10)
                 {
                 pick_up=Marker;
                 marker(Marker,3);
                 Mode=1;
                 } }
                }

               else if(Mode==1)
               {
               put_down=Marker;
               if(put_down==pick_up)
               { Mode=0; marker(put_down,4); goto cancel; }
               checker=valid_move(pick_up,put_down);
               if(checker==0)
               { Mode=0; marker(pick_up,4); goto cancel; }
               if(checker==2)  {
                   Board[pick_up]=0;
                   marker(put_down,2);
                   for( b=0;b<64;b++)
                   draw_piece(b);
                   setcolor(6);
                   outtextxy(530,50,"choose piece");
                  }
               if(checker==1)  {
               Board[put_down]=Board[pick_up];
               Board[pick_up]=0;
               marker(put_down,2);
               for(b=0;b<64;b++)
               draw_piece(b);
               }
               marker(pick_up,2);
               setcolor(15);
               rectangle(x-200,y-200,x+200,y+200);
               Mode=0;
               if(turn==White)
                 turn=Black;
               else if(turn==Black)
                 turn=White;
               previous_move_pick=pick_up;
               previous_move_put=put_down;
               cancel:
               }
             }
        }

}

}


valid_move(int pick,int put)
{

int leftup,leftdown,rightup,rightdown;
int up,down,right,left;
int sx,sy;
int i;
int x=getmaxx()/2,y=getmaxy()/2;


  if(Board[pick]<10 && Board[put]<10 && Board[put]!=0)
  return 0;
  if(Board[pick]>10 && Board[put]>10 && Board[put]!=0)
  return 0;

if(Board[pick]==1)

    {


        if(pick>=48&&pick<=55)
        {

             if(put!=pick-8&&put!=pick-16&&put!=pick-7&&put!=pick-9)
            return 0;

             if(put==pick-16)
             {
            if( Board[pick-8]!=0 || Board[pick-16]!=0)
            return 0;
             }
             else if(put==pick-8)
             {
            if(Board[pick-8]!=0)
            return 0;
             }
             else if(put==pick-7)
             {
            if(Board[pick-7]==0||Board[pick-7]<10)
            return 0;
             }
             else if(put==pick-9)
             {
            if(Board[pick-9]==0||Board[pick-9]<10)
            return 0;
             }
        }
        else if(pick<=47)
        {
             if(pick<=31 && pick>=24)
             {
              if(pick!=24)
            if(previous_move_pick==(pick-17)&&previous_move_put==(pick-1)&&put==pick-9)
            {
              Board[pick-1]=0;
              marker(pick-1,2);
              return 1;
            }
              if(pick!=31)
            if(previous_move_pick==(pick-15)&&previous_move_put==(pick+1)&&put==pick-7)
            {
              Board[pick+1]=0;
              marker(pick+1,2);
              return 1;
            }
             }

             if(put!=pick-8&&put!=pick-7&&put!=pick-9)
            return 0;

             if(put==pick-8)
             {
            if(Board[pick-8]!=0)
            return 0;
             }
             else if(put==pick-7)
             {
            if(Board[pick-7]==0||Board[pick-7]<10)
            return 0;
             }
             else if(put==pick-9)
             {
            if(Board[pick-9]==0||Board[pick-9]<10)
            return 0;
             }
        }

     if(put>=0 && put<=7)
     {
       int piece=0;
       setcolor(14);
       outtextxy(x+225,y-80,"Enter: ");
       outtextxy(x+225,y-60,"1-Queen");
       outtextxy(x+225,y-40,"2-Rook");
       outtextxy(x+225,y-20,"3-Bishop ");
       outtextxy(x+225,y,"4-Knight");
       gotoxy(72,17);
       cin>>piece;
       switch(piece)
       {
       case 1:  Board[put]=7;break;
       case 2:  Board[put]=5;break;
       case 3:  Board[put]=3;break;
       case 4:  Board[put]=2;break;
       default: Board[put]=7;break;
       }
       setcolor(6);
       outtextxy(x+225,y-80,"Enter: ");
       outtextxy(x+225,y-60,"1-Queen");
       outtextxy(x+225,y-40,"2-Rook");
       outtextxy(x+225,y-20,"3-Bishop ");
       outtextxy(x+225,y,"4-Knight");
       setfillstyle(SOLID_FILL,6);
       bar(x+225,y,x+300,y+50);
     return 2;
     }

    }

    else if(Board[pick]==11)
    {

        if(pick>=8&&pick<=15)
        {

             if(put!=pick+8&&put!=pick+16&&put!=pick+7&&put!=pick+9)
            return 0;

             if(put==pick+16)
             {
            if( Board[pick+8]!=0 || Board[pick+16]!=0)
            return 0;
             }
             else if(put==pick+8)
             {
            if(Board[pick+8]!=0)
            return 0;
             }
             else if(put==pick+7)
             {
            if(Board[pick+7]==0||Board[pick+7]>10)
            return 0;
             }
             else if(put==pick+9)
             {
            if(Board[pick+9]==0||Board[pick+9]>10)
            return 0;
             }
        }
        else if(pick>15)
        {
           if(pick<=39 && pick>=32)
           {
              if(pick!=39)
            if(previous_move_pick==(pick+17)&&previous_move_put==(pick+1)&&put==pick+9)
            {
              Board[pick+1]=0;
              marker(pick+1,2);
              return 1;
            }
              if(pick!=32)
            if(previous_move_pick==(pick+15)&&previous_move_put==(pick-1)&&put==pick+7)
            {
              Board[pick-1]=0;
              marker(pick-1,2);
              return 1;
            }
             }

             if(put!=pick+8&&put!=pick+7&&put!=pick+9)
            return 0;

             if(put==pick+8)
             {
            if(Board[pick+8]!=0)
            return 0;
             }
             else if(put==pick+7)
             {
            if(Board[pick+7]==0||Board[pick+7]>10)
            return 0;
             }
             else if(put==pick+9)
             {
            if(Board[pick+9]==0||Board[pick+9]>10)
            return 0;
             }
        }

     if(put>=56 && put<=63)
     {
       int piece=0;
       setcolor(14);
       outtextxy(x+225,y-80,"Enter: ");
       outtextxy(x+225,y-60,"1-Queen");
       outtextxy(x+225,y-40,"2-Rook");
       outtextxy(x+225,y-20,"3-Bishop ");
       outtextxy(x+225,y,"4-Knight");
       gotoxy(72,17);
       cin>>piece;
       switch(piece)
       {
       case 1:  Board[put]=17;break;
       case 2:  Board[put]=15;break;
       case 3:  Board[put]=13;break;
       case 4:  Board[put]=12;break;
       default: Board[put]=17;break;
       }
       setcolor(6);
       outtextxy(x+225,y-80,"Enter: ");
       outtextxy(x+225,y-60,"1-Queen");
       outtextxy(x+225,y-40,"2-Rook");
       outtextxy(x+225,y-20,"3-Bishop ");
       outtextxy(x+225,y,"4-Knight");
       setfillstyle(SOLID_FILL,6);
       bar(x+225,y,x+300,y+50);
     return 2;
     }

    }
    else if(Board[pick]==2||Board[pick]==12)
    {

    if(put!=pick-17&&put!=pick-15&&put!=pick+17&&put!=pick+15&&put!=pick-10&&put!=pick+6&&put!=pick+10&&put!=pick-6)
    return 0;


    if(pick%8==0)
       if(put==pick-17||put==pick+15||put==pick-10||put==pick+6)
           return 0;
    if(pick%8==1)
       if(put==pick-10||put==pick+6)
           return 0;
    if(pick%8==7)
       if(put==pick+17||put==pick-15||put==pick+10||put==pick-6)
           return 0;
    if(pick%8==6)
       if(put==pick+10||put==pick-6)
           return 0;

    if(pick>=0&&pick<=7)
       if(put==pick-17||put==pick-15||put==pick-10||put==pick-6)
           return 0;
    if(pick>=8&&pick<=15)
       if(put==pick-17||put==pick-15)
           return 0;

    if(pick>=56&&pick<=63)
       if(put==pick+17||put==pick+15||put==pick+10||put==pick+6)
           return 0;
    if(pick>=48&&pick<=55)
       if(put==pick+17||put==pick+15)
           return 0;

    }


if(Board[pick]==3||Board[pick]==13||Board[pick]==17||Board[pick]==7)
{


sx=pick%8;
sy=pick/8;

    if(sx>=sy)        leftup=sy;
    else            leftup=sx;

    if(sx>=(7-sy))        leftdown=7-sy;
    else            leftdown=sx;

    if((7-sx)>=sy)        rightup=sy;
    else            rightup=7-sx;

    if((7-sx)>=(7-sy))    rightdown=7-sy;
    else            rightdown=7-sx;

    for(i=1;i
    {
        if( put==(pick-9*i) )        return 1;
        else if( Board[pick-9*i]!=0)    break;
    }

    for(i=1;i
    {
        if( put==(pick+7*i) )        return 1;
        else if( Board[pick+7*i]!=0)    break;
    }
    for(i=1;i
    {
        if( put==(pick-7*i) )        return 1;
        else if( Board[pick-7*i]!=0)    break;
    }
    for(i=1;i
    {
        if( put==(pick+9*i) )        return 1;
        else if( Board[pick+9*i]!=0)    break;
    }


    if(Board[pick]==3||Board[pick]==13)
    return 0;

}


if(Board[pick]==5||Board[pick]==15||Board[pick]==17||Board[pick]==7)
{

sx=pick%8;
sy=pick/8;

up=sy;
down=7-sy;
right=7-sx;
left=sx;

    for(i=1;i
    {
        if( put==(pick-8*i) )        return 1;
        else if( Board[pick-8*i]!=0)    break;
    }
    for(i=1;i
    {
        if( put==(pick+8*i) )        return 1;
        else if( Board[pick+8*i]!=0)    break;
    }
    for(i=1;i
    {
        if( put==(pick-1*i) )        return 1;
        else if( Board[pick-1*i]!=0)    break;
    }
    for(i=1;i
    {
        if( put==(pick+1*i) )        return 1;
        else if( Board[pick+1*i]!=0)    break;
    }



    return 0;

}

 if(Board[pick]==9||Board[pick]==19)
 {

   if(pick==60&&put==62)
     {
     if(Board[61]==0&&Board[62]==0&&Board[63]==5)
       {
    Board[63]=0;
    Board[61]=5;
    marker(63,2);
    return 1;
       }
     }
   if(pick==60&&put==58)
     {
     if(Board[59]==0&&Board[58]==0&&Board[57]==0&&Board[56]==5)
       {
    Board[56]=0;
    Board[59]=5;
    marker(56,2);
    return 1;
       }
     }
   if(pick==4&&put==6)
     {
     if(Board[5]==0&&Board[6]==0&&Board[7]==15)
       {
    Board[7]=0;
    Board[5]=15;
    marker(7,2);
    return 1;
       }
     }
   if(pick==4&&put==2)
     {
     if(Board[3]==0&&Board[2]==0&&Board[1]==0&&Board[0]==15)
       {
    Board[0]=0;
    Board[3]=15;
    marker(0,2);
    return 1;
       }
     }


     if(pick%8==0)
     {
    if(put!=pick-8&&put!=pick+8&&put!=pick-7&&put!=pick+9&&put!=pick+1)
    return 0;
     }
     else if((pick+1)%8==0)
     {
    if(put!=pick-8&&put!=pick+8&&put!=pick-9&&put!=pick+7&&put!=pick-1)
    return 0;
     }
     else if(pick<=6&&pick>=1)
     {
    if(put!=pick+8&&put!=pick+9&&put!=pick+7&&put!=pick-1&&put!=pick+1)
    return 0;
     }
     else if(pick<=62&&pick>=57)
     {
    if(put!=pick-8&&put!=pick-9&&put!=pick-7&&put!=pick-1&&put!=pick+1)
    return 0;
     }
     else if(pick==0)
     {
    if(put!=pick+8&&put!=pick+9&&put!=pick+1)
    return 0;
     }
     else if(pick==7)
     {
    if(put!=pick+8&&put!=pick+7&&put!=pick-1)
    return 0;
     }
     else if(pick==63)
     {
    if(put!=pick-8&&put!=pick-9&&put!=pick-1)
    return 0;
     }
     else if(pick==56)
     {
    if(put!=pick-8&&put!=pick-7&&put!=pick+1)
    return 0;
     }
     else
     {
    if(put!=pick-8&&put!=pick+8&&put!=pick-9&&put!=pick+7&&put!=pick-1&&put!=pick+9&&put!=pick-7&&put!=pick+1)
    return 0;
     }

 }

return(1);
}

int marker(int position,short what)
{

int Dx,Dy;

   switch(position)
   {

        case 0:  Dx=-3; Dy=-3; break;  case 1:  Dx=-2; Dy=-3; break;
        case 2:  Dx=-1; Dy=-3; break;  case 3:  Dx=0; Dy=-3; break;
        case 4:  Dx=1; Dy=-3; break;   case 5:  Dx=2; Dy=-3; break;
        case 6:  Dx=3; Dy=-3; break;   case 7:  Dx=4; Dy=-3; break;

        case 8:  Dx=-3; Dy=-2; break;  case 9:  Dx=-2; Dy=-2; break;
        case 10:  Dx=-1; Dy=-2; break;  case 11:  Dx=0; Dy=-2; break;
        case 12:  Dx=1; Dy=-2; break;  case 13:  Dx=2; Dy=-2; break;
        case 14:  Dx=3; Dy=-2; break;  case 15:  Dx=4; Dy=-2; break;

        case 16:  Dx=-3; Dy=-1; break;  case 17:  Dx=-2; Dy=-1; break;
        case 18:  Dx=-1; Dy=-1; break;  case 19:  Dx=0; Dy=-1; break;
        case 20:  Dx=1; Dy=-1; break;  case 21:  Dx=2; Dy=-1; break;
        case 22:  Dx=3; Dy=-1; break;  case 23:  Dx=4; Dy=-1; break;

        case 24:  Dx=-3; Dy=0; break;  case 25:  Dx=-2; Dy=0; break;
        case 26:  Dx=-1; Dy=0; break;  case 27:  Dx=0; Dy=0; break;
        case 28:  Dx=1; Dy=0; break;  case 29:  Dx=2; Dy=0; break;
        case 30:  Dx=3; Dy=0; break;  case 31:  Dx=4; Dy=0; break;

        case 32:  Dx=-3; Dy=1; break;  case 33:  Dx=-2; Dy=1; break;
        case 34:  Dx=-1; Dy=1; break;  case 35:  Dx=0; Dy=1; break;
        case 36:  Dx=1; Dy=1; break;  case 37:  Dx=2; Dy=1; break;
        case 38:  Dx=3; Dy=1; break;  case 39:  Dx=4; Dy=1; break;

        case 40:  Dx=-3; Dy=2; break;  case 41:  Dx=-2; Dy=2; break;
        case 42:  Dx=-1; Dy=2; break;  case 43:  Dx=0; Dy=2; break;
        case 44:  Dx=1; Dy=2; break;  case 45:  Dx=2; Dy=2; break;
        case 46:  Dx=3; Dy=2; break;  case 47:  Dx=4; Dy=2; break;

        case 48:  Dx=-3; Dy=3; break;  case 49:  Dx=-2; Dy=3; break;
        case 50:  Dx=-1; Dy=3; break;  case 51:  Dx=0; Dy=3; break;
        case 52:  Dx=1; Dy=3; break;  case 53:  Dx=2; Dy=3; break;
        case 54:  Dx=3; Dy=3; break;  case 55:  Dx=4; Dy=3; break;

        case 56:  Dx=-3; Dy=4; break;  case 57:  Dx=-2; Dy=4; break;
        case 58:  Dx=-1; Dy=4; break;  case 59:  Dx=0; Dy=4; break;
        case 60:  Dx=1; Dy=4; break;  case 61:  Dx=2; Dy=4; break;
        case 62:  Dx=3; Dy=4; break;  case 63:  Dx=4; Dy=4; break;

        default:  gotoxy(3,3); cout<<"Error";break;

   }

int x,y;

x=getmaxx()/2+50+50*Dx;
y=getmaxy()/2-50+50*Dy;


    if(what==1)
        setcolor(7);
    else if(what==0)
        {
        if(Square_Color[position]==1)
             setcolor(15);
        else if(Square_Color[position]==0)
             setcolor(0);
        }
    else if(what==2)
        {
        x-=100;
        if(Square_Color[position]==1)
             setfillstyle(SOLID_FILL,15);
        else if(Square_Color[position]==0)
             setfillstyle(SOLID_FILL,0);
             bar(x,y,x+50,y+50);
             return 0;
        }
    else if(what==3)
        {
        x-=100;
        setcolor(LIGHTRED);
        rectangle(x+2,y+2,x+50-2,y+50-2);
        return 0;
        }
    else if(what==4)
        {
        if(Square_Color[position]==1)
             setcolor(15);
        else if(Square_Color[position]==0)
             setcolor(0);
        x-=100;
        rectangle(x+2,y+2,x+50-2,y+50-2);
        x+=100;
        }

rectangle(x-100+1,y+1,x-50-1,y+50-1);
line(x-85,y+1,x-65,y+1);
line(x-85,y+49,x-65,y+49);
line(x-99,y+15,x-99,y+35);
line(x-51,y+15,x-51,y+35);
line(x-85+1,y+1+1,x-65-1,y+1+1);
line(x-85+1,y+49-1,x-65-1,y+49-1);
line(x-99+1,y+15+1,x-99+1,y+35-1);
line(x-51-1,y+15+1,x-51-1,y+35-1);
return 0;

}


void draw_piece(int position)
{

int Dx,Dy;

 if(Board[position]!=0)
 {
   switch(position)
   {

        case 0:  Dx=-3; Dy=-3; break;  case 1:  Dx=-2; Dy=-3; break;
        case 2:  Dx=-1; Dy=-3; break;  case 3:  Dx=0; Dy=-3; break;
        case 4:  Dx=1; Dy=-3; break;   case 5:  Dx=2; Dy=-3; break;
        case 6:  Dx=3; Dy=-3; break;   case 7:  Dx=4; Dy=-3; break;

        case 8:  Dx=-3; Dy=-2; break;  case 9:  Dx=-2; Dy=-2; break;
        case 10:  Dx=-1; Dy=-2; break;  case 11:  Dx=0; Dy=-2; break;
        case 12:  Dx=1; Dy=-2; break;  case 13:  Dx=2; Dy=-2; break;
        case 14:  Dx=3; Dy=-2; break;  case 15:  Dx=4; Dy=-2; break;

        case 16:  Dx=-3; Dy=-1; break;  case 17:  Dx=-2; Dy=-1; break;
        case 18:  Dx=-1; Dy=-1; break;  case 19:  Dx=0; Dy=-1; break;
        case 20:  Dx=1; Dy=-1; break;  case 21:  Dx=2; Dy=-1; break;
        case 22:  Dx=3; Dy=-1; break;  case 23:  Dx=4; Dy=-1; break;

        case 24:  Dx=-3; Dy=0; break;  case 25:  Dx=-2; Dy=0; break;
        case 26:  Dx=-1; Dy=0; break;  case 27:  Dx=0; Dy=0; break;
        case 28:  Dx=1; Dy=0; break;  case 29:  Dx=2; Dy=0; break;
        case 30:  Dx=3; Dy=0; break;  case 31:  Dx=4; Dy=0; break;

        case 32:  Dx=-3; Dy=1; break;  case 33:  Dx=-2; Dy=1; break;
        case 34:  Dx=-1; Dy=1; break;  case 35:  Dx=0; Dy=1; break;
        case 36:  Dx=1; Dy=1; break;  case 37:  Dx=2; Dy=1; break;
        case 38:  Dx=3; Dy=1; break;  case 39:  Dx=4; Dy=1; break;

        case 40:  Dx=-3; Dy=2; break;  case 41:  Dx=-2; Dy=2; break;
        case 42:  Dx=-1; Dy=2; break;  case 43:  Dx=0; Dy=2; break;
        case 44:  Dx=1; Dy=2; break;  case 45:  Dx=2; Dy=2; break;
        case 46:  Dx=3; Dy=2; break;  case 47:  Dx=4; Dy=2; break;

        case 48:  Dx=-3; Dy=3; break;  case 49:  Dx=-2; Dy=3; break;
        case 50:  Dx=-1; Dy=3; break;  case 51:  Dx=0; Dy=3; break;
        case 52:  Dx=1; Dy=3; break;  case 53:  Dx=2; Dy=3; break;
        case 54:  Dx=3; Dy=3; break;  case 55:  Dx=4; Dy=3; break;

        case 56:  Dx=-3; Dy=4; break;  case 57:  Dx=-2; Dy=4; break;
        case 58:  Dx=-1; Dy=4; break;  case 59:  Dx=0; Dy=4; break;
        case 60:  Dx=1; Dy=4; break;  case 61:  Dx=2; Dy=4; break;
        case 62:  Dx=3; Dy=4; break;  case 63:  Dx=4; Dy=4; break;

        default:  gotoxy(3,3); cout<<"Error";break;

   }

 switch(Board[position])
   {
       case 1: pawn(White,Dx,Dy); break;
       case 11: pawn(Black,Dx,Dy); break;

       case 5: rook(White,Dx,Dy); break;
       case 15: rook(Black,Dx,Dy); break;

       case 2: knight(White,Dx,Dy); break;
       case 12: knight(Black,Dx,Dy); break;

       case 3: bishop(White,Dx,Dy); break;
       case 13: bishop(Black,Dx,Dy); break;

       case 7: queen(White,Dx,Dy); break;
       case 17: queen(Black,Dx,Dy); break;

       case 9: king(White,Dx,Dy); break;
       case 19: king(Black,Dx,Dy); break;

   }
 }
}

void chessboard()
{
int x,y,i;
x=getmaxx()/2;
y=getmaxy()/2;

///////////////////////////       chess board       ////////////////////////

//making board

for(i=0;i<450;i+=50)
{line(x-200+i,y-200,x-200+i,y+200);     }
for(i=0;i<450;i+=50)
{line(x-200,y-200+i,x+200,y-200+i);     }
setlinestyle(SOLID_LINE,1,3);

//filling color in squares

for(int g=0;g<400;g+=100)
for(int w=0;w<400;w+=100)
{floodfill(x-149+w,y-102+g,15);         }
for(g=0;g<400;g+=100)
for(w=0;w<400;w+=100)
{floodfill(x-199+w,y+102-g,15);         }

setlinestyle(SOLID_LINE,1,1);

/////////////////////////////  chess board completes  ////////////////////


}

void bishop(int color,float dx,float dy)
{
float x,y;
x=getmaxx()/2-25+50*dx;
y=getmaxy()/2-10+50*dy;
int col=0;

if(color==0)
col=4;
else if(color==1)
col=1;

setcolor(col);
ellipse(x,y,0,360,12,4);
ellipse(x,y-4,0,360,8,3);
line(x-5,y-4,x-3,y-25);
line(x+5,y-4,x+3,y-25);
ellipse(x,y-25,0,360,8,3);
circle(x,y-28,6);
circle(x,y-35,2);
line(x-3,y-24,x+3,y-24);
setcolor(0);
line(x-5,y-28,x+5,y-28);
line(x-3,y-23,x+3,y-23);
line(x-4,y-7,x+4,y-7);

setfillstyle(SOLID_FILL,col);
floodfill(x,y-36,col);

if(color==0)
setfillstyle(SOLID_FILL,14);
else if(color==1)
setfillstyle(SOLID_FILL,3);

floodfill(x-7,y-25,col);
floodfill(x+7,y-25,col);
floodfill(x,y-23,col);
floodfill(x,y-28,col);
floodfill(x,y-18,col);
floodfill(x,y,col);
setfillstyle(SOLID_FILL,col);
floodfill(x,y-3,col);
floodfill(x-6,y-4,col);
floodfill(x+6,y-4,col);
}

void knight(int color,float dx,float dy)
{
float x,y;
x=getmaxx()/2-25+50*dx;
y=getmaxy()/2-10+50*dy;
int col=0;

if(color==0)
col=4;
else if(color==1)
col=1;

setcolor(col);
ellipse(x,y,0,360,14,4);
ellipse(x,y-4,150,360,9,3);
line(x-7,y-3,x-8,y-12);
line(x-6,y-18,x-8,y-12);
line(x-6,y-18,x-3,y-22);
line(x-6,y-24,x-3,y-22);
line(x-6,y-24,x-11,y-24);

line(x+8,y-3,x+7,y-12);
line(x+6,y-20,x+7,y-12);
line(x+6,y-20,x+7,y-24);
line(x+6,y-30,x+7,y-24);
line(x+6,y-30,x+7,y-34);
line(x+4,y-31,x+7,y-34);
line(x+4,y-32,x-2,y-32);
line(x-4,y-30,x-2,y-32);
line(x-4,y-30,x-8,y-30);
line(x-11,y-29,x-8,y-30);
line(x-11,y-29,x-12,y-27);
line(x-11,y-25,x-12,y-27);
circle(x-2,y-28,1);
setcolor(0);
line(x-6,y-4,x+6,y-4);
if(color==0)
setfillstyle(SOLID_FILL,14);
else if(color==1)
setfillstyle(SOLID_FILL,3);
floodfill(x,y-18,col);
floodfill(x,y,col);
}



void rook(int color,float dx,float dy)
{
float x,y;
x=getmaxx()/2-25+50*dx;
y=getmaxy()/2-10+50*dy;
int col=0;

if(color==0)
col=4;
else if(color==1)
col=1;

setcolor(col);
ellipse(x,y,180,360,13,4);
ellipse(x,y-4,0,360,13,4);
ellipse(x,y-20-2,180,360,10,3);
ellipse(x,y-24-2,0,360,10,3);

line(x-10,y-20-2,x-10,y-24-2);
line(x+10,y-20-2,x+10,y-24-2);
line(x-13,y,x-13,y-4);
line(x+13,y,x+13,y-4);
line(x+7,y-17-2,x+7,y-5);
line(x-7,y-17-2,x-7,y-5);
line(x-10,y-25-2,x-10,y-28-2);
line(x-5,y-27-2,x-5,y-31-2);
line(x-10,y-28-2,x-5,y-31-2);
line(x+10,y-25-2,x+10,y-28-2);
line(x+5,y-27-2,x+5,y-31-2);
line(x+10,y-28-2,x+5,y-31-2);

rectangle(x-4,y-24-2,x+4,y-22-2);
putpixel(x-6,y-27-2,col);
putpixel(x+6,y-27-2,col);
setcolor(0);
line(x-6,y-8,x+6,y-8);
line(x-9,y-25-2,x-6,y-26-2);
line(x+9,y-25-2,x+6,y-26-2);

if(color==0)
setfillstyle(SOLID_FILL,14);
else if(color==1)
setfillstyle(SOLID_FILL,3);
bar(x-3,y-23-2,x+3,y-21-2);
floodfill(x,y-25-2,col);
floodfill(x,y-10,col);
floodfill(x,y+1,col);
floodfill(x,y-21-2,col);
}

void pawn(int color,float dx,float dy)
{
float x,y;
x=getmaxx()/2-25+50*dx;
y=getmaxy()/2-10+50*dy;
int col=0;

if(color==0)
col=4;
else if(color==1)
col=1;

setcolor(col);
ellipse(x,y,0,360,8,2);
ellipse(x,y-3,0,360,6,2);
ellipse(x,y-18,0,360,6,2);
line(x-3,y-5,x-3,y-17);
line(x+3,y-5,x+3,y-17);
circle(x,y-23,4);

setcolor(0);
line(x-2,y-5,x+2,y-5);
line(x-3,y-2,x+3,y-2);
line(x-1,y-20,x+1,y-20);
if(color==0)
setfillstyle(SOLID_FILL,14);
else if(color==1)
setfillstyle(SOLID_FILL,3);
floodfill(x,y,col);
floodfill(x,y-21,col);
floodfill(x,y-18,col);
floodfill(x,y-10,col);

}


void queen(int color,float dx,float dy)
{
int x,y;
x=getmaxx()/2-25+50*dx;
y=getmaxy()/2-10+50*dy;
int col=0;

if(color==0)
col=4;
else if(color==1)
col=1;

setcolor(col);
ellipse(x,y,0,360,18,4);
ellipse(x,y-4,130,45,14,3);
line(x-2,y-5,x-1,y-28);
line(x+2,y-5,x+1,y-28);
line(x-2,y-5,x-9,y-25);
line(x-5,y-5,x-10,y-24);
line(x-4,y-5,x-15,y-16);
line(x-8,y-5,x-16,y-15);
line(x+2,y-5,x+9,y-25);
line(x+5,y-5,x+10,y-24);
line(x+4,y-5,x+15,y-16);
line(x+8,y-5,x+16,y-15);
circle(x,y-32,4);
circle(x-10,y-27,2);
circle(x-18,y-18,2);
circle(x+10,y-27,2);
circle(x+18,y-18,2);

setcolor(0);
line(x-7,y-4,x+7,y-4);
line(x-8,y-3,x-10,y-3);
line(x+8,y-3,x+10,y-3);
if(color==0)
setfillstyle(SOLID_FILL,14);
else if(color==1)
setfillstyle(SOLID_FILL,3);
floodfill(x,y,col);
floodfill(x,y-14,col);
setfillstyle(SOLID_FILL,col);
floodfill(x,y-32,col);
floodfill(x-10,y-27,col);
floodfill(x-18,y-18,col);
floodfill(x+10,y-27,col);
floodfill(x+18,y-18,col);
if(color==0)
setcolor(14);
else if(color==1)
setcolor(3);

circle(x,y-32,4);
circle(x-10,y-27,2);
circle(x-18,y-18,2);
circle(x+10,y-27,2);
circle(x+18,y-18,2);
}


void king(int color,float dx,float dy)
{
float x,y;
x=getmaxx()/2-25+50*dx;
y=getmaxy()/2-10+50*dy;
int col=0;

if(color==0)
col=4;
else if(color==1)
col=1;

setcolor(col);
ellipse(x,y,0,360,18,4);
ellipse(x,y-4,130,45,14,3);

line(x-3,y-10,x,y-16);
line(x+3,y-10,x,y-16);
line(x-3,y-10,x,y-4);
line(x+3,y-10,x,y-4);

line(x-8,y-25,x,y-18);
line(x-8,y-25,x-13,y-27);
line(x-16,y-26,x-13,y-27);
line(x-17,y-25,x-16,y-26);
line(x-17,y-25,x-18,y-20);
line(x-17,y-15,x-18,y-20);
line(x-17,y-15,x-9,y-7);

line(x+8,y-25,x,y-18);
line(x+8,y-25,x+13,y-27);
line(x+16,y-26,x+13,y-27);
line(x+17,y-25,x+16,y-26);
line(x+17,y-25,x+18,y-20);
line(x+17,y-15,x+18,y-20);
line(x+17,y-15,x+9,y-7);

ellipse(x,y-25,0,360,3,5);
line(x,y-30,x,y-37);
line(x-3,y-34,x+3,y-34);
setcolor(0);
line(x-7,y-4,x+7,y-4);
line(x-8,y-3,x-10,y-3);
line(x+8,y-3,x+10,y-3);

if(color==0)
setfillstyle(SOLID_FILL,14);
else if(color==1)
setfillstyle(SOLID_FILL,3);
floodfill(x,y,col);
floodfill(x,y-11,col);
floodfill(x,y-23,col);
setfillstyle(SOLID_FILL,col);
floodfill(x-8,y-11,col);
}



Friday, May 21, 2010

gaming art works

Wednesday, May 5, 2010

The Wireless Application Protocol (WAP) and implementing WAP in gaming

URL: http://www.wapforum.org
The Wireless Application Protocol (WAP) is a set of standards based on the Internet Protocols (IP) and the Extensible Markup Language (XML). WAP is an open and global standard for wireless applications. WAP was designed to operate seamlessly over CMDA, CDPD, and all other major wireless network types.
WAP's primary technology—the Wireless Markup Language (WML)—is based on HDML and was developed by Unwired Planet (which became Phone.com and is now Openwave), Motorola, Nokia, and Ericsson. These companies and others have formed an open organization devoted to WAP called the WAP Forum.
WAP content is accessed using standard Uniform Resource Locators (URLs), just as Web pages are. Pages written in WML have the .WML extension, just as most HTML pages end with .HTML.
Most modern mobile phones support some version of WAP. Many phones come preloaded
with the Openwave (Phone.com) Mobile Browser. The following section is not intended to be a full WAP primer. Rather, it will provide a brief overview of most WML tags and attributes, allowing you to create simple WAP structures in which to support your Micro Java games.
The WAP Protocol Stack
The protocols that make up WAP are based strongly on the Internet Protocols. The Web protocol stack includes old favorites such as HTML, HTTP, SSL, UDP/IP, and TCP/IP. This is a very robust and efficient suite of protocols, to be sure. However, the Web stack itself is quite large, and provides more functionality than most mobile phones need.
Because of this, a special WAP protocol stack was created. The stack includes, in order
• An application layer—The actual application used to display things to the user. This uses the Wireless Application Environment (WAE) displaying pages written with WML.
• A session layer—How connections are made. This layer uses the Wireless Session Protocol (WSP).
• A transaction layer—How data is divided. This layer uses the Wireless Transaction Protocol (WTP).
• A security layer—Encrypts the data. This layer uses Wireless Transport Layer Security (WTLS).
• A datagram layer—How the data is packaged and sent across the network. This is done
using the Wireless Datagram Protocol (WDP). The WDP can use different bearers, such
as CDPD, SMS, and so on.
Wireless carriers and cell phone manufacturers need to worry about implementing all these
protocols properly. Lowly game developers need only focus on writing the actual applications
using WML and WMLScript.
WAP Architecture
A WAP browser works very similarly to a Web browser, and a WAP server works similarly to a Web server. As in the Web world, the client requests a page from a server. The server then responds with the page data. There is no continual connection. If the server has more data to send to the client, then another client request must first be made.
In the world of WAP, a phone is known as a user agent. In fact, most WAP pages come to the phone from a standard Web server, directed through a special server called a WAP gateway.

works as follows:
1. A mobile phone user asks for a specific URL.
2. The request is sent over a proprietary wireless network, using WAP protocols, to a gateway machine.
3. The gateway translates the request to HTTP and sends it to a standard Web server.
4. The Web server will grab or dynamically generate the content (usually a WML document) and send this response back to the gateway.
5. The gateway encodes the WML and WMLScript into byte code and sends it to the phone.
6. The phone processes the byte code and displays the first card to the user.

The Wireless Markup Language (WML)
The Wireless Markup Language is very similar, in concept, to the Hyper Text Markup Language
(HTML) used to create most Web pages. Obviously, a rich HTML Web site with snazzy animations, tons of colors, and fantastic music won't look quite so snazzy on a postage-stampsized black and white screen. WML was built to address the typical mobile phone's limitations:
• The screen is 20 or fewer characters across, and only three to six lines tall. As such, WML needs only very basic text formatting and layout abilities.
• Most phones have only a small amount of memory and rudimentary processor power. As such, the object model of how WMLScript can dynamically access a WML deck is vastly simplified.
• Typically, a phone only has only a numeric keypad. As such, all of WML's input methods are basic edit fields and option selections. Nothing that might rely on mouse or keyboard input is supported.
• Data transfer rates are extremely slow, which means latency is extremely high. As such, WML applications are not sent as separate pages requiring many separate requests and responses, but as one big deck separated into individual cards.
• Bandwidth, or the amount of data that can be uploaded or downloaded per second, is extremely limited. WML and WMLScript are usually compressed into tight runnable byte code, which means that a heavy WML file doesn't need to be parsed on the phone, but rather on the gateway server.
WML is currently released as version 1.3. However, most phones only support WML 1.1. The WML tags in this blog should work with WAP 1.1 browsers and up.

WML Basics
Every WML file must begin with a standard prologue, including an XML header and a document
definition tag:


"http://www.wapforum.org/DTD/wml_1.1.xml">
WARNING
Since WML is based on XML, it is case sensitive—every tag and attribute should be in
lowercase. Also, tags cannot be nested incorrectly. For example, the following line is illegal
and will generate errors:
Hello!

The rest of the code must be surrounded by and .
A Game of Cards and Decks In the world of the desktop Internet browser, there are Web sites and Web pages. On a mobile phone, there are decks and cards.
A card is a screen that a user sees and can interact with. There can only be one card visible at a time. There is no notion of various windows that can be moved around, minimized, or maximized. Each card is surrounded by the tags:

and

The id attribute refers to the name of the card. This name must be a single word with no spaces or wacky characters. Every card in a deck must have a different id name.
The title attribute is a short description of the card, and is usually displayed at the top of the mobile phone's screen. Each card must have at least one paragraph in it, as designated by the tags and
.Some WAP phones do not show the card title at all, so don't rely on it being there. A deck is a set of cards. When your mobile phone downloads a WML file, it is getting an entire deck. The first card in the deck is activated. Later cards can then be activated using their id as the user selects various menu or other options.
A deck must begin with

and end with

So, taking all these rules together, the world's simplest WML file might look like this:


"http://www.wapforum.org/DTD/wml_1.1.xml">




Wow! This is one of the world's most simple WML files!




Wow! The second card!

Anchors Away
You can use anchors to go from one card to another, or to actually load a new deck from the
server. Anchor text or images will be hypertext, and will usually appear underlined. Players will
be allowed to select this hypertext using the up/down/left/right keys on their mobile phones.
The tag contains inner tags:
Click Here— Loads a new WML deck and
brings up a specific card. If you omit the # symbol in the href attribute, then the first
card in the given deck will be brought up.


Likewise, if you omit the deck name completely and only use the # symbol, then you can
jump to a card within the currently active deck.
The tag is similar to the hyperlink tag in HTML. It allows you to send a
request to the server, asking for a specific URL.
Note that the tag can also contain a special tag called that allows
you to post parameters to the Web server:

— Goes to the previously loaded WML card.
Click Here— Reloads the current card.
— No operation. This does nothing at all. This is usually done to show a
command that is currently disabled.
So, to switch to a new card in a deck

Select here to bring up a new card
from the current deck


To switch to a new deck entirely

Select here to bring up a new deck


Most requests will return a new WML document. The WML document can be static, or created
dynamically by a CGI script, Java servlet, JSP, ASP, or other server-side technology.
For example, a request to a Java servlet might look like this:

The tag allows you to change certain variables and then reload the same or a
different card:

Select here to refresh variable x
85




Note that you can also use the
tag, similar to HTML, which is the same as using the
and combination:
Select here to bring up a new card.
Or
Select here to bring up a new deck.


Text Formatting Tags
Since a mobile phone doesn't have a lot of room or a wide variety of colors and fonts, only a few
tags are actually supported in WML.
The most popular tags for formatting text include the following:

— Used to add a line break. Because this tag stands alone and has no closing tag,
it must contain a slash.

My Paragraph
— Separates chunks of text into paragraphs.
I am mighty— Used to make text stronger (usually the same as
making text bold).
Emphasize me, baby!— Used to emphasize text (usually the same as
italicizing).
I am bold— Used to make text bold.
I am italic— Used to make text italicized.
I am underlined— Used to underline text.
Wee little me— Makes text smaller.
Big bad me— Makes text larger.
So the following code might appear as in Figure 4.4:


"http://www.wapforum.org/DTD/wml_1.1.xml">



Hello

I'm bold

I'm italic

I'm underlined

I'm big

I'm small


Be aware that some phones do not support many of these tags. For example, an older WAP
browser may only allow paragraph breaks and line breaks, but no bolding, italicizing, or
underlining.
NOTE
You can add a comment to a WML file using the same comment tags that work in HTML:

Tables
Although using tables is discouraged because there's usually not enough room for them, standard
table tags are supported similarly to HTML.
You surround your table with
and

You can create rows and columns using the following tags:
• Row— Surrounds a given row of text.
87
• Column— Creates a given column.
The following code creates a small two-by-two column table:
Top Left Top Right
Bottom Left Bottom Right

For example:
Top Left Top Right
Bottom Left Bottom Right
User Input Tags
The user input controls will look different on every phone you use. You can use many of the same input elements that you'll find in an HTML form.
Input Fields
Typically, a user input field is an empty box in which a person can type in a number, word, or phrase. Because typing on a cell phone is usually an arduous task, many phones will bring up a special screen when an input field is selected.
You can create a standard input field named "test" as follows:

An input field possesses several attributes:
• name— The name of the field, which will become a variable name you can access later or
send to the server.
• emptyok— Set to true if the text field can be left blank. By default this is set to false.
• maxlength— The maximum length of characters that a user can enter.
• size— The width of the field, indicated in number of characters.
• title— Sets a title for the input field. This will be displayed on some phones when the
user is inside this field.
• type— Sets the type of input field. By default this is text, but you might also have a
password type of field. In password fields, anything the user enters usually appears as
an asterisk, for added security.
• value— Sets the default value for this input field.
• format— The type of data that can be entered in the field. The default is *M. The types
are as follows:
A—Uppercase alphabetic characters
a—Lowercase alphabetic characters
88
N—Numeric characters
X—Uppercase characters of any type
x—Lowercase characters of any type
M—All characters
Precede any of the these types with an asterisk to indicate that any number of characters can be entered.
Precede any of the these types with a specific number from 1 to 9 to specify that the user must enter a specific amount of the given character type.
So, to create a 10 character-wide input field that must be numeric and can contain only 10 characters, you would use the following:

Option Groups
You can create a pull-down option list by surrounding the list with the and tags, and surrounding each individual option using the and tags:

First Option
Second Option

Each option tag can take several attributes, such as:
• value— Sets the value for the option that will be dumped into the variable, should the
option be selected.
• onpick— This attribute takes a URL or anchor card name as a parameter. If the given
option is selected, then the given URL is requested.
Check Boxes and Radio Buttons
To create check boxes, you can use the Field Sets
Finally, you can visibly group the buttons together into a sort of set. To do so, simply surround elements inside your user input forms with

and

This can help group check boxes or radio buttons.

"http://www.wapforum.org/DTD/wml_1.1.xml">




Name:







The Tag
The tag lets the user perform some sort of global command or other task on the current card.The command will usually appear in the soft-key menus at the bottom of the mobile phone's display. Most phones allow for two soft keys. If you create more than two options, then one of the soft-key commands will usually become Menu, which will lead to a special menu of
additional choices. The label attribute is the label for the command that will be shown to the
user.
The name attribute creates a variable name for the element.
The type attribute lets you choose what sort of command you wish to create. Various browsers
will display these commands in different ways. Usually, up to two commands can be shown on the
screen, mapped to the mobile phone's two command buttons. Other phones may display the
commands in a nested menu, or along with a special icon.
The following are some valid command types:
• accept— Acknowledgement of a message or event.
• prev— Navigate back to a previous deck.
• help— Help about this card.
• reset— Reset the WAP browser.
• options— A selection from a list of options.
• delete— Delete an item or choice.
• unknown— A special type, not one of the preceding types.
To perform an action, simply surround it with the and tags. To jump to a card in the
current deck named card2, you could use



The following command will add a back command to the current card, allowing you to go to the
previously loaded card:



Variables
WML files are capable of keeping track of and changing simple variables. This lets your WML
application keep information between cards.
To explicitly set the variable i to 10, use the tag:

Whenever you create an input element, the results are stored as variables. Simply use the name of
the element preceded by a dollar sign. You can surround the variable name by parentheses to
separate it from any other text.
So, to create a small application that asks the user for their name and then displays it, you could
use the following code:


"http://www.wapforum.org/DTD/wml_1.1.xml">
92









Your name is: $(myname)



The name is input in the first card (with the id of input). Then the card with the id result is called, as soon as the OK! button is pressed. The result is then displayed. Images
As with HTML, WML does support an tag:
MeThe src attribute points to an image in the WBMP format. This format is a special, tiny blackand-white bitmap created to fit snugly on wireless devices.

Timers
When using WAP, the connection between a mobile phone and the server does not remain
persistent between requests. If the server needs to send an update to the client, it has no way to do
so until the client explicitly requests a new deck.
Many games and other time-sensitive applications will need to constantly poll the server, asking
for any new updates. This can be done using a simple WML timer.
Set the ontimer attribute of the tag to point to the WML page you wish to update. You
can then use the tag to create the countdown, setting the value in tenths
of a second.
To refresh the WML document every three seconds, simply use the following:



Some Message


WMLScript
If you've followed along so far, you've noticed that WML has very limited interactivity on the
client side. Really, all you can do is display simple text and images, collect a little information via
user input forms, and send it all to the server to process.
Just as HTML has JavaScript (based on the ECMAScript standard), some WML browsers support
a special client-side scripting language called WMLScript. WMLScript is a much simpler subset
of ECMAScript. In addition, WMLScript is compiled into bytecode by the WAP gateway before
being sent down to the phone.
WARNING
Many WAP Browsers do not support WMLScript. Be sure to research your target platform
before relying on any client-side scripting. Check out the excellent table at
http://www.allnetdevices.com/faq/useragents.php3 to determine what version of WAP your
target device supports.
WMLScript is used, for the most part, to verify user input before wasting precious time sending it
to the server. For example, if you ask your game player for his age, a simple WMLScript can be
sure the input is indeed a number, isn't negative, and isn't over 200. If the results aren't valid, a
dialog box can pop up telling the player to enter a new number.
In addition, some versions of WMLScript allow you to access special features of the user agent,
such as the following:
• Dialog boxes to alert the user of something or to request input
• Make phone calls
• Access the SIM card
• Access or change the address book
• Configure the phone preferences
94
Accessing WML Script
WMLScript files are stored separately from WML files. They usually have the .wmls extension.
You can access a WMLScript file's WML the same way you would request any other document:

You can access specific external functions within WMLScript using the hash symbol. This allows
you to pass in variables. For example, the following file requests a variable called myvar and then
passes it to the process() function within a WMLScript file:


"http://www.wapforum.org/DTD/wml_1.1.xml">






Type something here:


WMLScript Example
You can make a simple guessing game entirely on the client side using WMLScript. For example,
you can create a dialog box that asks the user for a random number.
A function will pick a random number and compare it the user's guess, and show a card indicating
whether the user was correct.
The following is the code for GuessNumber.wml:


"http://www.WAPforum.org/DTD/wml_1.1.xml">



Guessing a Random Number...






You were right!
Number was $(randresult)


95


Sorry. Wrong!
Number was $(randresult)


Here's the code for RandomGuess.wmls:
extern function guessrandom()
{
// Request a number, 0 by default
var thenum = 0;
// Loop until a valid number is picked.
do
{
var r = Dialogs.prompt("Pick a number between 1 and 10", "0");
thenum = Lang.parseInt(r);
}
while (thenum < 1 || thenum > 10)
var randnum = Lang.random(10)+1;
// set the randresult variable
WMLBrowser.setVar("randresult", randnum);
if (randnum == thenum)
WMLBrowser.go("GuessNumber.wml#right");
else
WMLBrowser.go("GuessNumber.wml#wrong");
} ;
The guessrandom() function is preceded by the extern modifier, meaning that it can be
accessed by external WML or WMLScript documents.
Note that the variable randnum is a script variable, and can only be set and accessed within this
WMLScript function.
The randresult variable, however, is set using WMLScript's setVar() method, meaning it
will be an active browser variable—active and accessible as long as the player is visiting the
current WAP site.
Server-Side WAP
Most any Web server can serve out WML pages. You will, however, need to modify your server
using the instructions given in this section.
Server Configuration
Every response your Web server sends to a browser is tagged with a special header. One of the
most important lines of the header tells the browser what the content-type of the document is. This
content-type is expressed using a standard known as the Multipurpose Internet Mail Extension
(MIME).
96
The MIME type of HTML files, for example, is text/html. For WAP documents, you need to
add several new MIME types to allow for WML files, WML script files, compiled WML files,
and WBMP wireless bitmaps:
• text/vnd.wap.wml
• application/vnd.wap.wmlc
• text/vnd.wap.wmlscript
• application/vnd.wap.wmlscriptc
• image/vnd.wap.wbmp
Most Web servers make it easy to add new MIME types. Many servers have a
httpd.conf file in which these types can be added.
WAP and Java
Although some WAP pages will never change and can be written using a standard text editor or
HTML authoring tool, most WAP games and game tools will involve lots of dynamic information
such as game state, scores, number of users in a lobby, chat messages, and so on.
That means that the Web server will need to generate WML decks and cards on-the-fly. Serverside Java technologies, such as JavaServer Pages (JSPs) and Java Servlets, are a great way to pump out the necessary WML.
A Servlet Game Lobby For example, here's a simple servlet that can allow an unlimited number of players to chat with each other. This can lead up to a full-featured lobby where players can match up and then be joined together to play Java games.
The WAP need only call the servlet with one parameter:
mymessage
The servlet will take that message and return the last five lines of chat.
This is obviously a very simplified version of a game lobby. A real lobby would force users to log in with a password, keep track of the user's name, keep track of which chat lines each user has already seen, match players together, and kick off game sessions.
Sample
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class SimpleChatServlet extends HttpServlet {
// Store last five messages
private static String message[] = new String[5];
public void init() throws ServletException
{
// Set messages to blank for now
for (int i=0; i < 5; i++)
97
message[i] = "";
}
public void doGet(HttpServletRequest request,HttpServletResponse
response)
throws ServletException,IOException
{
// set content type as wap.wml
response.setContentType("text/vnd.wap.wml");
// create a print writer output
PrintWriter out = response.getWriter();
// get the latest message, if any
String mymsg = request.getParameter("mymessage");
// If the message isn't null, add it to the top of the queue
if (mymsg != null)
{
for (int i=4; i > 0; i—)
{
// Replace message with previous message
message[i] = message[i-1];
}
message[0] = mymsg;
}
// write the data
out.println("");
out.println("
1.1//EN\"");
out.println(" \"http://www.wapforum.org/DTD/wml_1.1.xml\">");
out.println("");
out.println("");
// Send any new messages back to this servlet
out.println("");
out.println(" method=\"get\">");
out.println(" value=\"$mymsg\"/>");
out.println("
");
out.println("
");
out.println("

");
// print out the last five messages
for (int i=0; i < 5; i++)
{
out.println(message[i]+"
");
}
out.println("
");
// Request a new chat message
out.println("");
out.println("Chat:
name=\"mymsg\"/>");
out.println("
");
out.println("
");
out.println("
");
out.println("
");
}
}Any WML card that requests this servlet will send its own chat message and retrieve the last five
messages that have been sent. Effectively, this servlet will pump out a WML file that looks like
the following:


"http://www.wapforum.org/DTD/wml_1.1.xml">







Message 1

Message 2

Message 3

Message 4

Message 5



Chat:



99

Using JavaServer Pages (JSPs)
Similarly, JavaServer Pages (JSPs) can be used to dynamically create cards, using variables that
can be created programmatically.
Here's a simple example:


"http://www.wapforum.org/DTD/wml_1.1.xml">
<%
response.setContentType("text/vnd.wap.wml");
out.println("");
out.println("");
out.println("
");
out.println("Date: "+ new java.util.Date());
out.println("
");
out.println("
");
out.println("
");
%>
Development Environment
To develop WAP applications, you can use a number of different environments. Every major cell phone manufacturer offers a software development kit that allows you to create and emulate their precise WAP environment.

Twitter Delicious Facebook Digg Stumbleupon Favorites More