Fix player system and clean progs

This commit is contained in:
Ulysse Cura 2025-02-28 19:29:30 +01:00
parent 6d5379d2c3
commit bc98f5040f
4 changed files with 38 additions and 26 deletions

View File

@ -18,59 +18,68 @@ void player_system_init(component_t *component, va_list args __attribute__((unus
}
// Only for this file
static void player_system_get_inputs(component_t *component)
static void player_system_get_inputs(player_system_data_t *system_data)
{
player_system_data_t *system_data = component->component_data.player_system_data;
system_data->last_state = system_data->state;
system_data->state &= 0xF0;
system_data->state &= 0xF0; // 11110000
system_data->state |= game.event.keys[KEY_UP] * RUNNING_UP;
system_data->state |= game.event.keys[KEY_DOWN] * RUNNING_DOWN;
system_data->state |= game.event.keys[KEY_LEFT] * RUNNING_LEFT;
system_data->state |= game.event.keys[KEY_RIGHT] * RUNNING_RIGHT;
// Special cases
if(system_data->state & RUNNING_UP && system_data->state & RUNNING_DOWN) system_data->state &= 0xFC; // 11111100
if(system_data->state & RUNNING_LEFT && system_data->state & RUNNING_RIGHT) system_data->state &= 0xF3; // 11110011
}
// Only for this file
static void player_system_set_state_velocity_and_animation(component_t *component)
static void player_system_set_velocity(player_system_data_t *system_data)
{
player_system_data_t *system_data = component->component_data.player_system_data;
transform_component_data_t *transform_component_data = system_data->transform_component_data;
sprite_component_data_t *sprite_component_data = system_data->sprite_component_data;
animation_system_data_t *animation_system_data = system_data->animation_system_data;
transform_component_data->velocity.x =
(float)((system_data->state & RUNNING_RIGHT) >> 3) - (float)((system_data->state & RUNNING_LEFT) >> 2);
transform_component_data->velocity.y =
(float)((system_data->state & RUNNING_DOWN) >> 1) - (float)(system_data->state & RUNNING_UP);
if(system_data->state & RUNNING_LEFT) sprite_component_data->flip = true;
if(system_data->state & RUNNING_RIGHT) sprite_component_data->flip = false;
if(is_not_zero(transform_component_data->velocity.x) && is_not_zero(transform_component_data->velocity.y))
{
transform_component_data->velocity.x *= 0.707106781186548f;
transform_component_data->velocity.y *= 0.707106781186548f;
}
}
// Only for this file
static void player_system_set_animation(player_system_data_t *system_data)
{
sprite_component_data_t *sprite_component_data = system_data->sprite_component_data;
animation_system_data_t *animation_system_data = system_data->animation_system_data;
if(system_data->state & RUNNING_LEFT) sprite_component_data->flip = true;
if(system_data->state & RUNNING_RIGHT) sprite_component_data->flip = false;
if((system_data->state & RUNNING) && !(system_data->last_state & RUNNING))
{
animation_system_data->frame_delay_ms = 200;
animation_system_data->frame_delay_ms = PLAYER_DEFAULT_RUN_ANIMATION_SPEED;
animation_system_change_animation(animation_system_data, "player_run_sheet", 6);
}
else if(!(system_data->state & RUNNING) && (system_data->last_state & RUNNING))
{
animation_system_data->actual_frame_nb = 0;
animation_system_data->frame_delay_ms = 200;
animation_system_data->frame_delay_ms = PLAYER_DEFAULT_IDLE_ANIMATION_SPEED;
animation_system_change_animation(animation_system_data, "player_idle_sheet", 4);
}
}
void player_system_update(component_t *component)
{
player_system_get_inputs(component);
player_system_set_state_velocity_and_animation(component);
player_system_data_t *system_data = component->component_data.player_system_data;
player_system_get_inputs(system_data);
player_system_set_velocity(system_data);
player_system_set_animation(system_data);
}
void player_system_destroy(component_t *component)

View File

@ -4,6 +4,10 @@
#include "ecs.h"
#include "transform_component.h"
#define PLAYER_DEFAULT_SPEED 80.0f // px / s
#define PLAYER_DEFAULT_IDLE_ANIMATION_SPEED 250.0f // ms / frame
#define PLAYER_DEFAULT_RUN_ANIMATION_SPEED 160.0f // ms / frame
typedef enum player_state_t {
IDLE = 0x00, // 00000000
RUNNING_UP = 0x01, // 00000001

View File

@ -10,19 +10,18 @@ void game_init(void)
entity_manager_init(&game.entity_manager);
entity_t *player = entity_manager_add_entity(&game.entity_manager, "player");
rect_t player_bounds = {10.0f, 10.0f, 32.0f, 32.0f};
float player_speed = 50.0f;
add_component(player, create_component(TRANSFORM_COMPONENT), player_bounds, player_speed);
add_component(player, create_component(SPRITE_COMPONENT), "player_idle_sheet");
add_component(player, create_component(ANIMATION_SYSTEM), 4, 0, 200.0f, true, true, false);
add_component(player, create_component(PLAYER_SYSTEM));
game.last_clock_state = clock();
game.is_running = true;
entity_t *player = entity_manager_add_entity(&game.entity_manager, "player");
rect_t player_bounds = {10.0f, 10.0f, 32.0f, 32.0f};
add_component(player, create_component(TRANSFORM_COMPONENT), player_bounds, PLAYER_DEFAULT_SPEED);
add_component(player, create_component(SPRITE_COMPONENT), "player_idle_sheet");
add_component(player, create_component(ANIMATION_SYSTEM), 4, 0, PLAYER_DEFAULT_IDLE_ANIMATION_SPEED, true, true, false);
add_component(player, create_component(PLAYER_SYSTEM));
}
void game_handle_event(void)