mirror of
https://github.com/GTAmodding/re3.git
synced 2024-12-02 09:45:43 +00:00
79 lines
1.6 KiB
C++
79 lines
1.6 KiB
C++
#include "common.h"
|
|
|
|
#include "main.h"
|
|
#include "PedRoutes.h"
|
|
|
|
CRouteNode gaRoutes[NUMPEDROUTES];
|
|
|
|
void
|
|
CRouteNode::Initialise()
|
|
{
|
|
for (int i = 0; i < NUMPEDROUTES; i++) {
|
|
gaRoutes[i].m_route = -1;
|
|
gaRoutes[i].m_pos = CVector(0.0f, 0.0f, 0.0f);
|
|
}
|
|
}
|
|
|
|
int16
|
|
CRouteNode::GetRouteThisPointIsOn(int16 point)
|
|
{
|
|
return gaRoutes[point].m_route;
|
|
}
|
|
|
|
// Actually GetFirstPointOfRoute
|
|
int16
|
|
CRouteNode::GetRouteStart(int16 route)
|
|
{
|
|
for (int i = 0; i < NUMPEDROUTES; i++) {
|
|
if (route == gaRoutes[i].m_route)
|
|
return i;
|
|
}
|
|
return -1;
|
|
}
|
|
|
|
CVector
|
|
CRouteNode::GetPointPosition(int16 point)
|
|
{
|
|
return gaRoutes[point].m_pos;
|
|
}
|
|
|
|
void
|
|
CRouteNode::AddRoutePoint(int16 route, CVector pos)
|
|
{
|
|
uint16 point;
|
|
for (point = 0; point < NUMPEDROUTES; point++) {
|
|
if (gaRoutes[point].m_route == -1)
|
|
break;
|
|
}
|
|
#ifdef FIX_BUGS
|
|
if (point == NUMPEDROUTES)
|
|
return;
|
|
#endif
|
|
gaRoutes[point].m_route = route;
|
|
gaRoutes[point].m_pos = pos;
|
|
}
|
|
|
|
void
|
|
CRouteNode::RemoveRoute(int16 route)
|
|
{
|
|
uint16 first_point, last_point, i;
|
|
for (first_point = 0; first_point < NUMPEDROUTES; first_point++) {
|
|
if (gaRoutes[first_point].m_route == route)
|
|
break;
|
|
}
|
|
if (first_point == NUMPEDROUTES)
|
|
return;
|
|
for (last_point = first_point; last_point < NUMPEDROUTES; last_point++)
|
|
if (gaRoutes[last_point].m_route != route)
|
|
break;
|
|
uint16 diff = last_point - first_point;
|
|
#ifdef FIX_BUGS
|
|
for (i = first_point; i < NUMPEDROUTES - diff; i++)
|
|
gaRoutes[i] = gaRoutes[i + diff];
|
|
#else
|
|
for (i = 0; i < diff; i++)
|
|
gaRoutes[first_point + i] = gaRoutes[last_point + i];
|
|
#endif
|
|
for (i = NUMPEDROUTES - diff; i < NUMPEDROUTES; i++)
|
|
gaRoutes[i].m_route = -1;
|
|
}
|