Ent movement fixed.

This commit is contained in:
2025-11-03 21:35:21 -06:00
parent d4a2e059d7
commit be79356f42
3 changed files with 16 additions and 18 deletions

View File

@@ -86,21 +86,21 @@ void entityWalk(entity_t *entity, const entitydir_t direction) {
// TODO: Map bounds in way?
// Entity in way?
// entity_t *start = GAME.overworld.map.entities;
// entity_t *end = start + MAP_ENTITY_COUNT;
// while(start < end) {
// if(
// start == entity ||
// entity->type == ENTITY_TYPE_NULL ||
// start->position.x != newX ||
// start->position.y != newY
// ) {
// start++;
// continue;
// }
entity_t *start = ENTITIES;
do {
if(
start == entity ||
entity->type == ENTITY_TYPE_NULL ||
start->position.x != newX ||
start->position.y != newY ||
start->position.z != entity->position.z
) {
start++;
continue;
}
// return;// Blocked
// }
return;// Blocked
} while(start < &ENTITIES[ENTITY_COUNT]);
// Move.
entity->position.x = newX;

View File

@@ -8,7 +8,7 @@
#pragma once
#include "dusk.h"
#define ENTITY_ANIM_TURN_DURATION 1
#define ENTITY_ANIM_TURN_DURATION 6
#define ENTITY_ANIM_WALK_DURATION 10
typedef enum {

View File

@@ -36,7 +36,7 @@ void playerMovement(entity_t *entity) {
// Turn
const playerinputdirmap_t *dirMap = PLAYER_INPUT_DIR_MAP;
do {
if(!inputPressed(dirMap->action)) continue;
if(!inputIsDown(dirMap->action)) continue;
if(entity->direction == dirMap->direction) continue;
return entityTurn(entity, dirMap->direction);
} while((++dirMap)->action != 0xFF);
@@ -48,8 +48,6 @@ void playerMovement(entity_t *entity) {
if(entity->direction != dirMap->direction) continue;
return entityWalk(entity, dirMap->direction);
} while((++dirMap)->action != 0xFF);
// Interaction
}
void playerInteraction(entity_t *entity) {