Use quadtree for collisions.

This commit is contained in:
Steve 2018-02-09 07:21:37 +00:00
parent 11960757cc
commit 0e71bcc88f
1 changed files with 18 additions and 4 deletions

View File

@ -125,6 +125,7 @@ void doEntities(void)
if (self->flags & EF_GONE)
{
self->isVisible = 0;
prev = self;
continue;
}
@ -281,13 +282,18 @@ static int getMarkerType(void)
static void checkPlatformContact(void)
{
Entity *e;
int i;
srcRect.x = self->x;
srcRect.y = self->y + 4;
srcRect.w = self->w;
srcRect.h = self->h;
for (e = world.entityHead.next ; e != NULL ; e = e->next)
Entity **candidates;
candidates = getAllEntsWithin(srcRect.x, srcRect.y, srcRect.w, srcRect.h, NULL);
for (i = 0, e = candidates[i] ; e != NULL ; e = candidates[++i])
{
if (e == self || e->type != ET_LIFT)
{
@ -462,6 +468,7 @@ static void haltAtEdge(void)
static int canWalkOnEntity(float x, float y)
{
int i;
Entity *e;
srcRect.x = x;
@ -469,7 +476,11 @@ static int canWalkOnEntity(float x, float y)
srcRect.w = 8;
srcRect.h = MAP_TILE_SIZE * 4;
for (e = world.entityHead.next ; e != NULL ; e = e->next)
Entity **candidates;
candidates = getAllEntsWithin(srcRect.x, srcRect.y, srcRect.w, srcRect.h, NULL);
for (i = 0, e = candidates[i] ; e != NULL ; e = candidates[++i])
{
if (self != e && e->isSolid && collision(x, y, 1, MAP_TILE_SIZE * 2, e->x, e->y, e->w, e->y))
{
@ -483,7 +494,8 @@ static int canWalkOnEntity(float x, float y)
static void moveToOthers(float dx, float dy, PointF *position)
{
Entity *e;
int clearTouched, hit, dirX, dirY, solidLoopHits;
Entity **candidates;
int clearTouched, hit, dirX, dirY, solidLoopHits, i;
srcRect.x = (int) position->x;
srcRect.y = (int) position->y;
@ -500,7 +512,9 @@ static void moveToOthers(float dx, float dy, PointF *position)
{
hit = 0;
for (e = world.entityHead.next ; e != NULL ; e = e->next)
candidates = getAllEntsWithin(srcRect.x, srcRect.y, srcRect.w, srcRect.h, NULL);
for (i = 0, e = candidates[i] ; e != NULL ; e = candidates[++i])
{
if (e == self || e->owner == self || self->owner == e)
{