- terrain.DoShadows();
- objects.DoShadows();
-}
-
-static void ch_skylight(Game *game, const char *args)
-{
- sscanf(args, "%f%f%f", &skyboxlightr, &skyboxlightg, &skyboxlightb);
-
- game->SetUpLighting();
-
- terrain.DoShadows();
- objects.DoShadows();
-}
-
-static void ch_skybox(Game *game, const char *args)
-{
- skyboxtexture = !skyboxtexture;
-
- game->SetUpLighting();
-
- terrain.DoShadows();
- objects.DoShadows();
-}
-
-static void cmd_dispatch(Game *game, const char *cmd)
-{
- int i, n_cmds = sizeof(cmd_names) / sizeof(cmd_names[0]);
-
- for (i = 0; i < n_cmds; i++)
- if (stripfx(cmd, cmd_names[i]))
- {
- cmd_handlers[i](game, cmd + strlen(cmd_names[i]));
- break;
- }
- emit_sound_np(i < n_cmds ? consolesuccesssound : consolefailsound);
-}
-
-/********************> Tick() <*****/
-extern bool save_image(const char * fname);
-void Screenshot (void)
-{
- char temp[1024];
- time_t t = time(NULL);
- struct tm *tme = localtime(&t);
- sprintf(temp, "Screenshots/Screenshot_%04d_%02d_%02d--%02d_%02d_%02d.png", tme->tm_year + 1900, tme->tm_mon + 1, tme->tm_mday, tme->tm_hour, tme->tm_min, tme->tm_sec);
-
- #if defined(_WIN32)
- mkdir("Screenshots");
- #else
- mkdir("Screenshots", S_IRWXU);
- #endif
-
- save_image(temp);
-}
-
-
-
-void Game::SetUpLighting(){
- if(environment==snowyenvironment)
- light.setColors(.65,.65,.7,.4,.4,.44);
- if(environment==desertenvironment)
- light.setColors(.95,.95,.95,.4,.35,.3);
- if(environment==grassyenvironment)
- light.setColors(.95,.95,1,.4,.4,.44);
- if(!skyboxtexture)
- light.setColors(1,1,1,.4,.4,.4);
- float average;
- average=(skyboxlightr+skyboxlightg+skyboxlightb)/3;
- light.color[0]*=(skyboxlightr+average)/2;
- light.color[1]*=(skyboxlightg+average)/2;
- light.color[2]*=(skyboxlightb+average)/2;
- light.ambient[0]*=(skyboxlightr+average)/2;
- light.ambient[1]*=(skyboxlightg+average)/2;
- light.ambient[2]*=(skyboxlightb+average)/2;
-}
-
-int Game::findPathDist(int start,int end){
- int smallestcount,count,connected;
- int last,last2,last3,last4;
- int closest;
-
- smallestcount=1000;
- for(int i=0;i<50;i++){
- count=0;
- last=start;
- last2=-1;
- last3=-1;
- last4=-1;
- while(last!=end&&count<30){
- closest=-1;
- for(int j=0;j<numpathpoints;j++){
- if(j!=last&&j!=last2&&j!=last3&&j!=last4)
- {
- connected=0;
- if(numpathpointconnect[j])
- for(int k=0;k<numpathpointconnect[j];k++){
- if(pathpointconnect[j][k]==last)connected=1;
- }
- if(!connected)
- if(numpathpointconnect[last])
- for(int k=0;k<numpathpointconnect[last];k++){
- if(pathpointconnect[last][k]==j)connected=1;
- }
- if(connected)
- if(closest==-1||Random()%2==0){
- closest=j;
- }
- }
- }
- last4=last3;
- last3=last2;
- last2=last;
- last=closest;
- count++;
- }
- if(count<smallestcount)smallestcount=count;
- }
- return smallestcount;
-}
-
-int Game::checkcollide(XYZ startpoint,XYZ endpoint){
- static XYZ colpoint,colviewer,coltarget;
- static float minx,minz,maxx,maxz,miny,maxy;
-
- minx=min(startpoint.x,endpoint.x)-1;
- miny=min(startpoint.y,endpoint.y)-1;
- minz=min(startpoint.z,endpoint.z)-1;
- maxx=max(startpoint.x,endpoint.x)+1;
- maxy=max(startpoint.y,endpoint.y)+1;
- maxz=max(startpoint.z,endpoint.z)+1;
-
- for(int i=0;i<objects.numobjects;i++){
- if( objects.position[i].x>minx-objects.model[i].boundingsphereradius&&
- objects.position[i].x<maxx+objects.model[i].boundingsphereradius&&
- objects.position[i].y>miny-objects.model[i].boundingsphereradius&&
- objects.position[i].y<maxy+objects.model[i].boundingsphereradius&&
- objects.position[i].z>minz-objects.model[i].boundingsphereradius&&
- objects.position[i].z<maxz+objects.model[i].boundingsphereradius){
- if( objects.type[i]!=treeleavestype&&
- objects.type[i]!=bushtype&&
- objects.type[i]!=firetype){
- colviewer=startpoint;
- coltarget=endpoint;
- if(objects.model[i].LineCheck(&colviewer,&coltarget,&colpoint,&objects.position[i],&objects.rotation[i])!=-1)return i;
- }
- }
- }
-
- //if(terrain.lineTerrain(startpoint,endpoint,&colpoint)!=-1)return 1000;
-
- return -1;
-}
-
-int Game::checkcollide(XYZ startpoint,XYZ endpoint,int what){
- static XYZ colpoint,colviewer,coltarget;
- static float minx,minz,maxx,maxz,miny,maxy;
- static int i; //FIXME: see below
-
- minx=min(startpoint.x,endpoint.x)-1;
- miny=min(startpoint.y,endpoint.y)-1;
- minz=min(startpoint.z,endpoint.z)-1;
- maxx=max(startpoint.x,endpoint.x)+1;
- maxy=max(startpoint.y,endpoint.y)+1;
- maxz=max(startpoint.z,endpoint.z)+1;
-
- if(what!=1000){
- if( objects.position[what].x>minx-objects.model[what].boundingsphereradius&&
- objects.position[what].x<maxx+objects.model[what].boundingsphereradius&&
- objects.position[what].y>miny-objects.model[what].boundingsphereradius&&
- objects.position[what].y<maxy+objects.model[what].boundingsphereradius&&
- objects.position[what].z>minz-objects.model[what].boundingsphereradius&&
- objects.position[what].z<maxz+objects.model[what].boundingsphereradius){
- if( objects.type[what]!=treeleavestype&&
- objects.type[what]!=bushtype&&
- objects.type[what]!=firetype){
- colviewer=startpoint;
- coltarget=endpoint;
- //FIXME: i/what
- if(objects.model[what].LineCheck(&colviewer,&coltarget,&colpoint,&objects.position[what],&objects.rotation[what])!=-1)return i;
- }
- }
- }
-
- if(what==1000)if(terrain.lineTerrain(startpoint,endpoint,&colpoint)!=-1)return 1000;
-
- return -1;
-}
-
-void Game::Setenvironment(int which)
-{
- LOGFUNC;
-
- LOG(" Setting environment...");
-
- float temptexdetail;
- environment=which;
-
- pause_sound(stream_music1snow);
- pause_sound(stream_music1grass);
- pause_sound(stream_music1desert);
- pause_sound(stream_wind);
- pause_sound(stream_desertambient);
-
-
- if(environment==snowyenvironment){
- windvector=0;
- windvector.z=3;
- if(ambientsound)
- emit_stream_np(stream_wind);
-
- LoadTexture(":Data:Textures:snowtree.png",&objects.treetextureptr,0,1);
- LoadTexture(":Data:Textures:bushsnow.png",&objects.bushtextureptr,0,1);
- LoadTexture(":Data:Textures:bouldersnow.jpg",&objects.rocktextureptr,1,0);
- LoadTexture(":Data:Textures:snowbox.jpg",&objects.boxtextureptr,1,0);
-
- footstepsound = footstepsn1;
- footstepsound2 = footstepsn2;
- footstepsound3 = footstepst1;
- footstepsound4 = footstepst2;
-
- LoadTexture(":Data:Textures:snow.jpg",&terraintexture,1,0);
-
- LoadTexture(":Data:Textures:rock.jpg",&terraintexture2,1,0);
-
- //LoadTexture(":Data:Textures:detailgrain.png",&terraintexture3,1);
-
-
-
-
- temptexdetail=texdetail;
- if(texdetail>1)texdetail=4;
- skybox.load( ":Data:Textures:Skybox(snow):Front.jpg",
- ":Data:Textures:Skybox(snow):Left.jpg",
- ":Data:Textures:Skybox(snow):Back.jpg",
- ":Data:Textures:Skybox(snow):Right.jpg",
- ":Data:Textures:Skybox(snow):Up.jpg",
- ":Data:Textures:Skybox(snow):Down.jpg");
-
-
-
-
- texdetail=temptexdetail;
- }
- if(environment==desertenvironment){
- windvector=0;
- windvector.z=2;
- LoadTexture(":Data:Textures:deserttree.png",&objects.treetextureptr,0,1);
- LoadTexture(":Data:Textures:bushdesert.png",&objects.bushtextureptr,0,1);
- LoadTexture(":Data:Textures:boulderdesert.jpg",&objects.rocktextureptr,1,0);
- LoadTexture(":Data:Textures:desertbox.jpg",&objects.boxtextureptr,1,0);
-
-
- if(ambientsound)
- emit_stream_np(stream_desertambient);
-
- footstepsound = footstepsn1;
- footstepsound2 = footstepsn2;
- footstepsound3 = footstepsn1;
- footstepsound4 = footstepsn2;
-
- LoadTexture(":Data:Textures:sand.jpg",&terraintexture,1,0);
-
- LoadTexture(":Data:Textures:sandslope.jpg",&terraintexture2,1,0);
-
- //LoadTexture(":Data:Textures:detailgrain.png",&terraintexture3,1);
-
-
-
- temptexdetail=texdetail;
- if(texdetail>1)texdetail=4;
- skybox.load( ":Data:Textures:Skybox(sand):Front.jpg",
- ":Data:Textures:Skybox(sand):Left.jpg",
- ":Data:Textures:Skybox(sand):Back.jpg",
- ":Data:Textures:Skybox(sand):Right.jpg",
- ":Data:Textures:Skybox(sand):Up.jpg",
- ":Data:Textures:Skybox(sand):Down.jpg");
-
-
-
-
- texdetail=temptexdetail;
- }
- if(environment==grassyenvironment){
- windvector=0;
- windvector.z=2;
- LoadTexture(":Data:Textures:tree.png",&objects.treetextureptr,0,1);
- LoadTexture(":Data:Textures:bush.png",&objects.bushtextureptr,0,1);
- LoadTexture(":Data:Textures:boulder.jpg",&objects.rocktextureptr,1,0);
- LoadTexture(":Data:Textures:grassbox.jpg",&objects.boxtextureptr,1,0);
-
- if(ambientsound)
- emit_stream_np(stream_wind, 100.);
-
- footstepsound = footstepgr1;
- footstepsound2 = footstepgr2;
- footstepsound3 = footstepst1;
- footstepsound4 = footstepst2;
-
- LoadTexture(":Data:Textures:grassdirt.jpg",&terraintexture,1,0);
-
- LoadTexture(":Data:Textures:mossrock.jpg",&terraintexture2,1,0);
-
- //LoadTexture(":Data:Textures:detail.png",&terraintexture3,1);
-
-
-
- temptexdetail=texdetail;
- if(texdetail>1)texdetail=4;
- skybox.load( ":Data:Textures:Skybox(grass):Front.jpg",
- ":Data:Textures:Skybox(grass):Left.jpg",
- ":Data:Textures:Skybox(grass):Back.jpg",
- ":Data:Textures:Skybox(grass):Right.jpg",
- ":Data:Textures:Skybox(grass):Up.jpg",
- ":Data:Textures:Skybox(grass):Down.jpg");
-
-
-
- texdetail=temptexdetail;
- }
- temptexdetail=texdetail;
- texdetail=1;
- terrain.load(":Data:Textures:heightmap.png");
-
- texdetail=temptexdetail;
-}
-
-
-void Game::Loadlevel(int which){
- stealthloading=0;
- whichlevel=which;
-
- if (which == -1) {
- tutoriallevel = -1;
- Loadlevel("tutorial");
- } else if (which >= 0 && which <= 15) {
- char buf[32];
- snprintf(buf, 32, "map%d", which + 1);
- Loadlevel(buf);
- } else
- Loadlevel("mapsave");
-}
-
-void Game::Loadlevel(const char *name){
- static int oldlevel;
- int templength;
- float lamefloat;
- int lameint;
- static const char *pfx = ":Data:Maps:";
- char *buf;
-
- float headprop,legprop,armprop,bodyprop;
-
- LOGFUNC;
-
- LOG(std::string("Loading level...") + name);
-
- if(!gameon)
- visibleloading=1;
- if(stealthloading)
- visibleloading=0;
- if(!stillloading)
- loadtime=0;
- gamestarted=1;
-
- numenvsounds=0;
- //visibleloading=1;
- if(tutoriallevel!=-1)
- tutoriallevel=0;
- else
- tutoriallevel=1;
-
- if(tutoriallevel==1)
- tutorialstage=0;
- if(tutorialstage==0){
- tutorialstagetime=0;
- tutorialmaxtime=1;
- }
- loadingstuff=1;
- if(!firstload)
- oldlevel=50;
- pause_sound(whooshsound);
- pause_sound(stream_firesound);
-
- // Change the map filename into something that is os specific
- buf = (char*) alloca(strlen(pfx) + strlen(name) + 1);
- sprintf(buf, "%s%s", pfx, name);
- const char *FixedFN = ConvertFileName(buf);
-
- int mapvers;
- FILE *tfile;
- tfile=fopen( FixedFN, "rb" );
- if(tfile){
- pause_sound(stream_firesound);
- scoreadded=0;
- windialogue=0;
- hostiletime=0;
- won=0;
-
- animation[bounceidleanim].Load((char *)"Idle",middleheight,neutral);
-
- numdialogues=0;
-
- for(int i=0;i<20;i++)
- dialoguegonethrough[i]=0;
-
- indialogue=-1;
- cameramode=0;
-
- damagedealt=0;
- damagetaken=0;
-
- if(accountactive)
- difficulty=accountactive->getDifficulty();
-
- if(difficulty!=2)
- minimap=1;
- else
- minimap=0;
-
- numhotspots=0;
- currenthotspot=-1;
- bonustime=1;
-
- skyboxtexture=1;
- skyboxr=1;
- skyboxg=1;
- skyboxb=1;
-
- freeze=0;
- winfreeze=0;
-
- for(int i=0;i<100;i++)
- bonusnum[i]=0;
-
- numfalls=0;
- numflipfail=0;
- numseen=0;
- numstaffattack=0;
- numswordattack=0;
- numknifeattack=0;
- numunarmedattack=0;
- numescaped=0;
- numflipped=0;
- numwallflipped=0;
- numthrowkill=0;
- numafterkill=0;
- numreversals=0;
- numattacks=0;
- maxalarmed=0;
- numresponded=0;
-
- bonustotal=startbonustotal;
- bonus=0;
- gameon=1;
- changedelay=0;
- if(console){
- emit_sound_np(consolesuccesssound);
- freeze=0;
- console=0;
- }
-
- if(!stealthloading){
- terrain.numdecals=0;
- Sprite::deleteSprites();
- for(int i=0;i<objects.numobjects;i++)
- objects.model[i].numdecals=0;
-
- int j=objects.numobjects;
- for(int i=0;i<j;i++){
- objects.DeleteObject(0);
- if(visibleloading)
- LoadingScreen();
- }
-
- for(int i=0;i<subdivision;i++)
- for(int j=0;j<subdivision;j++)
- terrain.patchobjectnum[i][j]=0;
- if(visibleloading)
- LoadingScreen();
- }
-
- weapons.numweapons=0;
-
- funpackf(tfile, "Bi", &mapvers);
- if(mapvers>=15)
- funpackf(tfile, "Bi", &indemo);
- else
- indemo=0;
- if(mapvers>=5)
- funpackf(tfile, "Bi", &maptype);
- else
- maptype=mapkilleveryone;
- if(mapvers>=6)
- funpackf(tfile, "Bi", &hostile);
- else
- hostile=1;
- if(mapvers>=4)
- funpackf(tfile, "Bf Bf", &viewdistance, &fadestart);
- else{
- viewdistance=100;
- fadestart=.6;
- }
- if(mapvers>=2)
- funpackf(tfile, "Bb Bf Bf Bf", &skyboxtexture, &skyboxr, &skyboxg, &skyboxb);
- else{
- skyboxtexture=1;
- skyboxr=1;
- skyboxg=1;
- skyboxb=1;
- }
- if(mapvers>=10)
- funpackf(tfile, "Bf Bf Bf", &skyboxlightr, &skyboxlightg, &skyboxlightb);
- else{
- skyboxlightr=skyboxr;
- skyboxlightg=skyboxg;
- skyboxlightb=skyboxb;
- }
- if(!stealthloading)
- funpackf(tfile, "Bf Bf Bf Bf Bf Bi", &player[0].coords.x,&player[0].coords.y,&player[0].coords.z,&player[0].rotation,&player[0].targetrotation, &player[0].num_weapons);
- if(stealthloading)
- funpackf(tfile, "Bf Bf Bf Bf Bf Bi", &lamefloat,&lamefloat,&lamefloat,&lamefloat,&lamefloat, &player[0].num_weapons);
- player[0].originalcoords=player[0].coords;
- if(player[0].num_weapons>0&&player[0].num_weapons<5)
- for(int j=0;j<player[0].num_weapons;j++){
- player[0].weaponids[j]=weapons.numweapons;
- funpackf(tfile, "Bi", &weapons.type[weapons.numweapons]);
- weapons.owner[weapons.numweapons]=0;
- weapons.numweapons++;
- }
-
- if(visibleloading)
- LoadingScreen();
-
- funpackf(tfile, "Bf Bf Bf", &player[0].armorhead, &player[0].armorhigh, &player[0].armorlow);
- funpackf(tfile, "Bf Bf Bf", &player[0].protectionhead, &player[0].protectionhigh, &player[0].protectionlow);
- funpackf(tfile, "Bf Bf Bf", &player[0].metalhead, &player[0].metalhigh, &player[0].metallow);
- funpackf(tfile, "Bf Bf", &player[0].power, &player[0].speedmult);
-
- funpackf(tfile, "Bi", &player[0].numclothes);
-
- if(mapvers>=9)
- funpackf(tfile, "Bi Bi", &player[0].whichskin, &player[0].creature);
- else{
- player[0].whichskin=0;
- player[0].creature=rabbittype;
- }
-
- player[0].lastattack=-1;
- player[0].lastattack2=-1;
- player[0].lastattack3=-1;
-
- //dialogues
- if(mapvers>=8){
- funpackf(tfile, "Bi", &numdialogues);
- for(int k=0;k<numdialogues;k++){
- funpackf(tfile, "Bi", &numdialogueboxes[k]);
- funpackf(tfile, "Bi", &dialoguetype[k]);
- for(int l=0;l<10;l++){
- funpackf(tfile, "Bf Bf Bf", &participantlocation[k][l].x, &participantlocation[k][l].y, &participantlocation[k][l].z);
- funpackf(tfile, "Bf", &participantrotation[k][l]);
- }
- for(int l=0;l<numdialogueboxes[k];l++){
- funpackf(tfile, "Bi", &dialogueboxlocation[k][l]);
- funpackf(tfile, "Bf", &dialogueboxcolor[k][l][0]);
- funpackf(tfile, "Bf", &dialogueboxcolor[k][l][1]);
- funpackf(tfile, "Bf", &dialogueboxcolor[k][l][2]);
- funpackf(tfile, "Bi", &dialogueboxsound[k][l]);
-
- bool doneread;
-
- funpackf(tfile, "Bi",&templength);
- if(templength>128||templength<=0)
- templength=128;
- int m;
- for(m=0;m<templength;m++){
- funpackf(tfile, "Bb", &dialoguetext[k][l][m]);
- if(dialoguetext[k][l][m]=='\0')
- break;
- }
- dialoguetext[k][l][m] = 0;
-
- funpackf(tfile, "Bi",&templength);
- if(templength>64||templength<=0)templength=64;
- for(m=0;m<templength;m++){
- funpackf(tfile, "Bb", &dialoguename[k][l][m]);
- if(dialoguename[k][l][m]=='\0')
- break;
- }
- dialoguename[k][l][m] = 0;
- funpackf(tfile, "Bf Bf Bf", &dialoguecamera[k][l].x, &dialoguecamera[k][l].y, &dialoguecamera[k][l].z);
- funpackf(tfile, "Bi", &participantfocus[k][l]);
- funpackf(tfile, "Bi", &participantaction[k][l]);
-
- for(m=0;m<10;m++)
- funpackf(tfile, "Bf Bf Bf", &participantfacing[k][l][m].x, &participantfacing[k][l][m].y, &participantfacing[k][l][m].z);
-
- funpackf(tfile, "Bf Bf",&dialoguecamerarotation[k][l],&dialoguecamerarotation2[k][l]);
- }
- }
- }else
- numdialogues=0;
-
- for(int k=0;k<player[0].numclothes;k++){
- funpackf(tfile, "Bi", &templength);
- for(int l=0;l<templength;l++)
- funpackf(tfile, "Bb", &player[0].clothes[k][l]);
- player[0].clothes[k][templength]='\0';
- funpackf(tfile, "Bf Bf Bf", &player[0].clothestintr[k], &player[0].clothestintg[k], &player[0].clothestintb[k]);
- }
-
- funpackf(tfile, "Bi", &environment);
-
- funpackf(tfile, "Bi", &objects.numobjects);
- for(int i=0;i<objects.numobjects;i++){
- funpackf(tfile, "Bi Bf Bf Bf Bf Bf Bf", &objects.type[i],&objects.rotation[i],&objects.rotation2[i], &objects.position[i].x, &objects.position[i].y, &objects.position[i].z,&objects.scale[i]);
- if(objects.type[i]==treeleavestype)
- objects.scale[i]=objects.scale[i-1];
- }
-
- if(mapvers>=7){
- funpackf(tfile, "Bi", &numhotspots);
- for(int i=0;i<numhotspots;i++){
- funpackf(tfile, "Bi Bf Bf Bf Bf", &hotspottype[i],&hotspotsize[i],&hotspot[i].x,&hotspot[i].y,&hotspot[i].z);
- funpackf(tfile, "Bi", &templength);
- if(templength)
- for(int l=0;l<templength;l++)
- funpackf(tfile, "Bb", &hotspottext[i][l]);
- hotspottext[i][templength]='\0';
- if(hotspottype[i]==-111)
- indemo=1;
- }
- }else
- numhotspots=0;
-
- if(visibleloading)
- LoadingScreen();
-
- if(!stealthloading){
- objects.center=0;
- for(int i=0;i<objects.numobjects;i++)
- objects.center+=objects.position[i];
- objects.center/=objects.numobjects;
-
-
- if(visibleloading)
- LoadingScreen();
-
- float maxdistance=0;
- float tempdist;
- int whichclosest;
- for(int i=0;i<objects.numobjects;i++){
- tempdist=findDistancefast(&objects.center,&objects.position[i]);
- if(tempdist>maxdistance){
- whichclosest=i;
- maxdistance=tempdist;
- }
- }
- objects.radius=fast_sqrt(maxdistance);
- }
-
- if(visibleloading)
- LoadingScreen();
- //mapcenter=objects.center;
- //mapradius=objects.radius;
-
- funpackf(tfile, "Bi", &numplayers);
- int howmanyremoved=0;
- bool removeanother=0;
- if(numplayers>1&&numplayers<maxplayers){
- for(int i=1;i<numplayers;i++){
- if(visibleloading)
- LoadingScreen();
- removeanother=0;
-
- funpackf(tfile, "Bi Bi Bf Bf Bf Bi",&player[i-howmanyremoved].whichskin,&player[i-howmanyremoved].creature, &player[i-howmanyremoved].coords.x,&player[i-howmanyremoved].coords.y,&player[i-howmanyremoved].coords.z,&player[i-howmanyremoved].num_weapons);
- if(mapvers>=5)
- funpackf(tfile, "Bi", &player[i-howmanyremoved].howactive);
- else
- player[i-howmanyremoved].howactive=typeactive;
- if(mapvers>=3)
- funpackf(tfile, "Bf",&player[i-howmanyremoved].scale);
- else
- player[i-howmanyremoved].scale=-1;
- if(mapvers>=11)
- funpackf(tfile, "Bb",&player[i-howmanyremoved].immobile);
- else
- player[i-howmanyremoved].immobile=0;
- if(mapvers>=12)
- funpackf(tfile, "Bf",&player[i-howmanyremoved].rotation);
- else
- player[i-howmanyremoved].rotation=0;
- player[i-howmanyremoved].targetrotation=player[i-howmanyremoved].rotation;
- if(player[i-howmanyremoved].num_weapons<0||player[i-howmanyremoved].num_weapons>5){
- removeanother=1;
- howmanyremoved++;
- }
- if(!removeanother){
- if(player[i-howmanyremoved].num_weapons>0&&player[i-howmanyremoved].num_weapons<5){
- for(int j=0;j<player[i-howmanyremoved].num_weapons;j++){
- player[i-howmanyremoved].weaponids[j]=weapons.numweapons;
- funpackf(tfile, "Bi", &weapons.type[player[i-howmanyremoved].weaponids[j]]);
- weapons.owner[player[i-howmanyremoved].weaponids[j]]=i;
- weapons.numweapons++;
- }
- }
- funpackf(tfile, "Bi", &player[i-howmanyremoved].numwaypoints);
- //player[i-howmanyremoved].numwaypoints=10;
- for(int j=0;j<player[i-howmanyremoved].numwaypoints;j++){
- funpackf(tfile, "Bf", &player[i-howmanyremoved].waypoints[j].x);
- funpackf(tfile, "Bf", &player[i-howmanyremoved].waypoints[j].y);
- funpackf(tfile, "Bf", &player[i-howmanyremoved].waypoints[j].z);
- if(mapvers>=5)
- funpackf(tfile, "Bi", &player[i-howmanyremoved].waypointtype[j]);
- else
- player[i-howmanyremoved].waypointtype[j] = wpkeepwalking;
- }
-
- funpackf(tfile, "Bi", &player[i-howmanyremoved].waypoint);
- if(player[i-howmanyremoved].waypoint>player[i-howmanyremoved].numwaypoints-1)
- player[i-howmanyremoved].waypoint=0;
-
- funpackf(tfile, "Bf Bf Bf", &player[i-howmanyremoved].armorhead, &player[i-howmanyremoved].armorhigh, &player[i-howmanyremoved].armorlow);
- funpackf(tfile, "Bf Bf Bf", &player[i-howmanyremoved].protectionhead, &player[i-howmanyremoved].protectionhigh, &player[i-howmanyremoved].protectionlow);
- funpackf(tfile, "Bf Bf Bf", &player[i-howmanyremoved].metalhead, &player[i-howmanyremoved].metalhigh, &player[i-howmanyremoved].metallow);
- funpackf(tfile, "Bf Bf", &player[i-howmanyremoved].power, &player[i-howmanyremoved].speedmult);
-
- if(mapvers>=4)
- funpackf(tfile, "Bf Bf Bf Bf", &headprop, &bodyprop, &armprop, &legprop);
- else{
- headprop=1;
- bodyprop=1;
- armprop=1;
- legprop=1;
- }
- if(player[i-howmanyremoved].creature==wolftype){
- player[i-howmanyremoved].proportionhead=1.1*headprop;
- player[i-howmanyremoved].proportionbody=1.1*bodyprop;
- player[i-howmanyremoved].proportionarms=1.1*armprop;
- player[i-howmanyremoved].proportionlegs=1.1*legprop;
- }
-
- if(player[i-howmanyremoved].creature==rabbittype){
- player[i-howmanyremoved].proportionhead=1.2*headprop;
- player[i-howmanyremoved].proportionbody=1.05*bodyprop;
- player[i-howmanyremoved].proportionarms=1.00*armprop;
- player[i-howmanyremoved].proportionlegs=1.1*legprop;
- player[i-howmanyremoved].proportionlegs.y=1.05*legprop;
- }
-
- funpackf(tfile, "Bi", &player[i-howmanyremoved].numclothes);
- if(player[i-howmanyremoved].numclothes){
- for(int k=0;k<player[i-howmanyremoved].numclothes;k++){
- int templength;
- funpackf(tfile, "Bi", &templength);
- for(int l=0;l<templength;l++)
- funpackf(tfile, "Bb", &player[i-howmanyremoved].clothes[k][l]);
- player[i-howmanyremoved].clothes[k][templength]='\0';
- funpackf(tfile, "Bf Bf Bf", &player[i-howmanyremoved].clothestintr[k], &player[i-howmanyremoved].clothestintg[k], &player[i-howmanyremoved].clothestintb[k]);
- }
- }
- }
- }
- }
- if(visibleloading)
- LoadingScreen();
-
- numplayers-=howmanyremoved;
- funpackf(tfile, "Bi", &numpathpoints);
- if(numpathpoints>30||numpathpoints<0)
- numpathpoints=0;
- for(int j=0;j<numpathpoints;j++){
- funpackf(tfile, "Bf Bf Bf Bi", &pathpoint[j].x,&pathpoint[j].y,&pathpoint[j].z,&numpathpointconnect[j]);
- for(int k=0;k<numpathpointconnect[j];k++){
- funpackf(tfile, "Bi", &pathpointconnect[j][k]);
- }
- }
- if(visibleloading)
- LoadingScreen();
-
- funpackf(tfile, "Bf Bf Bf Bf", &mapcenter.x,&mapcenter.y,&mapcenter.z,&mapradius);
-
- SetUpLighting();
- if(environment!=oldenvironment)
- Setenvironment(environment);
- oldenvironment=environment;
-
- if(!stealthloading){
- int j=objects.numobjects;
- objects.numobjects=0;
- for(int i=0;i<j;i++){
- objects.MakeObject(objects.type[i],objects.position[i],objects.rotation[i],objects.rotation2[i],objects.scale[i]);
- if(visibleloading)
- LoadingScreen();
- }
-
- terrain.DoShadows();
- if(visibleloading)
- LoadingScreen();
- objects.DoShadows();
- if(visibleloading)
- LoadingScreen();
- }
-
- fclose(tfile);
-
- oldlevel=whichlevel;
-
-
- if(numplayers>maxplayers-1)
- numplayers=maxplayers-1;
- for(int i=0;i<numplayers;i++){
- if(visibleloading)
- LoadingScreen();
- player[i].burnt=0;
- player[i].bled=0;
- player[i].onfire=0;
- if(i==0||player[i].scale<0)
- player[i].scale=.2;
- player[i].skeleton.free=0;
- player[i].skeleton.id=i;
- if(i==0&&mapvers<9)
- player[i].creature=rabbittype;
- if(player[i].creature!=wolftype){
- player[i].skeleton.Load(
- (char *)":Data:Skeleton:Basic Figure",
- (char *)":Data:Skeleton:Basic Figurelow",
- (char *)":Data:Skeleton:Rabbitbelt",
- (char *)":Data:Models:Body.solid",
- (char *)":Data:Models:Body2.solid",
- (char *)":Data:Models:Body3.solid",
- (char *)":Data:Models:Body4.solid",
- (char *)":Data:Models:Body5.solid",
- (char *)":Data:Models:Body6.solid",
- (char *)":Data:Models:Body7.solid",
- (char *)":Data:Models:Bodylow.solid",
- (char *)":Data:Models:Belt.solid",0);
- }else{
- if(player[i].creature!=wolftype){
- player[i].skeleton.Load(
- (char *)":Data:Skeleton:Basic Figure",
- (char *)":Data:Skeleton:Basic Figurelow",
- (char *)":Data:Skeleton:Rabbitbelt",
- (char *)":Data:Models:Body.solid",
- (char *)":Data:Models:Body2.solid",
- (char *)":Data:Models:Body3.solid",
- (char *)":Data:Models:Body4.solid",
- (char *)":Data:Models:Body5.solid",
- (char *)":Data:Models:Body6.solid",
- (char *)":Data:Models:Body7.solid",
- (char *)":Data:Models:Bodylow.solid",
- (char *)":Data:Models:Belt.solid",1);
- LoadTexture(":Data:Textures:Belt.png",&player[i].skeleton.drawmodelclothes.textureptr,1,1);
- }
- if(player[i].creature==wolftype){
- player[i].skeleton.Load(
- (char *)":Data:Skeleton:Basic Figure Wolf",
- (char *)":Data:Skeleton:Basic Figure Wolf Low",
- (char *)":Data:Skeleton:Rabbitbelt",
- (char *)":Data:Models:Wolf.solid",
- (char *)":Data:Models:Wolf2.solid",
- (char *)":Data:Models:Wolf3.solid",
- (char *)":Data:Models:Wolf4.solid",
- (char *)":Data:Models:Wolf5.solid",
- (char *)":Data:Models:Wolf6.solid",
- (char *)":Data:Models:Wolf7.solid",
- (char *)":Data:Models:Wolflow.solid",
- (char *)":Data:Models:Belt.solid",0);
- }
- }
-
-
- int texsize;
- texsize=512*512*3/texdetail/texdetail;
-
- LoadTextureSave(creatureskin[player[i].creature][player[i].whichskin],&player[i].skeleton.drawmodel.textureptr,1,&player[i].skeleton.skinText[0],&player[i].skeleton.skinsize);
-
- if(player[i].numclothes){
- for(int j=0;j<player[i].numclothes;j++){
- tintr=player[i].clothestintr[j];
- tintg=player[i].clothestintg[j];
- tintb=player[i].clothestintb[j];
- AddClothes((char *)player[i].clothes[j],&player[i].skeleton.skinText[0]);
- }
- player[i].DoMipmaps();
- }
-
- player[i].currentanimation=bounceidleanim;
- player[i].targetanimation=bounceidleanim;
- player[i].currentframe=0;
- player[i].targetframe=1;
- player[i].target=0;
- player[i].speed=1+(float)(Random()%100)/1000;
- if(difficulty==0)
- player[i].speed-=.2;
- if(difficulty==1)
- player[i].speed-=.1;
-
- player[i].velocity=0;
- player[i].oldcoords=player[i].coords;
- player[i].realoldcoords=player[i].coords;
-
- player[i].id=i;
- player[i].skeleton.id=i;
- player[i].updatedelay=0;
- player[i].normalsupdatedelay=0;
-
- player[i].aitype=passivetype;
- player[i].madskills=0;
-
- if(i==0){
- player[i].proportionhead=1.2;
- player[i].proportionbody=1.05;
- player[i].proportionarms=1.00;
- player[i].proportionlegs=1.1;
- player[i].proportionlegs.y=1.05;
- }
- player[i].headless=0;
- player[i].currentoffset=0;
- player[i].targetoffset=0;
-
- player[i].damagetolerance=200;
-
- if(player[i].creature==wolftype){
- if(i==0||player[i].scale<0)
- player[i].scale=.23;
- player[i].damagetolerance=300;
- }
-
- if(visibleloading)
- LoadingScreen();
- if(cellophane){
- player[i].proportionhead.z=0;
- player[i].proportionbody.z=0;
- player[i].proportionarms.z=0;
- player[i].proportionlegs.z=0;
- }
-
- player[i].tempanimation.Load((char *)"Tempanim",0,0);
-
- player[i].headmorphness=0;
- player[i].targetheadmorphness=1;
- player[i].headmorphstart=0;
- player[i].headmorphend=0;
-
- player[i].pausetime=0;
-
- player[i].dead=0;
- player[i].jumppower=5;
- player[i].damage=0;
- player[i].permanentdamage=0;
- player[i].superpermanentdamage=0;
-
- player[i].forwardkeydown=0;
- player[i].leftkeydown=0;
- player[i].backkeydown=0;
- player[i].rightkeydown=0;
- player[i].jumpkeydown=0;
- player[i].crouchkeydown=0;
- player[i].throwkeydown=0;
-
- player[i].collided=-10;
- player[i].loaded=1;
- player[i].bloodloss=0;
- player[i].weaponactive=-1;
- player[i].weaponstuck=-1;
- player[i].bleeding=0;
- player[i].deathbleeding=0;
- player[i].stunned=0;
- player[i].hasvictim=0;
- player[i].wentforweapon=0;
- }
-
- player[0].aitype=playercontrolled;
- player[0].weaponactive=-1;
-
- if(difficulty==1)
- player[0].power=1/.9;
-
- if(difficulty==0)
- player[0].power=1/.8;
-
- if(difficulty==1)
- player[0].damagetolerance=250;
- if(difficulty==0)
- player[0].damagetolerance=300;
- if(difficulty==0)
- player[0].armorhead*=1.5;
- if(difficulty==0)
- player[0].armorhigh*=1.5;
- if(difficulty==0)
- player[0].armorlow*=1.5;
- cameraloc=player[0].coords;
- cameraloc.y+=5;
- rotation=player[0].rotation;
-
- hawkcoords=player[0].coords;
- hawkcoords.y+=30;
-
- if(visibleloading)
- LoadingScreen();
- for(int i=0;i<weapons.numweapons;i++){
- weapons.bloody[i]=0;
- weapons.blooddrip[i]=0;
- weapons.blooddripdelay[i]=0;
- weapons.onfire[i]=0;
- weapons.flamedelay[i]=0;
- weapons.damage[i]=0;
- if(weapons.type[i]==sword){
- weapons.mass[i]=1.5;
- weapons.tipmass[i]=1;
- weapons.length[i]=.8;
- }
- if(weapons.type[i]==staff){
- weapons.mass[i]=2;
- weapons.tipmass[i]=1;
- weapons.length[i]=1.5;
- }
- if(weapons.type[i]==knife){
- weapons.mass[i]=1;
- weapons.tipmass[i]=1.2;
- weapons.length[i]=.25;
- }
- weapons.position[i]=-1000;
- weapons.tippoint[i]=-1000;
- }
-
- LOG("Starting background music...");
-
- OPENAL_StopSound(OPENAL_ALL);
- if(environment==snowyenvironment){
- if(ambientsound)
- emit_stream_np(stream_wind);
- }else if(environment==desertenvironment){
- if(ambientsound)
- emit_stream_np(stream_desertambient);
- }else if(environment==grassyenvironment){
- if(ambientsound)
- emit_stream_np(stream_wind, 100.);
- }
- oldmusicvolume[0]=0;
- oldmusicvolume[1]=0;
- oldmusicvolume[2]=0;
- oldmusicvolume[3]=0;
-
- if(!firstload)
- firstload=1;
- }
- leveltime=0;
- loadingstuff=0;
- visibleloading=0;
-}
-
-
-
-void Game::MenuTick(){
- //menu buttons
- if(mainmenu==1||mainmenu==2){
- if(Input::MouseClicked()&&selected==1){
- if(!gameon){
- fireSound(firestartsound);
- flash();
- //new game
- if(accountactive) {
- mainmenu=5;
- } else {
- mainmenu=7;
- }
- selected=-1;
- }else{
- //resume
- mainmenu=0;
- pause_sound(stream_music3);
- resume_stream(music1);
- }
- }
-
- if(Input::MouseClicked()&&selected==2){
- fireSound();
- flash();
- //options
- mainmenu=3;
- if(newdetail>2)newdetail=detail;
- if(newdetail<0)newdetail=detail;
- if(newscreenwidth>3000)newscreenwidth=screenwidth;
- if(newscreenwidth<0)newscreenwidth=screenwidth;
- if(newscreenheight>3000)newscreenheight=screenheight;
- if(newscreenheight<0)newscreenheight=screenheight;
- }
-
- if(Input::MouseClicked()&&selected==3){
- fireSound();
- flash();
- if(!gameon){
- //quit
- tryquit=1;
- pause_sound(stream_music3);
- }else{
- //end game
- gameon=0;
- mainmenu=1;