X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Fgame%2Fg_basic.pas;h=98cebcce846067023ff07b3fa558f1c9ddba0797;hb=58b15f7d5aee8dc280a2e407c11a1f0448eea7ef;hp=67285caa60e8cb5349cdd9f606ca1a66dc7f70ca;hpb=dd0d8ac4cc2a0aa774f25c8a1a774f7358acfae7;p=d2df-sdl.git diff --git a/src/game/g_basic.pas b/src/game/g_basic.pas index 67285ca..98cebcc 100644 --- a/src/game/g_basic.pas +++ b/src/game/g_basic.pas @@ -47,8 +47,6 @@ function g_CollideLevel(X, Y: Integer; Width, Height: Word): Boolean; function g_CollideAround(X1, Y1: Integer; Width1, Height1: Word; X2, Y2: Integer; Width2, Height2: Word): Boolean; function g_CollidePlayer(X, Y: Integer; Width, Height: Word): Boolean; -function g_CollideMonster(X, Y: Integer; Width, Height: Word): Boolean; -function g_CollideItem(X, Y: Integer; Width, Height: Word): Boolean; function g_PatchLength(X1, Y1, X2, Y2: Integer): Word; function g_TraceVector(X1, Y1, X2, Y2: Integer): Boolean; function g_GetAcidHit(X, Y: Integer; Width, Height: Word): Byte; @@ -102,6 +100,10 @@ begin end; function g_CollideLevel(X, Y: Integer; Width, Height: Word): Boolean; +begin + result := g_Map_CollidePanel(X, Y, Width, Height, (PANEL_WALL or PANEL_CLOSEDOOR or PANEL_OPENDOOR), false); +end; +(* var a: Integer; begin @@ -121,6 +123,7 @@ begin Exit; end; end; +*) function g_CollidePlayer(X, Y: Integer; Width, Height: Word): Boolean; var @@ -139,41 +142,6 @@ begin end; end; -function g_CollideMonster(X, Y: Integer; Width, Height: Word): Boolean; -var - a: Integer; -begin - Result := False; - - if gMonsters = nil then Exit; - - for a := 0 to High(gMonsters) do - if (gMonsters[a] <> nil) and gMonsters[a].Live then - if g_Obj_Collide(X, Y, Width, Height, @gMonsters[a].Obj) then - begin - Result := True; - Exit; - end; -end; - -function g_CollideItem(X, Y: Integer; Width, Height: Word): Boolean; -var - a: Integer; -begin - Result := False; - - if gItems = nil then - Exit; - - for a := 0 to High(gItems) do - if gItems[a].Live then - if g_Obj_Collide(X, Y, Width, Height, @gItems[a].Obj) then - begin - Result := True; - Exit; - end; -end; - function g_TraceVector(X1, Y1, X2, Y2: Integer): Boolean; var i: Integer; @@ -254,19 +222,12 @@ begin UID_MONSTER: begin - repeat - Result := UID_MAX_PLAYER+$1+Random(UID_MAX_MONSTER-UID_MAX_GAME-UID_MAX_PLAYER+$1); - - ok := True; - if gMonsters <> nil then - for i := 0 to High(gMonsters) do - if gMonsters[i] <> nil then - if Result = gMonsters[i].UID then - begin - ok := False; - Break; - end; - until ok; + //FIXME!!! + while true do + begin + result := UID_MAX_PLAYER+$1+Random(UID_MAX_MONSTER-UID_MAX_GAME-UID_MAX_PLAYER+$1); + if (g_Monsters_ByUID(result) = nil) then break; + end; end; end; end; @@ -986,7 +947,7 @@ begin UID_MONSTER: begin - m := g_Monsters_Get(UID); + m := g_Monsters_ByUID(UID); if m = nil then Exit; if not m.Live then Exit;