mirror of
https://git.do.srb2.org/STJr/SRB2.git
synced 2025-04-05 01:11:39 +00:00
Switch Ideya orbiting state to centered offset states when orbiting around Drone
This commit is contained in:
parent
b97037f644
commit
8154578fb6
1 changed files with 18 additions and 0 deletions
|
@ -799,10 +799,18 @@ void P_TouchSpecialThing(mobj_t *special, mobj_t *toucher, boolean heightcheck)
|
|||
{
|
||||
if (toucher->tracer) // Move the ideya over to the drone!
|
||||
{
|
||||
statenum_t currentstate = toucher->tracer->state - states;
|
||||
mobj_t *hnext = special->hnext;
|
||||
P_SetTarget(&special->hnext, toucher->tracer);
|
||||
P_SetTarget(&special->hnext->hnext, hnext); // Buffalo buffalo Buffalo buffalo buffalo buffalo Buffalo buffalo.
|
||||
P_SetTarget(&special->hnext->target, special);
|
||||
|
||||
// switch to centered orbit states
|
||||
if (currentstate >= mobjinfo[MT_GOTEMERALD].missilestate
|
||||
&& currentstate <= mobjinfo[MT_GOTEMERALD].missilestate + 4)
|
||||
P_SetMobjState(toucher->tracer,
|
||||
mobjinfo[MT_GOTEMERALD].raisestate + currentstate - mobjinfo[MT_GOTEMERALD].missilestate);
|
||||
|
||||
P_SetTarget(&toucher->tracer, NULL);
|
||||
if (hnext)
|
||||
{
|
||||
|
@ -814,8 +822,18 @@ void P_TouchSpecialThing(mobj_t *special, mobj_t *toucher, boolean heightcheck)
|
|||
if (player->exiting) // ...then move it back?
|
||||
{
|
||||
mobj_t *hnext = special;
|
||||
statenum_t currentstate;
|
||||
while ((hnext = hnext->hnext))
|
||||
{
|
||||
P_SetTarget(&hnext->target, toucher);
|
||||
currentstate = hnext->state - states;
|
||||
|
||||
// switch to regular orbit states
|
||||
if (currentstate >= mobjinfo[MT_GOTEMERALD].raisestate
|
||||
&& currentstate <= mobjinfo[MT_GOTEMERALD].raisestate + 4)
|
||||
P_SetMobjState(hnext,
|
||||
mobjinfo[MT_GOTEMERALD].missilestate + currentstate - mobjinfo[MT_GOTEMERALD].raisestate);
|
||||
}
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue