12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700 |
- #include "Hunt.h"
- bool ShowFaces = true;
- void UploadGeometry()
- {
- int x,y,xx,yy;
- byte temp;
-
- AudioFCount = 0;
- int MaxView = 18;
- int HalfView = (int)(MaxView/2)+1;
- for (x = 0; x < MaxView; x++)
- for (y = 0; y < MaxView; y++)
- {
- xx = (x - HalfView)*2;
- yy = (y - HalfView)*2;
- data[AudioFCount].x1 = (CCX+xx) * 256 - CameraX;
- data[AudioFCount].y1 = HMap[CCY+yy][CCX+xx] * ctHScale - CameraY;
- data[AudioFCount].z1 = (CCY+yy) * 256 - CameraZ;
- xx = ((x+1) - HalfView)*2;
- yy = (y - HalfView)*2;
- data[AudioFCount].x2 = (CCX+xx) * 256 - CameraX;
- data[AudioFCount].y2 = HMap[CCY+yy][CCX+xx] * ctHScale - CameraY;
- data[AudioFCount].z2 = (CCY+yy) * 256 - CameraZ;
- xx = ((x+1) - HalfView)*2;
- yy = ((y+1) - HalfView)*2;
- data[AudioFCount].x3 = (CCX+xx) * 256 - CameraX;
- data[AudioFCount].y3 = HMap[CCY+yy][CCX+xx] * ctHScale - CameraY;
- data[AudioFCount].z3 = (CCY+yy) * 256 - CameraZ;
- xx = (x - HalfView)*2;
- yy = ((y+1) - HalfView)*2;
- data[AudioFCount].x4 = (CCX+xx) * 256 - CameraX;
- data[AudioFCount].y4 = HMap[CCY+yy][CCX+xx] * ctHScale - CameraY;
- data[AudioFCount].z4 = (CCY+yy) * 256 - CameraZ;
- AudioFCount++;
- }
- if (ShowFaces)
- { wsprintf(logt,"Audio_UpdateGeometry: %i faces uploaded\n", AudioFCount); PrintLog(logt);
- ShowFaces = false;}
- }
- void SetupRes()
- {
- if (!HARD3D)
- if (OptRes>5) OptRes=5;
- if (OptRes==0) { WinW = 320; WinH=240; }
- if (OptRes==1) { WinW = 400; WinH=300; }
- if (OptRes==2) { WinW = 512; WinH=384; }
- if (OptRes==3) { WinW = 640; WinH=480; }
- if (OptRes==4) { WinW = 800; WinH=600; }
- if (OptRes==5) { WinW =1024; WinH=768; }
- if (OptRes==6) { WinW =1280; WinH=1024; }
- if (OptRes==7) { WinW =1600; WinH=1200; }
- }
- float GetLandOH(int x, int y)
- {
- return (float)(HMapO[y][x]) * ctHScale;
- }
- float GetLandOUH(int x, int y)
- {
- if (FMap[y][x] & fmReverse)
- return (float)((int)(HMap[y][x+1]+HMap[y+1][x])/2.f)*ctHScale;
- else
- return (float)((int)(HMap[y][x]+HMap[y+1][x+1])/2.f)*ctHScale;
- }
- float GetLandUpH(float x, float y)
- {
-
- int CX = (int)x / 256;
- int CY = (int)y / 256;
- if (!(FMap[CY][CX] & fmWaterA)) return GetLandH(x,y);
-
- return (float)(WaterList[ WMap[CY][CX] ].wlevel * ctHScale);
- }
- float GetLandH(float x, float y)
- {
- int CX = (int)x / 256;
- int CY = (int)y / 256;
-
- int dx = (int)x % 256;
- int dy = (int)y % 256;
- int h1 = HMap[CY][CX];
- int h2 = HMap[CY][CX+1];
- int h3 = HMap[CY+1][CX+1];
- int h4 = HMap[CY+1][CX];
- if (FMap[CY][CX] & fmReverse) {
- if (256-dx>dy) h3 = h2+h4-h1;
- else h1 = h2+h4-h3;
- } else {
- if (dx>dy) h4 = h1+h3-h2;
- else h2 = h1+h3-h4;
- }
- float h = (float)
- (h1 * (256-dx) + h2 * dx) * (256-dy) +
- (h4 * (256-dx) + h3 * dx) * dy;
- return (h / 256.f / 256.f) * ctHScale;
- }
- float GetLandLt(float x, float y)
- {
- int CX = (int)x / 256;
- int CY = (int)y / 256;
-
- int dx = (int)x % 256;
- int dy = (int)y % 256;
- int h1 = LMap[CY][CX];
- int h2 = LMap[CY][CX+1];
- int h3 = LMap[CY+1][CX+1];
- int h4 = LMap[CY+1][CX];
- float h = (float)
- (h1 * (256-dx) + h2 * dx) * (256-dy) +
- (h4 * (256-dx) + h3 * dx) * dy;
- return (h / 256.f / 256.f);
- }
- float GetLandLt2(float x, float y)
- {
- int CX = ((int)x / 512)*2 - CCX;
- int CY = ((int)y / 512)*2 - CCY;
-
- int dx = (int)x % 512;
- int dy = (int)y % 512;
- int h1 = VMap[CY+128][CX+128].Light;
- int h2 = VMap[CY+128][CX+2+128].Light;
- int h3 = VMap[CY+2+128][CX+2+128].Light;
- int h4 = VMap[CY+2+128][CX+128].Light;
- float h = (float)
- (h1 * (512-dx) + h2 * dx) * (512-dy) +
- (h4 * (512-dx) + h3 * dx) * dy;
- return (h / 512.f / 512.f);
- }
- void CalcModelGroundLight(TModel *mptr, float x0, float z0, int FI)
- {
- float ca = cos(FI * pi / 2);
- float sa = sin(FI * pi / 2);
- for (int v=0; v<mptr->VCount; v++) {
- float x = mptr->gVertex[v].x * ca + mptr->gVertex[v].z * sa + x0;
- float z = mptr->gVertex[v].z * ca - mptr->gVertex[v].x * sa + z0;
- mptr->VLight[0][v] = GetLandLt2(x, z) - 128;
- }
- }
- BOOL PointOnBound(float &H, float px, float py, float cx, float cy, float oy, TBound *bound, int angle)
- {
- px-=cx;
- py-=cy;
-
- float ca = (float) cos(angle*pi / 2.f);
- float sa = (float) sin(angle*pi / 2.f);
- BOOL _on = FALSE;
- H=-1000;
- for (int o=0; o<8; o++) {
-
- if (bound[o].a<0) continue;
- if (bound[o].y2 + oy > PlayerY + 128) continue;
-
- float a,b;
- float ccx = bound[o].cx*ca + bound[o].cy*sa;
- float ccy = bound[o].cy*ca - bound[o].cx*sa;
- if (angle & 1) {
- a = bound[o].b;
- b = bound[o].a;
- } else {
- a = bound[o].a;
- b = bound[o].b;
- }
- if ( ( fabs(px - ccx) < a) && (fabs(py - ccy) < b) )
- {
- _on=TRUE;
- if (H < bound[o].y2) H = bound[o].y2;
- }
- }
- return _on;
- }
- BOOL PointUnBound(float &H, float px, float py, float cx, float cy, float oy, TBound *bound, int angle)
- {
- px-=cx;
- py-=cy;
-
- float ca = (float) cos(angle*pi / 2.f);
- float sa = (float) sin(angle*pi / 2.f);
- BOOL _on = FALSE;
- H=+1000;
- for (int o=0; o<8; o++) {
-
- if (bound[o].a<0) continue;
- if (bound[o].y1 + oy < PlayerY + 128) continue;
-
- float a,b;
- float ccx = bound[o].cx*ca + bound[o].cy*sa;
- float ccy = bound[o].cy*ca - bound[o].cx*sa;
- if (angle & 1) {
- a = bound[o].b;
- b = bound[o].a;
- } else {
- a = bound[o].a;
- b = bound[o].b;
- }
- if ( ( fabs(px - ccx) < a) && (fabs(py - ccy) < b) )
- {
- _on=TRUE;
- if (H > bound[o].y1) H = bound[o].y1;
- }
- }
- return _on;
- }
- float GetLandCeilH(float CameraX, float CameraZ)
- {
- float h,hh;
-
- h = GetLandH(CameraX, CameraZ) + 20480;
- int ccx = (int)CameraX / 256;
- int ccz = (int)CameraZ / 256;
- for (int z=-4; z<=4; z++)
- for (int x=-4; x<=4; x++)
- if (OMap[ccz+z][ccx+x]!=255) {
- int ob = OMap[ccz+z][ccx+x];
-
- float CR = (float)MObjects[ob].info.Radius - 1.f;
-
- float oz = (ccz+z) * 256.f + 128.f;
- float ox = (ccx+x) * 256.f + 128.f;
- float LandY = GetLandOH(ccx+x, ccz+z);
- if (!(MObjects[ob].info.flags & ofBOUND)) {
- if (MObjects[ob].info.YLo + LandY > h) continue;
- if (MObjects[ob].info.YLo + LandY < PlayerY+100) continue;
- }
- float r = CR+1;
- if (MObjects[ob].info.flags & ofBOUND)
- {
- float hh;
- if (PointUnBound(hh, CameraX, CameraZ, ox, oz, LandY, MObjects[ob].bound, ((FMap[ccz+z][ccx+x] >> 2) & 3) ) )
- if (h > LandY + hh) h = LandY + hh;
- } else {
- if (MObjects[ob].info.flags & ofCIRCLE)
- r = (float) sqrt( (ox-CameraX)*(ox-CameraX) + (oz-CameraZ)*(oz-CameraZ) );
- else
- r = (float) max( fabs(ox-CameraX) , fabs(oz-CameraZ) );
-
- if (r<CR) h = MObjects[ob].info.YLo + LandY;
- }
-
- }
- return h;
- }
- float GetLandQH(float CameraX, float CameraZ)
- {
- float h,hh;
-
- h = GetLandH(CameraX, CameraZ);
- hh = GetLandH(CameraX-90.f, CameraZ-90.f); if (hh>h) h=hh;
- hh = GetLandH(CameraX+90.f, CameraZ-90.f); if (hh>h) h=hh;
- hh = GetLandH(CameraX-90.f, CameraZ+90.f); if (hh>h) h=hh;
- hh = GetLandH(CameraX+90.f, CameraZ+90.f); if (hh>h) h=hh;
- hh = GetLandH(CameraX+128.f, CameraZ); if (hh>h) h=hh;
- hh = GetLandH(CameraX-128.f, CameraZ); if (hh>h) h=hh;
- hh = GetLandH(CameraX, CameraZ+128.f); if (hh>h) h=hh;
- hh = GetLandH(CameraX, CameraZ-128.f); if (hh>h) h=hh;
- int ccx = (int)CameraX / 256;
- int ccz = (int)CameraZ / 256;
- for (int z=-4; z<=4; z++)
- for (int x=-4; x<=4; x++)
- if (OMap[ccz+z][ccx+x]!=255) {
- int ob = OMap[ccz+z][ccx+x];
-
- float CR = (float)MObjects[ob].info.Radius - 1.f;
-
- float oz = (ccz+z) * 256.f + 128.f;
- float ox = (ccx+x) * 256.f + 128.f;
- float LandY = GetLandOH(ccx+x, ccz+z);
- if (!(MObjects[ob].info.flags & ofBOUND)) {
- if (MObjects[ob].info.YHi + LandY < h) continue;
- if (MObjects[ob].info.YHi + LandY > PlayerY+128) continue;
-
- }
- float r = CR+1;
- if (MObjects[ob].info.flags & ofBOUND)
- {
- float hh;
- if (PointOnBound(hh, CameraX, CameraZ, ox, oz, LandY, MObjects[ob].bound, ((FMap[ccz+z][ccx+x] >> 2) & 3) ) )
- if (h < LandY + hh) h = LandY + hh;
- } else {
- if (MObjects[ob].info.flags & ofCIRCLE)
- r = (float) sqrt( (ox-CameraX)*(ox-CameraX) + (oz-CameraZ)*(oz-CameraZ) );
- else
- r = (float) max( fabs(ox-CameraX) , fabs(oz-CameraZ) );
-
- if (r<CR) h = MObjects[ob].info.YHi + LandY;
- }
-
- }
- return h;
- }
- float GetLandHObj(float CameraX, float CameraZ)
- {
- float h;
- h = 0;
- int ccx = (int)CameraX / 256;
- int ccz = (int)CameraZ / 256;
- for (int z=-3; z<=3; z++)
- for (int x=-3; x<=3; x++)
- if (OMap[ccz+z][ccx+x]!=255) {
- int ob = OMap[ccz+z][ccx+x];
- float CR = (float)MObjects[ob].info.Radius - 1.f;
-
- float oz = (ccz+z) * 256.f + 128.f;
- float ox = (ccx+x) * 256.f + 128.f;
- if (MObjects[ob].info.YHi + GetLandOH(ccx+x, ccz+z) < h) continue;
- if (MObjects[ob].info.YLo + GetLandOH(ccx+x, ccz+z) > PlayerY+256) continue;
- float r;
- if (MObjects[ob].info.flags & ofCIRCLE)
- r = (float) sqrt( (ox-CameraX)*(ox-CameraX) + (oz-CameraZ)*(oz-CameraZ) );
- else
- r = (float) max( fabs(ox-CameraX) , fabs(oz-CameraZ) );
- if (r<CR)
- h = MObjects[ob].info.YHi + GetLandOH(ccx+x, ccz+z);
- }
- return h;
- }
- float GetLandQHNoObj(float CameraX, float CameraZ)
- {
- float h,hh;
-
- h = GetLandH(CameraX, CameraZ);
- hh = GetLandH(CameraX-90.f, CameraZ-90.f); if (hh>h) h=hh;
- hh = GetLandH(CameraX+90.f, CameraZ-90.f); if (hh>h) h=hh;
- hh = GetLandH(CameraX-90.f, CameraZ+90.f); if (hh>h) h=hh;
- hh = GetLandH(CameraX+90.f, CameraZ+90.f); if (hh>h) h=hh;
- hh = GetLandH(CameraX+128.f, CameraZ); if (hh>h) h=hh;
- hh = GetLandH(CameraX-128.f, CameraZ); if (hh>h) h=hh;
- hh = GetLandH(CameraX, CameraZ+128.f); if (hh>h) h=hh;
- hh = GetLandH(CameraX, CameraZ-128.f); if (hh>h) h=hh;
-
- return h;
- }
- void ProcessCommandLine()
- {
- for (int a=0; a<__argc; a++) {
- LPSTR s = __argv[a];
- if (strstr(s,"x=")) { PlayerX = (float)atof(&s[2])*256.f; LockLanding = TRUE; }
- if (strstr(s,"y=")) { PlayerZ = (float)atof(&s[2])*256.f; LockLanding = TRUE; }
- if (strstr(s,"reg=")) TrophyRoom.RegNumber = atoi(&s[4]);
- if (strstr(s,"prj=")) strcpy(ProjectName, (s+4));
- if (strstr(s,"din=")) TargetDino = (atoi(&s[4])*1024);
- if (strstr(s,"wep=")) WeaponPres = atoi(&s[4]);
- if (strstr(s,"dtm=")) OptDayNight = atoi(&s[4]);
- if (strstr(s,"-debug")) DEBUG = TRUE;
- if (strstr(s,"-double")) DoubleAmmo = TRUE;
- if (strstr(s,"-radar")) RadarMode = TRUE;
- if (strstr(s,"-tranq")) Tranq = TRUE;
- if (strstr(s,"-observ")) ObservMode = TRUE;
- }
- }
- void AddWCircle(float x, float z, float scale)
- {
- WCircles[WCCount].pos.x = x;
- WCircles[WCCount].pos.z = z;
- WCircles[WCCount].pos.y = GetLandUpH(x, z);
- WCircles[WCCount].FTime = 0;
- WCircles[WCCount].scale = scale;
- WCCount++;
- }
- void AddShipTask(int cindex)
- {
- TCharacter *cptr = &Characters[cindex];
- BOOL TROPHYON = (GetLandUpH(cptr->pos.x, cptr->pos.z) - GetLandH(cptr->pos.x, cptr->pos.z) < 100) &&
- (!Tranq);
- if (TROPHYON) {
- ShipTask.clist[ShipTask.tcount] = cindex;
- ShipTask.tcount++;
- AddVoicev(ShipModel.SoundFX[3].length,
- ShipModel.SoundFX[3].lpData, 256);
- }
-
- SYSTEMTIME st;
- GetLocalTime(&st);
- int t=0;
- for (t=0; t<23; t++)
- if (!TrophyRoom.Body[t].ctype) break;
- float score = (float)DinoInfo[Characters[cindex].CType].BaseScore;
- if (TrophyRoom.Last.success>1)
- score*=(1.f + TrophyRoom.Last.success / 10.f);
- if (!(TargetDino & (1<<Characters[cindex].AI)) ) score/=2.f;
- if (Tranq ) score *= 1.25f;
- if (RadarMode) score *= 0.70f;
- if (ScentMode) score *= 0.80f;
- if (CamoMode ) score *= 0.85f;
- TrophyRoom.Score+=(int)score;
- if (!Tranq) {
- TrophyTime = 20 * 1000;
- TrophyBody = t;
- TrophyRoom.Body[t].ctype = Characters[cindex].CType;
- TrophyRoom.Body[t].scale = Characters[cindex].scale;
- TrophyRoom.Body[t].weapon = CurrentWeapon;
- TrophyRoom.Body[t].score = (int)score;
- TrophyRoom.Body[t].phase = (RealTime & 3);
- TrophyRoom.Body[t].time = (st.wHour<<10) + st.wMinute;
- TrophyRoom.Body[t].date = (st.wYear<<20) + (st.wMonth<<10) + st.wDay;
- TrophyRoom.Body[t].range = VectorLength( SubVectors(Characters[cindex].pos, PlayerPos) ) / 64.f;
- PrintLog("Trophy added: ");
- PrintLog(DinoInfo[Characters[cindex].CType].Name);
- PrintLog("\n");
- }
- }
- void InitShip(int cindex)
- {
- TCharacter *cptr = &Characters[cindex];
- Ship.DeltaY = 2048.f + DinoInfo[cptr->CType].ShDelta * cptr->scale;
- Ship.pos.x = PlayerX - 90*256;
- if (Ship.pos.x < 256) Ship.pos.x = PlayerX + 90*256;
- Ship.pos.z = PlayerZ - 90*256;
- if (Ship.pos.z < 256) Ship.pos.z = PlayerZ + 90*256;
- Ship.pos.y = GetLandUpH(Ship.pos.x, Ship.pos.z) + Ship.DeltaY + 1024;
- Ship.tgpos.x = cptr->pos.x;
- Ship.tgpos.z = cptr->pos.z;
- Ship.tgpos.y = GetLandUpH(Ship.tgpos.x, Ship.tgpos.z) + Ship.DeltaY;
- Ship.State = 0;
- Ship.retpos = Ship.pos;
- Ship.cindex = cindex;
- Ship.FTime = 0;
- }
- void HideWeapon()
- {
- TWeapon *wptr = &Weapon;
- if (UNDERWATER && !wptr->state) return;
- if (ObservMode || TrophyMode) return;
-
- if (wptr->state == 0) {
- if (!ShotsLeft[CurrentWeapon]) return;
- if (WeapInfo[CurrentWeapon].Optic) OPTICMODE = TRUE;
- AddVoicev(wptr->chinfo[CurrentWeapon].SoundFX[0].length,
- wptr->chinfo[CurrentWeapon].SoundFX[0].lpData, 256);
- wptr->FTime = 0;
- wptr->state = 1;
- BINMODE = FALSE;
- MapMode = FALSE;
- wptr->shakel = 0.2f;
- return;
- }
- if (wptr->state!=2 || wptr->FTime!=0) return;
- AddVoicev(wptr->chinfo[CurrentWeapon].SoundFX[2].length,
- wptr->chinfo[CurrentWeapon].SoundFX[2].lpData, 256);
- wptr->state = 3;
- wptr->FTime = 0;
- OPTICMODE = FALSE;
- return ;
- }
- void InitGameInfo()
- {
- for (int c=0; c<32; c++) {
- DinoInfo[c].Scale0 = 800;
- DinoInfo[c].ScaleA = 600;
- DinoInfo[c].ShDelta = 0;
- }
- LoadResourcesScript();
- }
- void InitEngine()
- {
- DEBUG = FALSE;
- WATERANI = TRUE;
- NODARKBACK = TRUE;
- LoDetailSky = TRUE;
- CORRECTION = TRUE;
- FOGON = TRUE;
- FOGENABLE = TRUE;
- Clouds = TRUE;
- SKY = TRUE;
- GOURAUD = TRUE;
- MODELS = TRUE;
- TIMER = DEBUG;
- BITMAPP = FALSE;
- MIPMAP = TRUE;
- NOCLIP = FALSE;
- CLIP3D = TRUE;
-
- SLOW = FALSE;
- LOWRESTX = FALSE;
- MORPHP = TRUE;
- MORPHA = TRUE;
- _GameState = 0;
- RadarMode = FALSE;
- fnt_BIG = CreateFont(
- 23, 10, 0, 0,
- 600, 0,0,0,
- #ifdef __rus
- RUSSIAN_CHARSET,
- #else
- ANSI_CHARSET,
- #endif
- OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY, DEFAULT_PITCH | FF_SWISS, NULL);
- fnt_Small = CreateFont(
- 14, 5, 0, 0,
- 100, 0,0,0,
- #ifdef __rus
- RUSSIAN_CHARSET,
- #else
- ANSI_CHARSET,
- #endif
- OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY, DEFAULT_PITCH | FF_SWISS, NULL);
- fnt_Midd = CreateFont(
- 16, 7, 0, 0,
- 550, 0,0,0,
- #ifdef __rus
- RUSSIAN_CHARSET,
- #else
- ANSI_CHARSET,
- #endif
- OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY, DEFAULT_PITCH | FF_SWISS, NULL);
- Heap = HeapCreate( 0, 60000000, 64000000 );
- if( Heap == NULL ) {
- MessageBox(hwndMain,"Error creating heap.","Error",IDOK);
- return; }
- Textures[255] = (TEXTURE*) _HeapAlloc(Heap, 0, sizeof(TEXTURE));
- WaterR = 10;
- WaterG = 38;
- WaterB = 46;
- WaterA = 10;
- TargetDino = 1<<10;
- TargetCall = 10;
- WeaponPres = 1;
- MessageList.timeleft = 0;
- InitGameInfo();
-
- CreateVideoDIB();
- CreateFadeTab();
- CreateDivTable();
- InitClips();
-
- TrophyRoom.RegNumber=0;
-
- PlayerX = (ctMapSize / 3) * 256;
- PlayerZ = (ctMapSize / 3) * 256;
- ProcessCommandLine();
-
- switch (OptDayNight) {
- case 0:
- SunShadowK = 0.7;
- Sun3dPos.x = - 4048;
- Sun3dPos.y = + 2048;
- Sun3dPos.z = - 4048;
- break;
- case 1:
- SunShadowK = 0.5;
- Sun3dPos.x = - 2048;
- Sun3dPos.y = + 4048;
- Sun3dPos.z = - 2048;
- break;
- case 2:
- SunShadowK = -0.7;
- Sun3dPos.x = + 3048;
- Sun3dPos.y = + 3048;
- Sun3dPos.z = + 3048;
- break;
- }
- LoadTrophy();
-
- ProcessCommandLine();
-
-
-
-
-
-
- ctViewR = 42 + (int)(OptViewR / 8)*2;
- ctViewR1 = 28;
- ctViewRM = 24;
-
- Soft_Persp_K = 1.5f;
- HeadY = 220;
- FogsList[0].fogRGB = 0x000000;
- FogsList[0].YBegin = 0;
- FogsList[0].Transp = 000;
- FogsList[0].FLimit = 000;
- FogsList[127].fogRGB = 0x00504000;
- FogsList[127].Mortal = FALSE;
- FogsList[127].Transp = 460;
- FogsList[127].FLimit = 200;
- FillMemory( FogsMap, sizeof(FogsMap), 0);
- PrintLog("Init Engine: Ok.\n");
- }
- void ShutDownEngine()
- {
- ReleaseDC(hwndMain,hdcMain);
- }
- void ProcessSyncro()
- {
- RealTime = timeGetTime();
- srand( (unsigned) RealTime );
- if (SLOW) RealTime/=4;
- TimeDt = RealTime - PrevTime;
- if (TimeDt<0) TimeDt = 10;
- if (TimeDt>10000) TimeDt = 10;
- if (TimeDt>1000) TimeDt = 1000;
- PrevTime = RealTime;
- Takt++;
- if (!PAUSE)
- if (MyHealth) MyHealth+=TimeDt*4;
- if (MyHealth>MAX_HEALTH) MyHealth = MAX_HEALTH;
- }
- void AddBloodTrail(TCharacter *cptr)
- {
- if (BloodTrail.Count>508) {
- memcpy(&BloodTrail.Trail[0], &BloodTrail.Trail[1], 510*sizeof(TBloodP));
- BloodTrail.Count--;
- }
- BloodTrail.Trail[BloodTrail.Count].LTime = 210000;
- BloodTrail.Trail[BloodTrail.Count].pos = cptr->pos;
- BloodTrail.Trail[BloodTrail.Count].pos.x+=siRand(32);
- BloodTrail.Trail[BloodTrail.Count].pos.z+=siRand(32);
- BloodTrail.Trail[BloodTrail.Count].pos.y =
- GetLandH(BloodTrail.Trail[BloodTrail.Count].pos.x,
- BloodTrail.Trail[BloodTrail.Count].pos.z)+4;
- BloodTrail.Count++;
- }
- void MakeCall()
- {
- if (!TargetDino) return;
- if (UNDERWATER) return;
- if (ObservMode || TrophyMode) return;
- if (CallLockTime) return;
-
- CallLockTime=1024*3;
-
- NextCall+=(RealTime % 2)+1;
- NextCall%=3;
- AddVoicev(fxCall[TargetCall-10][NextCall].length,
- fxCall[TargetCall-10][NextCall].lpData, 256);
- float dmin = 512*256;
- int ai = -1;
- for (int c=0; c<ChCount; c++) {
- TCharacter *cptr = &Characters[c];
- if (DinoInfo[AI_to_CIndex[TargetCall] ].DangerCall)
- if (cptr->AI<10) {
- cptr->State=2;
- cptr->AfraidTime = (10 + rRand(5)) * 1024;
- }
- if (cptr->AI!=TargetCall) continue;
- if (cptr->AfraidTime) continue;
- if (cptr->State) continue;
- float d = VectorLength(SubVectors(PlayerPos, cptr->pos));
- if (d < ctViewR * 400) {
- if (rRand(128) > 32)
- if (d<dmin) { dmin = d; ai = c; }
- cptr->tgx = PlayerX + siRand(1800);
- cptr->tgz = PlayerZ + siRand(1800);
- }
- }
- if (ai!=-1) {
- answpos = SubVectors(Characters[ai].pos, PlayerPos);
- answpos.x/=-3.f; answpos.y/=-3.f; answpos.z/=-3.f;
- answpos = SubVectors(PlayerPos, answpos);
- answtime = 2000 + rRand(2000);
- answcall = TargetCall;
- }
-
- }
- DWORD ColorSum(DWORD C1, DWORD C2)
- {
- DWORD R,G,B;
- R = min(255, ((C1>> 0) & 0xFF) + ((C2>> 0) & 0xFF));
- G = min(255, ((C1>> 8) & 0xFF) + ((C2>> 8) & 0xFF));
- B = min(255, ((C1>>16) & 0xFF) + ((C2>>16) & 0xFF));
- return R + (G<<8) + (B<<16);
- }
- #define partBlood 1
- #define partWater 2
- #define partGround 3
- #define partBubble 4
- void AddElements(float x, float y, float z, int etype, int cnt)
- {
- if (ElCount > 30) {
- memcpy(&Elements[0], &Elements[1], (ElCount-1) * sizeof(TElements));
- ElCount--;
- }
- Elements[ElCount].EDone = 0;
- Elements[ElCount].Type = etype;
- Elements[ElCount].ECount = min(30, cnt);
- int c;
- switch (etype) {
- case partBlood:
- #ifdef _d3d
- Elements[ElCount].RGBA = 0xE0600000;
- Elements[ElCount].RGBA2= 0x20300000;
- #else
- Elements[ElCount].RGBA = 0xE0000060;
- Elements[ElCount].RGBA2= 0x20000030;
- #endif
- break;
- case partGround:
- #ifdef _d3d
- Elements[ElCount].RGBA = 0xF0F09E55;
- Elements[ElCount].RGBA2= 0x10F09E55;
- #else
- Elements[ElCount].RGBA = 0xF0559EF0;
- Elements[ElCount].RGBA2= 0x10559EF0;
- #endif
- break;
- case partBubble:
- c = WaterList[ WMap[ (int)z / 256][ (int)x / 256] ].fogRGB;
- #ifdef _d3d
- c = ColorSum( ((c & 0xFEFEFE)>>1) , 0x152020);
- #else
- c = ColorSum( ((c & 0xFEFEFE)>>1) , 0x202015);
- #endif
- Elements[ElCount].RGBA = 0x70000000 + (ColorSum(c, ColorSum(c,c)));
- Elements[ElCount].RGBA2= 0x40000000 + (ColorSum(c, c));
- break;
- case partWater:
- c = WaterList[ WMap[ (int)z / 256][ (int)x / 256] ].fogRGB;
- #ifdef _d3d
- c = ColorSum( ((c & 0xFEFEFE)>>1) , 0x152020);
- #else
- c = ColorSum( ((c & 0xFEFEFE)>>1) , 0x202015);
- #endif
- Elements[ElCount].RGBA = 0xB0000000 + ( ColorSum(c, ColorSum(c,c)) );
- Elements[ElCount].RGBA2 = 0x40000000 + (c);
- break;
- }
-
- Elements[ElCount].RGBA = conv_xGx(Elements[ElCount].RGBA);
- Elements[ElCount].RGBA2 = conv_xGx(Elements[ElCount].RGBA2);
-
- float al = siRand(128) / 128.f * pi / 4.f;
- float ss = sin(al);
- float cc = cos(al);
- for (int e=0; e<Elements[ElCount].ECount; e++) {
- Elements[ElCount].EList[e].pos.x = x;
- Elements[ElCount].EList[e].pos.y = y;
- Elements[ElCount].EList[e].pos.z = z;
- Elements[ElCount].EList[e].R = 6 + rRand(5);
- Elements[ElCount].EList[e].Flags = 0;
- float v;
- switch (etype) {
- case partBlood:
- v = e * 6 + rRand(96) + 220;
- Elements[ElCount].EList[e].speed.x =ss*ca*v + siRand(32);
- Elements[ElCount].EList[e].speed.y =cc * (v * 3);
- Elements[ElCount].EList[e].speed.z =ss*sa*v + siRand(32);
- break;
- case partGround:
- Elements[ElCount].EList[e].speed.x =siRand(52)-sa*64;
- Elements[ElCount].EList[e].speed.y =rRand(100) + 600 + e * 20;
- Elements[ElCount].EList[e].speed.z =siRand(52)+ca*64;
- break;
- case partWater:
- Elements[ElCount].EList[e].speed.x =siRand(32);
- Elements[ElCount].EList[e].speed.y =rRand(80) + 400 + e * 40;
- Elements[ElCount].EList[e].speed.z =siRand(32);
- break;
- case partBubble:
- Elements[ElCount].EList[e].speed.x =siRand(40);
- Elements[ElCount].EList[e].speed.y =rRand(140) + 20;
- Elements[ElCount].EList[e].speed.z =siRand(40);
- break;
- }
- }
- ElCount++;
- }
- void MakeShot(float ax, float ay, float az,
- float bx, float by, float bz)
- {
- int sres;
- if (!WeapInfo[CurrentWeapon].Fall)
- sres = TraceShot(ax, ay, az, bx, by, bz);
- else {
- Vector3d dl;
- float dy = 40.f * ctViewR / 36.f;
- dl.x = (bx-ax) / 3;
- dl.y = (by-ay) / 3;
- dl.z = (bz-az) / 3;
- bx = ax + dl.x;
- by = ay + dl.y - dy / 2;
- bz = az + dl.z;
- sres = TraceShot(ax, ay, az, bx, by, bz);
- if (sres!=-1) goto ENDTRACE;
- ax = bx; ay = by; az = bz;
- bx = ax + dl.x;
- by = ay + dl.y - dy * 3;
- bz = az + dl.z;
- sres = TraceShot(ax, ay, az, bx, by, bz);
- if (sres!=-1) goto ENDTRACE;
- ax = bx; ay = by; az = bz;
- bx = ax + dl.x;
- by = ay + dl.y - dy * 5;
- bz = az + dl.z;
- sres = TraceShot(ax, ay, az, bx, by, bz);
- if (sres!=-1) goto ENDTRACE;
- ax = bx; ay = by; az = bz;
- }
- ENDTRACE:
- if (sres==-1) return;
- int mort = (sres & 0xFF00) && (Characters[ShotDino].Health);
- sres &= 0xFF;
- if (sres == tresGround)
- AddElements(bx, by, bz, partGround, 6 + WeapInfo[CurrentWeapon].Power*4);
- if (sres == tresModel)
- AddElements(bx, by, bz, partGround, 6 + WeapInfo[CurrentWeapon].Power*4);
-
- if (sres == tresWater) {
- AddElements(bx, by, bz, partWater, 4 + WeapInfo[CurrentWeapon].Power*3);
-
- AddWCircle(bx, bz, 1.2);
- AddWCircle(bx, bz, 1.2);
- }
-
- if (sres!=tresChar) return;
- AddElements(bx, by, bz, partBlood, 4 + WeapInfo[CurrentWeapon].Power*4);
- if (!Characters[ShotDino].Health) return;
-
- if (mort) Characters[ShotDino].Health = 0;
- else Characters[ShotDino].Health-=WeapInfo[CurrentWeapon].Power;
- if (Characters[ShotDino].Health<0) Characters[ShotDino].Health=0;
-
- if (!Characters[ShotDino].Health) {
- if (Characters[ShotDino].AI>=10) {
- TrophyRoom.Last.success++;
- AddShipTask(ShotDino);
- }
- if (Characters[ShotDino].AI<10)
- Characters_AddSecondaryOne(Characters[ShotDino].CType);
-
- }
- else {
- Characters[ShotDino].AfraidTime = 60*1000;
- if (Characters[ShotDino].AI!=AI_TREX || Characters[ShotDino].State==0)
- Characters[ShotDino].State = 2;
-
- if (Characters[ShotDino].AI != AI_BRACH)
- Characters[ShotDino].BloodTTime+=90000;
-
- }
- if (Characters[ShotDino].AI==AI_TREX)
- if (Characters[ShotDino].State)
- Characters[ShotDino].State = 5;
- else
- Characters[ShotDino].State = 1;
- }
- void RemoveCharacter(int index)
- {
- if (index==-1) return;
- memcpy( &Characters[index], &Characters[index+1], (255 - index) * sizeof(TCharacter) );
- ChCount--;
-
- if (DemoPoint.CIndex > index) DemoPoint.CIndex--;
- for (int c=0; c<ShipTask.tcount; c++)
- if (ShipTask.clist[c]>index) ShipTask.clist[c]--;
- }
- void AnimateShip()
- {
- if (Ship.State==-1) {
- SetAmbient3d(0,0, 0,0,0);
- if (!ShipTask.tcount) return;
- InitShip(ShipTask.clist[0]);
- memcpy(&ShipTask.clist[0], &ShipTask.clist[1], 250*4);
- ShipTask.tcount--;
- return;
- }
- SetAmbient3d(ShipModel.SoundFX[0].length,
- ShipModel.SoundFX[0].lpData,
- Ship.pos.x, Ship.pos.y, Ship.pos.z);
- int _TimeDt = TimeDt;
- if (Ship.FTime) {
- int am = ShipModel.Animation[0].AniTime;
- if (Ship.FTime < 500) _TimeDt = TimeDt * (Ship.FTime + 48) / 548;
- if (am-Ship.FTime < 500) _TimeDt = TimeDt * (am-Ship.FTime + 48) / 548;
- if (_TimeDt<2) _TimeDt=2;
- }
- float L = VectorLength( SubVectors(Ship.tgpos, Ship.pos) );
- float L2 = sqrt ( (Ship.tgpos.x - Ship.pos.x) * (Ship.tgpos.x - Ship.pos.x) +
- (Ship.tgpos.x - Ship.pos.x) * (Ship.tgpos.x - Ship.pos.x) );
- Ship.pos.y+=0.3f*(float)cos(RealTime / 256.f);
-
- Ship.tgalpha = FindVectorAlpha(Ship.tgpos.x - Ship.pos.x, Ship.tgpos.z - Ship.pos.z);
- float currspeed;
- float dalpha = (float)fabs(Ship.tgalpha - Ship.alpha);
- float drspd = dalpha; if (drspd>pi) drspd = 2*pi - drspd;
- if (Ship.State)
- if (Ship.speed>1)
- if (L<4000)
- if (VectorLength(SubVectors(PlayerPos, Ship.pos))<(ctViewR+2)*256) {
- Ship.tgpos.x += (float)cos(Ship.alpha) * 256*6.f;
- Ship.tgpos.z += (float)sin(Ship.alpha) * 256*6.f;
- Ship.tgpos.y = GetLandUpH(Ship.tgpos.x, Ship.tgpos.z) + Ship.DeltaY;
- Ship.tgpos.y = max(Ship.tgpos.y, GetLandUpH(Ship.pos.x, Ship.pos.z) + Ship.DeltaY);
- }
- if (Ship.State==3) {
- Ship.FTime+=_TimeDt;
- if (Ship.FTime>=ShipModel.Animation[0].AniTime) {
- Ship.FTime=ShipModel.Animation[0].AniTime-1;
- Ship.State=2;
- AddVoicev(ShipModel.SoundFX[4].length,
- ShipModel.SoundFX[4].lpData, 256);
- AddVoice3d(ShipModel.SoundFX[1].length, ShipModel.SoundFX[1].lpData,
- Ship.pos.x, Ship.pos.y, Ship.pos.z);
- }
- return;
- }
-
- if (Ship.State) {
- if (Ship.cindex!=-1) {
- DeltaFunc(Characters[Ship.cindex].pos.y, Ship.pos.y-650 - (Ship.DeltaY-2048), _TimeDt / 3.f);
- DeltaFunc(Characters[Ship.cindex].beta, 0, TimeDt / 4048.f);
- DeltaFunc(Characters[Ship.cindex].gamma, 0, TimeDt / 4048.f);
- }
-
- if (Ship.State==2) {
- Ship.FTime-=_TimeDt;
- if (Ship.FTime<0) Ship.FTime=0;
- if (Ship.FTime==0)
- if (fabs(Characters[Ship.cindex].pos.y - (Ship.pos.y-650 - (Ship.DeltaY-2048))) < 1.f) {
- Ship.State = 1;
- AddVoicev(ShipModel.SoundFX[5].length,
- ShipModel.SoundFX[5].lpData, 256);
- AddVoice3d(ShipModel.SoundFX[2].length, ShipModel.SoundFX[2].lpData,
- Ship.pos.x, Ship.pos.y, Ship.pos.z);
- }
- return;
- }
- }
-
- float vspeed = 1.f + L / 128.f;
- if (vspeed > 24) vspeed = 24;
- if (Ship.State) vspeed = 24;
- if (fabs(dalpha) > 0.4) vspeed = 0.f;
- float _s = Ship.speed;
- if (vspeed>Ship.speed) DeltaFunc(Ship.speed, vspeed, TimeDt / 200.f);
- else Ship.speed = vspeed;
- if (Ship.speed>0 && _s==0)
- AddVoice3d(ShipModel.SoundFX[2].length, ShipModel.SoundFX[2].lpData,
- Ship.pos.x, Ship.pos.y, Ship.pos.z);
- float l = TimeDt * Ship.speed / 16.f;
-
- if (fabs(dalpha) < 0.4)
- if (l<L) {
- if (l>L2) l = L2 * 0.5f;
- if (L2<0.1) l = 0;
- Ship.pos.x += (float)cos(Ship.alpha)*l;
- Ship.pos.z += (float)sin(Ship.alpha)*l;
- } else {
- if (Ship.State) {
- Ship.State = -1;
- RemoveCharacter(Ship.cindex);
- return;
- } else {
- Ship.pos = Ship.tgpos;
- Ship.State = 3;
- Ship.FTime = 1;
- Ship.tgpos = Ship.retpos;
- Ship.tgpos.y = GetLandUpH(Ship.tgpos.x, Ship.tgpos.z) + Ship.DeltaY;
- Ship.tgpos.y = max(Ship.tgpos.y, GetLandUpH(Ship.pos.x, Ship.pos.z) + Ship.DeltaY);
- Characters[Ship.cindex].StateF = 0xFF;
- AddVoice3d(ShipModel.SoundFX[1].length, ShipModel.SoundFX[1].lpData,
- Ship.pos.x, Ship.pos.y, Ship.pos.z);
- }
- }
- float h = GetLandUpH(Ship.pos.x, Ship.pos.z);
- DeltaFunc(Ship.pos.y, Ship.tgpos.y, TimeDt / 4.f);
- if (Ship.pos.y < h + 1024) {
- if (Ship.State)
- if (Ship.cindex!=-1)
- Characters[Ship.cindex].pos.y+= h + 1024 - Ship.pos.y;
- Ship.pos.y = h + 1024;
- }
-
-
-
- if (Ship.tgalpha > Ship.alpha) currspeed = 0.1f + (float)fabs(drspd)/2.f;
- else currspeed =-0.1f - (float)fabs(drspd)/2.f;
-
- if (fabs(dalpha) > pi) currspeed=-currspeed;
-
-
- DeltaFunc(Ship.rspeed, currspeed, (float)TimeDt / 420.f);
-
- float rspd=Ship.rspeed * TimeDt / 1024.f;
- if (fabs(drspd) < fabs(rspd)) { Ship.alpha = Ship.tgalpha; Ship.rspeed/=2; }
- else {
- Ship.alpha+=rspd;
- if (Ship.State)
- if (Ship.cindex!=-1)
- Characters[Ship.cindex].alpha+=rspd;
- }
- if (Ship.alpha<0) Ship.alpha+=pi*2;
- if (Ship.alpha>pi*2) Ship.alpha-=pi*2;
- if (Ship.State) {
- if (Ship.cindex!=-1) {
- Characters[Ship.cindex].pos.x = Ship.pos.x;
- Characters[Ship.cindex].pos.z = Ship.pos.z;
- }
- if (L>1000) Ship.tgpos.y+=TimeDt / 12.f;
- } else {
- Ship.tgpos.x = Characters[Ship.cindex].pos.x;
- Ship.tgpos.z = Characters[Ship.cindex].pos.z;
- Ship.tgpos.y = GetLandUpH(Ship.tgpos.x, Ship.tgpos.z) + Ship.DeltaY;
- Ship.tgpos.y = max(Ship.tgpos.y, GetLandUpH(Ship.pos.x, Ship.pos.z) + Ship.DeltaY);
- }
-
-
- }
- void ProcessTrophy()
- {
- TrophyBody = -1;
- for (int c=0; c<ChCount; c++) {
- Vector3d p = Characters[c].pos;
- p.x+=Characters[c].lookx * 256*2.5f;
- p.z+=Characters[c].lookz * 256*2.5f;
- if (VectorLength( SubVectors(p, PlayerPos) ) < 148)
- TrophyBody = c;
- }
- if (TrophyBody==-1) return;
- TrophyBody = Characters[TrophyBody].State;
- }
- void AnimateElements()
- {
- for (int eg=0; eg<ElCount; eg++) {
- if (Elements[eg].Type == partGround) {
- int a1 = Elements[eg].RGBA >> 24; a1-=TimeDt/4; if (a1<0) a1=0; Elements[eg].RGBA = (Elements[eg].RGBA & 0x00FFFFFF) + (a1<<24);
- int a2 = Elements[eg].RGBA2>> 24; a2-=TimeDt/4; if (a2<0) a2=0; Elements[eg].RGBA2= (Elements[eg].RGBA2 & 0x00FFFFFF) + (a2<<24);
- if (a1 == 0 && a2==0) Elements[eg].ECount = 0;
- }
- if (Elements[eg].Type == partWater)
- if (Elements[eg].EDone == Elements[eg].ECount)
- Elements[eg].ECount = 0;
- if (Elements[eg].Type == partBubble)
- if (Elements[eg].EDone == Elements[eg].ECount)
- Elements[eg].ECount = 0;
-
- if (Elements[eg].Type == partBlood)
- if ((Takt & 3)==0)
- if (Elements[eg].EDone == Elements[eg].ECount) {
- int a1 = Elements[eg].RGBA >> 24; a1--; if (a1<0) a1=0; Elements[eg].RGBA = (Elements[eg].RGBA & 0x00FFFFFF) + (a1<<24);
- int a2 = Elements[eg].RGBA2>> 24; a2--; if (a2<0) a2=0; Elements[eg].RGBA2= (Elements[eg].RGBA2 & 0x00FFFFFF) + (a2<<24);
- if (a1 == 0 && a2==0) Elements[eg].ECount = 0;
- }
- if (!Elements[eg].ECount) {
- memcpy(&Elements[eg], &Elements[eg+1], (ElCount+1-eg) * sizeof(TElements));
- ElCount--;
- eg--;
- continue;
- }
- for (int e=0; e<Elements[eg].ECount; e++) {
- if (Elements[eg].EList[e].Flags) continue;
- Elements[eg].EList[e].pos.x+=Elements[eg].EList[e].speed.x * TimeDt / 1000.f;
- Elements[eg].EList[e].pos.y+=Elements[eg].EList[e].speed.y * TimeDt / 1000.f;
- Elements[eg].EList[e].pos.z+=Elements[eg].EList[e].speed.z * TimeDt / 1000.f;
- float h;
- h = GetLandUpH(Elements[eg].EList[e].pos.x, Elements[eg].EList[e].pos.z);
- BOOL OnWater = GetLandH(Elements[eg].EList[e].pos.x, Elements[eg].EList[e].pos.z) < h;
- switch (Elements[eg].Type) {
- case partBubble:
- Elements[eg].EList[e].speed.y += 2.0 * 256 * TimeDt / 1000.f;
- if (Elements[eg].EList[e].speed.y > 824) Elements[eg].EList[e].speed.y = 824;
- if (Elements[eg].EList[e].pos.y > h) {
- AddWCircle(Elements[eg].EList[e].pos.x, Elements[eg].EList[e].pos.z, 0.6);
- Elements[eg].EDone++;
- Elements[eg].EList[e].Flags = 1;
- if (OnWater) Elements[eg].EList[e].pos.y-= 10240;
- }
- break;
-
- default:
- Elements[eg].EList[e].speed.y -= 9.8 * 256 * TimeDt / 1000.f;
- if (Elements[eg].EList[e].pos.y < h) {
- if (OnWater) AddWCircle(Elements[eg].EList[e].pos.x, Elements[eg].EList[e].pos.z, 0.6);
- Elements[eg].EDone++;
- Elements[eg].EList[e].Flags = 1;
- if (OnWater) Elements[eg].EList[e].pos.y-= 10240;
- else Elements[eg].EList[e].pos.y = h + 4;
- }
- break;
-
- }
- }
- }
- for (int b=0; b<BloodTrail.Count; b++) {
- BloodTrail.Trail[b].LTime-=TimeDt;
- if (BloodTrail.Trail[b].LTime<=0) {
- memcpy(&BloodTrail.Trail[b], &BloodTrail.Trail[b+1], (511-b)*sizeof(TBloodP));
- BloodTrail.Count--;
- b--;
- }
- }
- }
- void AnimateProcesses()
- {
- AnimateElements();
- if ((Takt & 63)==0) {
- float al2 = CameraAlpha + siRand(60) * pi / 180.f;
- float c2 = cos(al2);
- float s2 = sin(al2);
- float l = 1024 + rRand(3120);
- float xx = CameraX + s2 * l;
- float zz = CameraZ - c2 * l;
- if (GetLandUpH(xx,zz) > GetLandH(xx,zz)+256)
- AddElements(xx, GetLandH(xx,zz), zz, 4, 6 + rRand(6));
- }
- if (Takt & 1) {
- Wind.alpha+=siRand(16) / 4096.f;
- Wind.speed+=siRand(400) / 6400.f;
- }
- if (Wind.speed< 4.f) Wind.speed=4.f;
- if (Wind.speed>18.f) Wind.speed=18.f;
- Wind.nv.x = (float) sin(Wind.alpha);
- Wind.nv.z = (float)-cos(Wind.alpha);
- Wind.nv.y = 0.f;
- if (answtime) {
- answtime-=TimeDt;
- if (answtime<=0) {
- answtime = 0;
- int r = rRand(128) % 3;
- AddVoice3d(fxCall[answcall-10][r].length, fxCall[answcall-10][r].lpData,
- answpos.x, answpos.y, answpos.z);
- }
- }
- if (CallLockTime) {
- CallLockTime-=TimeDt;
- if (CallLockTime<0) CallLockTime=0;
- }
- CheckAfraid();
- AnimateShip();
- if (TrophyMode)
- ProcessTrophy();
-
- for (int w=0; w<WCCount; w++) {
- if (WCircles[w].scale > 1)
- WCircles[w].FTime+=(int)(TimeDt*3 / WCircles[w].scale);
- else
- WCircles[w].FTime+=TimeDt*3;
- if (WCircles[w].FTime >= 2000) {
- memcpy(&WCircles[w], &WCircles[w+1], sizeof(TWCircle) * (WCCount+1-w) );
- w--;
- WCCount--;
- }
- }
- if (ExitTime) {
- ExitTime-=TimeDt;
- if (ExitTime<=0) {
- TrophyRoom.Total.time +=TrophyRoom.Last.time;
- TrophyRoom.Total.smade +=TrophyRoom.Last.smade;
- TrophyRoom.Total.success+=TrophyRoom.Last.success;
- TrophyRoom.Total.path +=TrophyRoom.Last.path;
-
- if (MyHealth) SaveTrophy();
- else LoadTrophy();
- DoHalt("");
- }
- }
- }
- void RemoveCurrentTrophy()
- {
- int p = 0;
- if (!TrophyMode) return;
- if (!TrophyRoom.Body[TrophyBody].ctype) return;
- PrintLog("Trophy removed: ");
- PrintLog(DinoInfo[TrophyRoom.Body[TrophyBody].ctype].Name);
- PrintLog("\n");
- for (int c=0; c<TrophyBody; c++)
- if (TrophyRoom.Body[c].ctype) p++;
- TrophyRoom.Body[TrophyBody].ctype = 0;
- if (TrophyMode) {
- memcpy(&Characters[p],
- &Characters[p+1],
- (250-p) * sizeof(TCharacter) );
- ChCount--;
- }
- TrophyTime = 0;
- TrophyBody = -1;
- }
- void LoadTrophy()
- {
- int pr = TrophyRoom.RegNumber;
- FillMemory(&TrophyRoom, sizeof(TrophyRoom), 0);
- TrophyRoom.RegNumber = pr;
- DWORD l;
- char fname[128];
- int rn = TrophyRoom.RegNumber;
- wsprintf(fname, "trophy0%d.sav", TrophyRoom.RegNumber);
- HANDLE hfile = CreateFile(fname, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
- if (hfile==INVALID_HANDLE_VALUE) {
- PrintLog("===> Error loading trophy!\n");
- return;
- }
- ReadFile(hfile, &TrophyRoom, sizeof(TrophyRoom), &l, NULL);
- ReadFile(hfile, &OptAgres, 4, &l, NULL);
- ReadFile(hfile, &OptDens , 4, &l, NULL);
- ReadFile(hfile, &OptSens , 4, &l, NULL);
- ReadFile(hfile, &OptRes, 4, &l, NULL);
- ReadFile(hfile, &FOGENABLE, 4, &l, NULL);
- ReadFile(hfile, &OptText , 4, &l, NULL);
- ReadFile(hfile, &OptViewR, 4, &l, NULL);
- ReadFile(hfile, &SHADOWS3D, 4, &l, NULL);
- ReadFile(hfile, &OptMsSens, 4, &l, NULL);
- ReadFile(hfile, &OptBrightness, 4, &l, NULL);
- ReadFile(hfile, &KeyMap, sizeof(KeyMap), &l, NULL);
- ReadFile(hfile, &REVERSEMS, 4, &l, NULL);
- ReadFile(hfile, &ScentMode, 4, &l, NULL);
- ReadFile(hfile, &CamoMode, 4, &l, NULL);
- ReadFile(hfile, &RadarMode, 4, &l, NULL);
- ReadFile(hfile, &Tranq , 4, &l, NULL);
- ReadFile(hfile, &OPT_ALPHA_COLORKEY, 4, &l, NULL);
- ReadFile(hfile, &OptSys , 4, &l, NULL);
- ReadFile(hfile, &OptSound , 4, &l, NULL);
- ReadFile(hfile, &OptRender, 4, &l, NULL);
-
- SetupRes();
- CloseHandle(hfile);
- TrophyRoom.RegNumber = rn;
- PrintLog("Trophy Loaded.\n");
- }
- void SaveTrophy()
- {
- DWORD l;
- char fname[128];
- wsprintf(fname, "trophy0%d.sav", TrophyRoom.RegNumber);
- int r = TrophyRoom.Rank;
- TrophyRoom.Rank = 0;
- if (TrophyRoom.Score >= 100) TrophyRoom.Rank = 1;
- if (TrophyRoom.Score >= 300) TrophyRoom.Rank = 2;
-
- HANDLE hfile = CreateFile(fname, GENERIC_WRITE, FILE_SHARE_READ, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
- if (hfile == INVALID_HANDLE_VALUE) {
- PrintLog("==>> Error saving trophy!\n");
- return;
- }
- WriteFile(hfile, &TrophyRoom, sizeof(TrophyRoom), &l, NULL);
- WriteFile(hfile, &OptAgres, 4, &l, NULL);
- WriteFile(hfile, &OptDens , 4, &l, NULL);
- WriteFile(hfile, &OptSens , 4, &l, NULL);
- WriteFile(hfile, &OptRes, 4, &l, NULL);
- WriteFile(hfile, &FOGENABLE, 4, &l, NULL);
- WriteFile(hfile, &OptText , 4, &l, NULL);
- WriteFile(hfile, &OptViewR, 4, &l, NULL);
- WriteFile(hfile, &SHADOWS3D, 4, &l, NULL);
- WriteFile(hfile, &OptMsSens, 4, &l, NULL);
- WriteFile(hfile, &OptBrightness, 4, &l, NULL);
- WriteFile(hfile, &KeyMap, sizeof(KeyMap), &l, NULL);
- WriteFile(hfile, &REVERSEMS, 4, &l, NULL);
- WriteFile(hfile, &ScentMode, 4, &l, NULL);
- WriteFile(hfile, &CamoMode , 4, &l, NULL);
- WriteFile(hfile, &RadarMode, 4, &l, NULL);
- WriteFile(hfile, &Tranq , 4, &l, NULL);
- WriteFile(hfile, &OPT_ALPHA_COLORKEY, 4, &l, NULL);
- WriteFile(hfile, &OptSys , 4, &l, NULL);
- WriteFile(hfile, &OptSound , 4, &l, NULL);
- WriteFile(hfile, &OptRender, 4, &l, NULL);
- CloseHandle(hfile);
- PrintLog("Trophy Saved.\n");
- }
|