mirror of
https://github.com/coop-deluxe/sm64coopdx.git
synced 2025-01-03 14:11:10 +00:00
Prevent bubble popping on dying players, prevent collision on recently unbubbled
This commit is contained in:
parent
f013f0b10b
commit
7136a06dba
2 changed files with 39 additions and 4 deletions
|
@ -1306,6 +1306,10 @@ u32 interact_cannon_base(struct MarioState *m, UNUSED u32 interactType, struct O
|
|||
|
||||
static u8 resolve_player_collision(struct MarioState* m, struct MarioState* m2) {
|
||||
if (!m || !m2) { return FALSE; }
|
||||
if (!m->marioObj || !m2->marioObj) { return FALSE; }
|
||||
if (m->invincTimer > 0 || m2->invincTimer > 0) { return FALSE; }
|
||||
if (m->action == ACT_DEATH_EXIT_LAND || m2->action == ACT_DEATH_EXIT_LAND) { return FALSE; }
|
||||
|
||||
// move player outside of other player
|
||||
f32 extentY = m->marioObj->hitboxHeight;
|
||||
f32 radius = m->marioObj->hitboxRadius * 2.0f;
|
||||
|
|
|
@ -968,12 +968,42 @@ static void bubbled_offset_visual(struct MarioState* m) {
|
|||
m->marioObj->header.gfx.pos[1] -= upOffset;
|
||||
}
|
||||
|
||||
static struct MarioState* nearest_antibubble_mario_state_to_object(struct Object *obj) {
|
||||
if (!obj) { return NULL; }
|
||||
struct MarioState* nearest = NULL;
|
||||
f32 nearestDist = 0;
|
||||
for (s32 i = 0; i < MAX_PLAYERS; i++) {
|
||||
struct MarioState* m = &gMarioStates[i];
|
||||
if (!m->marioObj) { continue; }
|
||||
if (m->marioObj == obj) { continue; }
|
||||
if (!m->visibleToEnemies) { continue; }
|
||||
if (!is_player_active(m)) { continue; }
|
||||
|
||||
switch (m->action) {
|
||||
case ACT_WATER_DEATH:
|
||||
case ACT_STANDING_DEATH:
|
||||
case ACT_QUICKSAND_DEATH:
|
||||
case ACT_DEATH_ON_STOMACH:
|
||||
case ACT_DEATH_ON_BACK:
|
||||
continue;
|
||||
}
|
||||
|
||||
float dist = dist_between_objects(obj, m->marioObj);
|
||||
if (nearest == NULL || dist < nearestDist) {
|
||||
nearest = m;
|
||||
nearestDist = dist;
|
||||
}
|
||||
}
|
||||
|
||||
return nearest;
|
||||
}
|
||||
|
||||
s32 act_bubbled(struct MarioState* m) {
|
||||
if (!m) { return 0; }
|
||||
if (m->playerIndex == 0 && m->area->camera->mode == CAMERA_MODE_WATER_SURFACE) {
|
||||
set_camera_mode(m->area->camera, CAMERA_MODE_FREE_ROAM, 1);
|
||||
}
|
||||
struct MarioState* targetMarioState = nearest_mario_state_to_object(m->marioObj);
|
||||
struct MarioState* targetMarioState = nearest_antibubble_mario_state_to_object(m->marioObj);
|
||||
if (targetMarioState == NULL) {
|
||||
targetMarioState = &gMarioStates[0];
|
||||
}
|
||||
|
@ -1021,9 +1051,9 @@ s32 act_bubbled(struct MarioState* m) {
|
|||
f32 oldYaw = m->faceAngle[1];
|
||||
m->faceAngle[0] = 0;
|
||||
m->faceAngle[1] = m->intendedYaw;
|
||||
m->forwardVel = m->intendedMag * 1.5f;
|
||||
if (m->input & INPUT_A_DOWN) { m->vel[1] += 5.0f; }
|
||||
if (m->input & INPUT_Z_DOWN) { m->vel[1] -= 5.0f; }
|
||||
m->forwardVel = m->intendedMag * 1.6f;
|
||||
if (m->input & INPUT_A_DOWN) { m->vel[1] += 5.5f; }
|
||||
if (m->input & INPUT_Z_DOWN) { m->vel[1] -= 5.5f; }
|
||||
|
||||
// set and smooth velocity
|
||||
Vec3f oldVel = { m->vel[0], m->vel[1], m->vel[2] };
|
||||
|
@ -1087,6 +1117,7 @@ s32 act_bubbled(struct MarioState* m) {
|
|||
mario_set_forward_vel(m, 0.0f);
|
||||
m->vel[1] = 0.0f;
|
||||
m->marioObj->header.gfx.node.flags &= ~GRAPH_RENDER_INVISIBLE;
|
||||
m->invincTimer = 30 * 3;
|
||||
if (m->playerIndex == 0) {
|
||||
soft_reset_camera(m->area->camera);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue