Synchronize sleeping animations

Sleeping animations were desynchronized previously. Now remote goes to
sitting, and to laying down, at the right times. A snoring remote player
will no longer lower your music, and will no longer get stuck snoring
when they wake up.

Fixes #11 reported by somario360
This commit is contained in:
MysterD 2020-09-01 23:00:12 -07:00
parent c88ff19190
commit f62f80a228
2 changed files with 28 additions and 13 deletions

View file

@ -264,16 +264,18 @@ s32 act_start_sleeping(struct MarioState *m) {
s32 act_sleeping(struct MarioState *m) {
s32 sp24;
if (m->input & INPUT_UNKNOWN_A41F /* ? */) {
return set_mario_action(m, ACT_WAKING_UP, m->actionState);
}
if (m->playerIndex == 0) {
if (m->input & INPUT_UNKNOWN_A41F /* ? */) {
return set_mario_action(m, ACT_WAKING_UP, m->actionState);
}
if (m->quicksandDepth > 30.0f) {
return set_mario_action(m, ACT_WAKING_UP, m->actionState);
}
if (m->quicksandDepth > 30.0f) {
return set_mario_action(m, ACT_WAKING_UP, m->actionState);
}
if (m->pos[1] - find_floor_height_relative_polar(m, -0x8000, 60.0f) > 24.0f) {
return set_mario_action(m, ACT_WAKING_UP, m->actionState);
if (m->pos[1] - find_floor_height_relative_polar(m, -0x8000, 60.0f) > 24.0f) {
return set_mario_action(m, ACT_WAKING_UP, m->actionState);
}
}
m->marioBodyState->eyeState = MARIO_EYES_CLOSED;
@ -282,7 +284,7 @@ s32 act_sleeping(struct MarioState *m) {
case 0: {
sp24 = set_mario_animation(m, MARIO_ANIM_SLEEP_IDLE);
if (sp24 == -1 && !m->actionTimer) {
if (m->playerIndex == 0 && sp24 == -1 && !m->actionTimer) {
lower_background_noise(2);
}
@ -294,7 +296,7 @@ s32 act_sleeping(struct MarioState *m) {
play_sound(SOUND_MARIO_SNORING2, m->marioObj->header.gfx.cameraToObject);
}
if (is_anim_at_end(m)) {
if (m->playerIndex == 0 && is_anim_at_end(m)) {
m->actionTimer++;
if (m->actionTimer > 45) {
m->actionState++;
@ -307,7 +309,7 @@ s32 act_sleeping(struct MarioState *m) {
play_mario_heavy_landing_sound(m, SOUND_ACTION_TERRAIN_BODY_HIT_GROUND);
}
if (is_anim_at_end(m)) {
if (m->playerIndex == 0 && is_anim_at_end(m)) {
m->actionState++;
}
break;
@ -338,7 +340,9 @@ s32 act_waking_up(struct MarioState *m) {
#ifndef VERSION_JP
func_803205E8(SOUND_MARIO_SNORING3, m->marioObj->header.gfx.cameraToObject);
#endif
raise_background_noise(2);
if (m->playerIndex == 0) {
raise_background_noise(2);
}
}
if (m->input & INPUT_UNKNOWN_10) {

View file

@ -75,7 +75,18 @@ void network_receive_player(struct Packet* p) {
}
// restore action state, needed for jump kicking
gMarioStates[1].actionState = oldActionState;
if (gMarioStates[1].action == ACT_JUMP_KICK) {
gMarioStates[1].actionState = oldActionState;
}
// mute snoring
if (oldAction == ACT_SLEEPING && gMarioStates[1].action != ACT_SLEEPING) {
func_803205E8(SOUND_MARIO_SNORING1, gMarioStates[1].marioObj->header.gfx.cameraToObject);
func_803205E8(SOUND_MARIO_SNORING2, gMarioStates[1].marioObj->header.gfx.cameraToObject);
#ifndef VERSION_JP
func_803205E8(SOUND_MARIO_SNORING3, gMarioStates[1].marioObj->header.gfx.cameraToObject);
#endif
}
}
void network_update_player(void) {