2019-06-24 16:57:54 +02:00
|
|
|
#include "common.h"
|
2020-04-17 15:31:11 +02:00
|
|
|
|
2020-03-28 15:47:52 +01:00
|
|
|
#include "Ped.h"
|
2019-06-24 16:57:54 +02:00
|
|
|
#include "PedPlacement.h"
|
|
|
|
#include "World.h"
|
|
|
|
|
|
|
|
void
|
|
|
|
CPedPlacement::FindZCoorForPed(CVector* pos)
|
|
|
|
{
|
|
|
|
float zForPed;
|
|
|
|
float startZ = pos->z - 100.0f;
|
|
|
|
float foundColZ = -100.0f;
|
|
|
|
float foundColZ2 = -100.0f;
|
|
|
|
CColPoint foundCol;
|
|
|
|
CEntity* foundEnt;
|
|
|
|
|
|
|
|
CVector vec(
|
|
|
|
pos->x,
|
|
|
|
pos->y,
|
|
|
|
pos->z + 1.0f
|
|
|
|
);
|
|
|
|
|
2019-06-30 12:53:39 +02:00
|
|
|
if (CWorld::ProcessVerticalLine(vec, startZ, foundCol, foundEnt, true, false, false, false, true, false, nil))
|
2019-06-24 16:57:54 +02:00
|
|
|
foundColZ = foundCol.point.z;
|
|
|
|
|
|
|
|
// Adjust coords and do a second test
|
|
|
|
vec.x += 0.1f;
|
|
|
|
vec.y += 0.1f;
|
|
|
|
|
2019-06-30 12:53:39 +02:00
|
|
|
if (CWorld::ProcessVerticalLine(vec, startZ, foundCol, foundEnt, true, false, false, false, true, false, nil))
|
2019-06-24 16:57:54 +02:00
|
|
|
foundColZ2 = foundCol.point.z;
|
|
|
|
|
2020-04-19 18:34:08 +02:00
|
|
|
zForPed = Max(foundColZ, foundColZ2);
|
2019-06-24 16:57:54 +02:00
|
|
|
|
|
|
|
if (zForPed > -99.0f)
|
2020-03-07 20:22:43 +01:00
|
|
|
pos->z = FEET_OFFSET + zForPed;
|
2019-06-24 16:57:54 +02:00
|
|
|
}
|
|
|
|
|
2019-07-18 04:26:46 +02:00
|
|
|
CEntity*
|
2020-05-05 03:45:18 +02:00
|
|
|
CPedPlacement::IsPositionClearOfCars(Const CVector *pos)
|
2019-07-18 04:26:46 +02:00
|
|
|
{
|
2019-07-31 17:54:18 +02:00
|
|
|
return CWorld::TestSphereAgainstWorld(*pos, 0.25f, nil, true, true, false, false, false, false);
|
2019-07-18 04:26:46 +02:00
|
|
|
}
|
|
|
|
|
2020-02-18 00:56:13 +01:00
|
|
|
bool
|
|
|
|
CPedPlacement::IsPositionClearForPed(CVector* pos)
|
|
|
|
{
|
|
|
|
int16 count;
|
|
|
|
CWorld::FindObjectsKindaColliding(*pos, 0.75f, true, &count, 2, nil, false, true, true, false, false);
|
|
|
|
return count == 0;
|
|
|
|
}
|