Compare commits
2 Commits
bc0f7617d4
...
707ab692a1
Author | SHA1 | Date |
---|---|---|
|
707ab692a1 | |
|
b8fc099ced |
|
@ -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)
|
||||
|
|
Loading…
Reference in New Issue