From 43b790c26f83d0b4cc58bad1161beda7a060ca2f Mon Sep 17 00:00:00 2001 From: mazmazz Date: Sun, 12 Aug 2018 01:07:26 -0400 Subject: [PATCH] A_OrbitNights make actor scale to target * Added `donotrescale` input to disable this behavior * Reverted previous commit changes for scaling Ideya because unneeded --- src/p_enemy.c | 9 +++++++-- src/p_inter.c | 2 -- src/p_mobj.c | 9 +-------- 3 files changed, 8 insertions(+), 12 deletions(-) diff --git a/src/p_enemy.c b/src/p_enemy.c index 68d01c163..06223eb7a 100644 --- a/src/p_enemy.c +++ b/src/p_enemy.c @@ -8544,12 +8544,14 @@ void A_ToggleFlameJet(mobj_t* actor) // var1 = Angle adjustment (aka orbit speed) // var2: // Lower 16 bits: height offset -// Upper 16 bits: set if object is Nightopian Helper +// Bits 17-20: set if object is Nightopian Helper +// Bits 21-24: set to not sync scale to player // void A_OrbitNights(mobj_t* actor) { INT32 ofs = (var2 & 0xFFFF); - boolean ishelper = var2 >> 16; + boolean ishelper = (var2 & 0xF0000); + boolean donotrescale = (var2 & 0xF00000); #ifdef HAVE_BLUA if (LUA_CallAction("A_OrbitNights", actor)) return; @@ -8594,6 +8596,9 @@ void A_OrbitNights(mobj_t* actor) else actor->flags2 &= ~MF2_DONTDRAW; } + + if (!donotrescale && actor->destscale != actor->target->destscale) + actor->destscale = actor->target->destscale; } } diff --git a/src/p_inter.c b/src/p_inter.c index e05f18364..66c6bd852 100644 --- a/src/p_inter.c +++ b/src/p_inter.c @@ -807,8 +807,6 @@ void P_TouchSpecialThing(mobj_t *special, mobj_t *toucher, boolean heightcheck) P_SetTarget(&orbittarget->hnext->target, orbittarget); // goalpost P_SetTarget(&toucher->tracer, NULL); - orbittarget->hnext->destscale = orbittarget->destscale; - if (hnext) { orbittarget->hnext->extravalue1 = (angle_t)(hnext->extravalue1 - 72*ANG1); diff --git a/src/p_mobj.c b/src/p_mobj.c index 2450743b7..3aa68e521 100644 --- a/src/p_mobj.c +++ b/src/p_mobj.c @@ -7883,14 +7883,7 @@ void P_MobjThinker(mobj_t *mobj) || flipchanged || goalpost->threshold != (mobj->flags & (MF_SLIDEME | MF_GRENADEBOUNCE))) { - if (goalpost->destscale != mobj->destscale) - { - goalpost->destscale = sparkle->destscale = droneman->destscale = mobj->destscale; - // get the orbiting ideyas and scale them too - mobj_t *hnext = goalpost; - while ((hnext = hnext->hnext)) - hnext->destscale = mobj->destscale; - } + goalpost->destscale = sparkle->destscale = droneman->destscale = mobj->destscale; // straight copy-pasta from P_SpawnMapThing, case MT_NIGHTSDRONE if (!flip)