X-Git-Url: http://royale.zerezo.com/git/?p=zeRace;a=blobdiff_plain;f=zeRace.c;h=9277dd3b74bf5935dd74b00a43745bec15f3afbf;hp=6f787e059854f8975a5204079e4157ac3f0ff85d;hb=HEAD;hpb=ee6ec6d95d78f74973a2ba97077cc94709bb6c61 diff --git a/zeRace.c b/zeRace.c index 6f787e0..9277dd3 100644 --- a/zeRace.c +++ b/zeRace.c @@ -1,5 +1,5 @@ /* - * zeRace 0.4, a funny retro racing game + * zeRace 0.7, a funny retro racing game * http://royale.zerezo.com/zerace/ * * Copyright (C) 2004 Antoine Jacquet @@ -41,6 +41,15 @@ #define WIDTH 1024 #define HEIGHT 768 #define MAXRECORDKEYS 9999 +#define NB_CARS 16 + +/* some usefull colors */ +#define C_BLACK SDL_MapRGB(screen->format,0,0,0) +#define C_WHITE SDL_MapRGB(screen->format,255,255,255) +#define C_RED SDL_MapRGB(screen->format,255,0,0) +#define C_ORANGE SDL_MapRGB(screen->format,255,200,0) +#define C_YELLOW SDL_MapRGB(screen->format,255,255,100) +#define T_BLACK SDL_MapRGB(cir->format,0,0,0) /* tracklist */ struct _tracklist *tracklist; @@ -59,7 +68,9 @@ struct _config SDLKey right; int color; SDLKey boss; -} config = {"anonymous","",0,0,1,SDLK_UP,SDLK_DOWN,SDLK_LEFT,SDLK_RIGHT,6,SDLK_b}; + int bynight; + int internet; +} config = {"anonymous","",0,0,1,SDLK_UP,SDLK_DOWN,SDLK_LEFT,SDLK_RIGHT,6,SDLK_b,0,1}; /* full script for a lap */ struct _record @@ -71,7 +82,7 @@ struct _record /* display and all directions for the car */ SDL_Surface *screen; -SDL_Surface *cars[12][256]; +SDL_Surface *cars[NB_CARS][256]; /* network stuff */ UDPsocket udpsock=NULL; @@ -83,7 +94,7 @@ int network_speed=1; void zeRace_read_config() { FILE *fic; - if ((fic=fopen("zeRace.cfg","rt"))==NULL) + if ((fic=fopen("zeRace.cfg","rb"))==NULL) { fprintf(stderr,"can't open config file \"zeRace.cfg\"\n"); return; @@ -97,7 +108,7 @@ void zeRace_read_config() void zeRace_save_config() { FILE *fic; - if ((fic=fopen("zeRace.cfg","wt"))==NULL) + if ((fic=fopen("zeRace.cfg","wb"))==NULL) { fprintf(stderr,"can't create config file \"zeRace.cfg\"\n"); return; @@ -132,6 +143,8 @@ void zeRace_check_version() char response[1024],*tmp,*version; int len,result; + if (!config.internet) return; + printf("checking version... "); fflush(stdout); @@ -188,6 +201,8 @@ void zeRace_update_tracks() int len,result; FILE *fic; + if (!config.internet) return; + printf("checking version and updating tracks... "); fflush(stdout); @@ -239,6 +254,8 @@ void zeRace_download_file(char *file) FILE *fic; struct stat buf; + if (!config.internet) return; + if (stat(file,&buf)<0) { printf("downloading file \"%s\" : ",file); @@ -268,7 +285,7 @@ void zeRace_download_file(char *file) fprintf(stderr,"SDLNet_TCP_Send: %s\n",SDLNet_GetError()); else { - if ((fic=fopen(file,"wt"))==NULL) + if ((fic=fopen(file,"wb"))==NULL) { fprintf(stderr,"can't create \"%s\" file\n",file); zeRace_exit(); @@ -294,7 +311,7 @@ void zeRace_generate_cars() int i,j; SDL_Surface *car; char temp[20]="sprites/carX.png"; - for (i=0;i<12;i++) + for (i=0;inext!=loopcheck) + do { zeRace_download_file(tracklist->full); zeRace_download_file(tracklist->function); tracklist=tracklist->next; - } + } while (tracklist!=loopcheck); srand(time(NULL)); - if (SDL_Init(SDL_INIT_VIDEO|SDL_INIT_AUDIO)<0) - { - fprintf(stderr,"could not initialize SDL : %s\n",SDL_GetError()); - zeRace_exit(); - } - atexit(SDL_Quit); - - if (SDLNet_Init()==-1) - { - fprintf(stderr,"could not initialize SDLNet : %s\n",SDLNet_GetError()); - zeRace_exit(); - } - packet=SDLNet_AllocPacket(1024); if (!packet) { @@ -405,7 +424,7 @@ void zeRace_init() /* send the best time for this race to the web server */ -void zeRace_send_time(struct _record record) +void zeRace_send_time(struct _record *record) { IPaddress ip; TCPsocket tcpsock; @@ -428,8 +447,10 @@ void zeRace_send_time(struct _record record) char *msg9="&bkeys="; int len,result; + if (!config.internet) return; + /* if the best time is small enought to save all keys, send it */ - if (record.time>=MAXRECORDKEYS) return; + if (record->time>=MAXRECORDKEYS) return; printf("sending time... "); fflush(stdout); @@ -447,8 +468,8 @@ void zeRace_send_time(struct _record record) return; } - temp=(char *)malloc(strlen(msg1)+strlen(config.pseudo)+strlen(msg2)+strlen(config.url)+strlen(msg3)+strlen(tracklist->name)+strlen(msg4)+10+strlen(msg5)+10+strlen(msg6)+10+strlen(msg7)+10+strlen(msg8)+10+strlen(msg9)+strlen(record.keys)+100); - sprintf(temp,"%s%s%s%s%s%s%s%d%s%f%s%f%s%f%s%f%s%s\n",msg1,config.pseudo,msg2,config.url,msg3,tracklist->name,msg4,record.time,msg5,record.x,msg6,record.y,msg7,record.speed,msg8,record.angle,msg9,record.keys); + temp=(char *)malloc(strlen(msg1)+strlen(config.pseudo)+strlen(msg2)+strlen(config.url)+strlen(msg3)+strlen(tracklist->name)+strlen(msg4)+10+strlen(msg5)+10+strlen(msg6)+10+strlen(msg7)+10+strlen(msg8)+10+strlen(msg9)+strlen(record->keys)+100); + sprintf(temp,"%s%s%s%s%s%s%s%d%s%f%s%f%s%f%s%f%s%s\n",msg1,config.pseudo,msg2,config.url,msg3,tracklist->name,msg4,record->time,msg5,record->x,msg6,record->y,msg7,record->speed,msg8,record->angle,msg9,record->keys); len=strlen(temp); result=SDLNet_TCP_Send(tcpsock,temp,len); @@ -481,10 +502,35 @@ void print_time(int x,int y,int time) } +/* car lights */ +void lights(int x,int y,int r,Uint32 pixel) +{ + putpixel(screen,x,y,pixel); + if (r>1) + { + putpixel(screen,x-1,y,pixel); + putpixel(screen,x+1,y,pixel); + putpixel(screen,x,y-1,pixel); + putpixel(screen,x,y+1,pixel); + } + if (r>2) + { + putpixel(screen,x-2,y,pixel); + putpixel(screen,x+2,y,pixel); + putpixel(screen,x,y-2,pixel); + putpixel(screen,x,y+2,pixel); + putpixel(screen,x-1,y-1,pixel); + putpixel(screen,x-1,y+1,pixel); + putpixel(screen,x+1,y-1,pixel); + putpixel(screen,x+1,y+1,pixel); + } +} + + /* launch a new race */ void zeRace_launch(int alltime,int go) { - SDL_Surface *cir,*fun; + SDL_Surface *cir,*fun,*hilight; SDL_Rect pos; SDL_Event event; int ku=0,kd=0,kl=0,kr=0,i; @@ -496,7 +542,8 @@ void zeRace_launch(int alltime,int go) int lastack=alltime; struct _record net; struct _car oldnetpos[MAX_CLIENTS],newnetpos[MAX_CLIENTS]; - + int l=80,o=15; + /* free memory */ void free_mem() { @@ -513,13 +560,31 @@ void zeRace_launch(int alltime,int go) } cir=IMG_Load(tracklist->full); + /* dark the track if it is night */ + if (config.bynight) + { + for (pos.x=0;pos.xw;pos.x++) + for (pos.y=0;pos.yh;pos.y++) + { + Uint32 c; + Uint8 r,g,b; + c=getpixel(cir,pos.x,pos.y); + SDL_GetRGB(c,cir->format,&r,&g,&b); + r*=0.3; + g*=0.3; + b*=0.3; + putpixel(cir,pos.x,pos.y,SDL_MapRGB(cir->format,r,g,b)); + } + } fun=IMG_Load(tracklist->function); + hilight=IMG_Load("sprites/light.png"); current.speed=car.speed=0; current.angle=car.angle=tracklist->a*2*M_PI/360; current.x=car.ox=car.x=tracklist->x; current.y=car.oy=car.y=tracklist->y; car.lastcheck=0; + car.lapflag=0; car.w=cars[0][0]->w; car.h=cars[0][0]->h; current.time=0; @@ -581,7 +646,7 @@ void zeRace_launch(int alltime,int go) SDLNet_UDP_Send(udpsock,-1,packet); SDL_Flip(screen); } - zeRace_send_time(best); + zeRace_send_time(&best); free_mem(); return; default: @@ -626,6 +691,9 @@ void zeRace_launch(int alltime,int go) net.keys[net.time+1]='\0'; } + /* move the car */ + move_car(&car,(ku<<3 | kd<<2 | kl<<1 | kr),fun); + delay=DELAY; /* if we are in network mode */ if (udpsock!=NULL) @@ -648,17 +716,30 @@ void zeRace_launch(int alltime,int go) for (i=0;idata+strlen("positions")+1+4+4+2+i*8); - newnetpos[i].y=SDLNet_Read16(packet->data+strlen("positions")+1+4+4+2+i*8+2); - newnetpos[i].angle=(float)SDLNet_Read16(packet->data+strlen("positions")+1+4+4+2+i*8+2+2)/1000; - newnetpos[i].color=SDLNet_Read16(packet->data+strlen("positions")+1+4+4+2+i*8+2+2+2); + newnetpos[i].x=SDLNet_Read16(packet->data+strlen("positions")+1+4+4+2+i*14); + newnetpos[i].y=SDLNet_Read16(packet->data+strlen("positions")+1+4+4+2+i*14+2); + newnetpos[i].angle=(float)SDLNet_Read16(packet->data+strlen("positions")+1+4+4+2+i*14+2+2)/1000; + newnetpos[i].color=SDLNet_Read16(packet->data+strlen("positions")+1+4+4+2+i*14+2+2+2); + newnetpos[i].lights_brake=SDLNet_Read16(packet->data+strlen("positions")+1+4+4+2+i*14+2+2+2+2); + newnetpos[i].lights_backwards=SDLNet_Read16(packet->data+strlen("positions")+1+4+4+2+i*14+2+2+2+2+2); + newnetpos[i].lights_warning=SDLNet_Read16(packet->data+strlen("positions")+1+4+4+2+i*14+2+2+2+2+2+2); } lastack=clienttime; } } + else if (strcmp(packet->data,"collision")==0) + { + net.time=-1; + net.keys[0]='\0'; + lastack=SDLNet_Read32(packet->data+strlen("collision")+1); + car.x=(float)SDLNet_Read32(packet->data+strlen("collision")+1+4)/65536-100; + car.y=(float)SDLNet_Read32(packet->data+strlen("collision")+1+4+4)/65536-100; + car.speed=(float)SDLNet_Read32(packet->data+strlen("collision")+1+4+4+4)/65536-100; + car.angle=(float)SDLNet_Read32(packet->data+strlen("collision")+1+4+4+4+4)/65536-100; + } else /* end of this network race */ { - zeRace_send_time(best); + zeRace_send_time(&best); free_mem(); return; } @@ -669,6 +750,10 @@ void zeRace_launch(int alltime,int go) tmp+=strlen(tmp)+1; SDLNet_Write32(lastack,tmp); tmp+=4; + SDLNet_Write32(car.x,tmp); + tmp+=4; + SDLNet_Write32(car.y,tmp); + tmp+=4; strcpy(tmp,net.keys); tmp+=strlen(tmp)+1; packet->len=(void *)tmp-(void *)packet->data+10; @@ -697,6 +782,25 @@ void zeRace_launch(int alltime,int go) pos.h=car.h; SDL_BlitSurface(cir,&pos,screen,&pos); + /* clear the lights */ + if (config.bynight) + { + pos.x=car.ox-cos(car.angle)*l-sin(car.angle)*o; + pos.y=car.oy-sin(car.angle)*l+cos(car.angle)*o; + pos.x-=60; + pos.y-=60; + pos.w=120; + pos.h=120; + SDL_BlitSurface(cir,&pos,screen,&pos); + pos.x=car.ox-cos(car.angle)*l+sin(car.angle)*o; + pos.y=car.oy-sin(car.angle)*l-cos(car.angle)*o; + pos.x-=60; + pos.y-=60; + pos.w=120; + pos.h=120; + SDL_BlitSurface(cir,&pos,screen,&pos); + } + /* display the network car at the new position */ if (udpsock) for (i=0;iscreen->w) pos.w=screen->w-pos.x; + if (pos.y+pos.h>screen->h) pos.h=screen->h-pos.y; + SDL_UpdateRect(screen,pos.x,pos.y,pos.w,pos.h); + pos.x=car.x-cos(car.angle)*l+sin(car.angle)*15; + pos.y=car.y-sin(car.angle)*l-cos(car.angle)*15; + pos.x-=60; + pos.y-=60; + pos.w=120; + pos.h=120; + if (pos.x<0) pos.x=0; + if (pos.y<0) pos.y=0; + if (pos.x+pos.w>screen->w) pos.w=screen->w-pos.x; + if (pos.y+pos.h>screen->h) pos.h=screen->h-pos.y; + SDL_UpdateRect(screen,pos.x,pos.y,pos.w,pos.h); + } + memcpy(oldnetpos,newnetpos,MAX_CLIENTS*sizeof(struct _car)); - /* move the car */ - move_car(&car,(ku<<3 | kd<<2 | kl<<1 | kr),fun); - /* play engine sound if no sound is currently playing */ if (lastsound_time+100w/2-splash->w/2-1; pos.w=splash->w+2; pos.y=screen->h/2-splash->h/2-1; pos.h=splash->h+2; - SDL_FillRect(screen,&pos,0xffffff); + SDL_FillRect(screen,&pos,C_WHITE); pos.x=screen->w/2-splash->w/2; pos.y=screen->h/2-splash->h/2; SDL_BlitSurface(splash,NULL,screen,&pos); @@ -844,7 +1065,7 @@ void zeRace_local() { SDL_Surface *full,*preview; SDL_Rect pos; - SDL_FillRect(screen,NULL,0x000000); + SDL_FillRect(screen,NULL,C_BLACK); print(screen,WIDTH/2-28*5,HEIGHT/6,"* Please choose your race *"); print(screen,WIDTH/2-strlen(tracklist->title)*5,5*HEIGHT/6-20,tracklist->title); print(screen,WIDTH/2-(strlen(tracklist->author)+strlen("Author : "))*5,5*HEIGHT/6+0,"Author : "); @@ -862,7 +1083,7 @@ void zeRace_local() pos.w=preview->w+2; pos.y=screen->h/2-preview->h/2-1; pos.h=preview->h+2; - SDL_FillRect(screen,&pos,0xffffff); + SDL_FillRect(screen,&pos,C_WHITE); pos.x=WIDTH/2-preview->w/2; pos.y=screen->h/2-preview->h/2; SDL_BlitSurface(preview,NULL,screen,&pos); @@ -914,7 +1135,7 @@ void zeRace_top10(char *buf) { int i,nb,tmp; SDL_Rect pos; - SDL_FillRect(screen,NULL,0x000000); + SDL_FillRect(screen,NULL,C_BLACK); nb=SDLNet_Read16(buf); buf+=2; print(screen,WIDTH/2-16*5,HEIGHT/14,"* Race results *"); @@ -966,7 +1187,7 @@ void zeRace_connect(char *host,int port) tmp+=strlen(tmp)+1; go=*tmp++; printf("server asked for track : %s\n",tmp); - while (tracklist->next!=loopcheck) if (strcmp(tracklist->name,tmp)==0) break; else tracklist=tracklist->next; + do if (strcmp(tracklist->name,tmp)==0) break; else tracklist=tracklist->next; while (tracklist!=loopcheck); if (strcmp(tracklist->name,tmp)!=0) { fprintf(stderr,"unknown track : %s\n",tmp); @@ -999,7 +1220,7 @@ void zeRace_network() void update() { - SDL_FillRect(screen,NULL,0x000000); + SDL_FillRect(screen,NULL,C_BLACK); print(screen,380,HEIGHT/(NETWORK_OPTIONS+4)*(3+active),">"); print(screen,WIDTH/2-18*5,HEIGHT/(NETWORK_OPTIONS+4),"* Network screen *"); print(screen,400,HEIGHT/(NETWORK_OPTIONS+4)*3,"Server : "); @@ -1083,6 +1304,8 @@ void zeRace_internet() int active=0; #define INTERNET_OPTIONS 11 + if (!config.internet) return; + printf("dowloading list of servers... "); fflush(stdout); @@ -1128,7 +1351,7 @@ void zeRace_internet() void update() { int i; - SDL_FillRect(screen,NULL,0x000000); + SDL_FillRect(screen,NULL,C_BLACK); print(screen,380,HEIGHT/(INTERNET_OPTIONS+4)*(3+active),">"); print(screen,WIDTH/2-19*5,HEIGHT/(INTERNET_OPTIONS+4),"* Internet screen *"); for (i=0;i<10;i++) @@ -1186,12 +1409,12 @@ void zeRace_config() { SDL_Event event; int active=0; - #define CONFIG_OPTIONS 12 + #define CONFIG_OPTIONS 14 void update() { SDL_Rect pos; - SDL_FillRect(screen,NULL,0x000000); + SDL_FillRect(screen,NULL,C_BLACK); print(screen,20,HEIGHT/(CONFIG_OPTIONS+4)*(3+active),">"); print(screen,WIDTH/2-24*5,HEIGHT/(CONFIG_OPTIONS+4),"* Configuration screen *"); print(screen,40,HEIGHT/(CONFIG_OPTIONS+4)*3,"Pseudo : "); @@ -1218,6 +1441,10 @@ void zeRace_config() SDL_BlitSurface(cars[config.color][0],NULL,screen,&pos); print(screen,40,HEIGHT/(CONFIG_OPTIONS+4)*13,"Boss key : "); print(screen,40+10*strlen("Boss key : "),HEIGHT/(CONFIG_OPTIONS+4)*13,config.boss?SDL_GetKeyName(config.boss):""); + print(screen,40,HEIGHT/(CONFIG_OPTIONS+4)*14,"By night : "); + print(screen,40+10*strlen("By night : "),HEIGHT/(CONFIG_OPTIONS+4)*14,config.bynight?"Yes":"No"); + print(screen,40,HEIGHT/(CONFIG_OPTIONS+4)*15,"Internet : "); + print(screen,40+10*strlen("Internet : "),HEIGHT/(CONFIG_OPTIONS+4)*15,config.internet?"Yes":"No"); print(screen,40,HEIGHT/(CONFIG_OPTIONS+4)*(CONFIG_OPTIONS+2),"Back to main menu"); SDL_Flip(screen); } @@ -1267,11 +1494,13 @@ void zeRace_config() case 8: config.right=0; update(); config.right=read_key(); break; case 9: if (event.key.keysym.sym==SDLK_LEFT) config.color--; else config.color++; - if (config.color<0) config.color=11; - if (config.color>11) config.color=0; + if (config.color<0) config.color=NB_CARS-1; + if (config.color>NB_CARS-1) config.color=0; break; case 10: config.boss=0; update(); config.boss=read_key(); break; - case 11: + case 11: config.bynight=!config.bynight; break; + case 12: config.internet=!config.internet; break; + case 13: return; } update(); @@ -1306,7 +1535,7 @@ void zeRace_menu() void update() { SDL_Rect pos; - SDL_FillRect(screen,NULL,0x000000); + SDL_FillRect(screen,NULL,C_BLACK); pos.x=WIDTH/2-logo->w/2; pos.y=HEIGHT/6-logo->h/2; SDL_BlitSurface(logo,NULL,screen,&pos);