Browse Source

examples/models: optimize collision check in first_person_maze (#5478)

Limit collision detection to the player surrounding cells instead of
iterating the full cubicmap each frame.
pull/5481/head
Paul de Mascarel 3 days ago
committed by GitHub
parent
commit
5e1f5d5b74
No known key found for this signature in database GPG Key ID: B5690EEEBB952194
1 changed files with 5 additions and 4 deletions
  1. +5
    -4
      examples/models/models_first_person_maze.c

+ 5
- 4
examples/models/models_first_person_maze.c View File

@ -80,12 +80,13 @@ int main(void)
if (playerCellY < 0) playerCellY = 0;
else if (playerCellY >= cubicmap.height) playerCellY = cubicmap.height - 1;
// Check map collisions using image data and player position
// TODO: Improvement: Just check player surrounding cells for collision
for (int y = 0; y < cubicmap.height; y++)
// Check map collisions using image data and player position against surrounding cells only
for (int y = playerCellY - 1; y <= playerCellY + 1; y++)
{
for (int x = 0; x < cubicmap.width; x++)
if (y < 0 || y >= cubicmap.height) continue;
for (int x = playerCellX - 1; x <= playerCellX + 1; x++)
{
if (x < 0 || x >= cubicmap.width) continue;
if ((mapPixels[y*cubicmap.width + x].r == 255) && // Collision: white pixel, only check R channel
(CheckCollisionCircleRec(playerPos, playerRadius,
(Rectangle){ mapPosition.x - 0.5f + x*1.0f, mapPosition.z - 0.5f + y*1.0f, 1.0f, 1.0f })))

Loading…
Cancel
Save