Compare commits

...

2 Commits

Author SHA1 Message Date
En Yi 707ab692a1 Allow transition to ladder only on climbing up 2025-04-15 21:34:01 +08:00
En Yi b8fc099ced Remove 1frame jump after crate jump 2025-04-15 21:23:46 +08:00
1 changed files with 31 additions and 26 deletions

View File

@ -343,32 +343,32 @@ void player_movement_input_system(Scene_t* scene)
p_player->position.y--;
}
}
else if (p_pstate->player_dir.y > 0)
{
unsigned int tile_idx;
//else if (p_pstate->player_dir.y > 0)
//{
// unsigned int tile_idx;
if (p_mstate->ground_state & 1)
{
tile_idx = get_tile_idx(
p_player->position.x + p_bbox->half_size.x,
p_player->position.y + p_bbox->size.y,
data->tilemap
);
}
else
{
tile_idx = get_tile_idx(
p_player->position.x + p_bbox->half_size.x,
p_player->position.y + p_bbox->half_size.y,
data->tilemap
);
}
if (tile_idx < tilemap.n_tiles && tilemap.tiles[tile_idx].tile_type == LADDER)
{
p_pstate->ladder_state = true;
p_player->position.y++;
}
}
// if (p_mstate->ground_state & 1)
// {
// tile_idx = get_tile_idx(
// p_player->position.x + p_bbox->half_size.x,
// p_player->position.y + p_bbox->size.y,
// data->tilemap
// );
// }
// else
// {
// tile_idx = get_tile_idx(
// p_player->position.x + p_bbox->half_size.x,
// p_player->position.y + p_bbox->half_size.y,
// data->tilemap
// );
// }
// if (tile_idx < tilemap.n_tiles && tilemap.tiles[tile_idx].tile_type == LADDER)
// {
// p_pstate->ladder_state = true;
// p_player->position.y++;
// }
//}
}
}
else
@ -1408,6 +1408,10 @@ void player_ground_air_transition_system(Scene_t* scene)
// Handle Ground<->Air Transition
bool in_water = (p_mstate->water_state & 1);
bool jump_recover_cond = (p_mstate->ground_state & 1 || in_water || p_pstate->ladder_state);
// There is this odd state that can happen, so deal with it
if(!p_cjump->jump_released && !p_pstate->jump_pressed) p_cjump->jump_released = true;
// Landing or in water
if (p_mstate->water_state == 0b10 || p_mstate->ground_state == 0b10)
{
@ -1418,7 +1422,6 @@ void player_ground_air_transition_system(Scene_t* scene)
// Recover jumps
p_cjump->jumps = p_cjump->max_jumps;
p_cjump->jumped = false;
if(!p_cjump->jump_released && !p_pstate->jump_pressed) p_cjump->jump_released = true;
p_cjump->short_hop = false;
p_cjump->jump_ready = true;
p_cjump->coyote_timer = 0;
@ -1714,6 +1717,8 @@ void hitbox_update_system(Scene_t* scene)
// Don't allow the usual jump interaction with crate jump
p_cjump->short_hop = true;
p_cjump->jumped = false;
p_cjump->jump_released = false;
p_pstate->jump_pressed = true;
p_ctransform->velocity.y = -400;
if (p_pstate->jump_pressed)