mirror of
https://github.com/ZDoom/Raze.git
synced 2025-01-18 14:41:55 +00:00
- more repeats replaced by SetScale.
This commit is contained in:
parent
b004de9fb0
commit
2589e7030c
4 changed files with 34 additions and 40 deletions
|
@ -444,20 +444,20 @@ DEFINE_PROPERTY(clipdist, I, CoreActor)
|
|||
//==========================================================================
|
||||
//
|
||||
//==========================================================================
|
||||
DEFINE_PROPERTY(xrepeat, I, CoreActor)
|
||||
DEFINE_PROPERTY(scalex, I, CoreActor)
|
||||
{
|
||||
PROP_INT_PARM(i, 0);
|
||||
bag.Info->ActorInfo()->defsprite.xrepeat = i;
|
||||
bag.Info->ActorInfo()->defsprite.xrepeat = i / REPEAT_SCALE;
|
||||
bag.Info->ActorInfo()->DefaultFlags |= DEFF_XREPEAT;
|
||||
}
|
||||
|
||||
//==========================================================================
|
||||
//
|
||||
//==========================================================================
|
||||
DEFINE_PROPERTY(yrepeat, I, CoreActor)
|
||||
DEFINE_PROPERTY(scaley, I, CoreActor)
|
||||
{
|
||||
PROP_INT_PARM(i, 0);
|
||||
bag.Info->ActorInfo()->defsprite.yrepeat = i;
|
||||
bag.Info->ActorInfo()->defsprite.yrepeat = i / REPEAT_SCALE;
|
||||
bag.Info->ActorInfo()->DefaultFlags |= DEFF_YREPEAT;
|
||||
}
|
||||
|
||||
|
|
|
@ -337,7 +337,7 @@ static void ThrowThing(DBloodActor* actor, bool impact)
|
|||
|
||||
switch (curWeapon) {
|
||||
case kThingNapalmBall:
|
||||
spawned->spr.xrepeat = spawned->spr.yrepeat = 24;
|
||||
spawned->spr.SetScale(0.375, 0.375);
|
||||
spawned->xspr.data4 = 3 + gGameOptions.nDifficulty;
|
||||
impact = true;
|
||||
break;
|
||||
|
@ -1405,9 +1405,8 @@ void removeLeech(DBloodActor* actLeech, bool delSprite)
|
|||
{
|
||||
effectactor->spr.cstat = CSTAT_SPRITE_ALIGNMENT_FACING;
|
||||
effectactor->spr.pal = 6;
|
||||
int repeat = 64 + Random(50);
|
||||
effectactor->spr.xrepeat = repeat;
|
||||
effectactor->spr.yrepeat = repeat;
|
||||
double repeat = 1 + Random(50) * REPEAT_SCALE;
|
||||
effectactor->spr.SetScale(repeat, repeat);
|
||||
}
|
||||
|
||||
sfxPlay3DSoundCP(actLeech, 490, -1, 0, 60000);
|
||||
|
|
|
@ -110,6 +110,7 @@ static const WEAPONICON gWeaponIcon[] = {
|
|||
|
||||
static tspritetype* viewAddEffect(tspriteArray& tsprites, int nTSprite, VIEW_EFFECT nViewEffect)
|
||||
{
|
||||
double s;
|
||||
assert(nViewEffect >= 0 && nViewEffect < kViewEffectMax);
|
||||
auto pTSprite = tsprites.get(nTSprite);
|
||||
auto owneractor = static_cast<DBloodActor*>(pTSprite->ownerActor);
|
||||
|
@ -178,7 +179,7 @@ static tspritetype* viewAddEffect(tspriteArray& tsprites, int nTSprite, VIEW_EFF
|
|||
pNSprite->pal = 0;
|
||||
pNSprite->pos.Z = top;
|
||||
if (nViewEffect == kViewEffectFlag)
|
||||
pNSprite->xrepeat = pNSprite->yrepeat = 24;
|
||||
pNSprite->SetScale(0.375, 0.375);
|
||||
else
|
||||
pNSprite->SetScale(1, 1);
|
||||
pNSprite->picnum = 3558;
|
||||
|
@ -235,7 +236,7 @@ static tspritetype* viewAddEffect(tspriteArray& tsprites, int nTSprite, VIEW_EFF
|
|||
pNSprite->shade = 26;
|
||||
pNSprite->pal = 0;
|
||||
pNSprite->cstat |= CSTAT_SPRITE_TRANSLUCENT;
|
||||
pNSprite->xrepeat = pNSprite->yrepeat = 24;
|
||||
pNSprite->SetScale(0.375, 0.375);
|
||||
pNSprite->picnum = 626;
|
||||
break;
|
||||
}
|
||||
|
@ -287,7 +288,8 @@ static tspritetype* viewAddEffect(tspriteArray& tsprites, int nTSprite, VIEW_EFF
|
|||
pNSprite->pos.Z = pTSprite->pos.Z;
|
||||
pNSprite->picnum = 908;
|
||||
pNSprite->statnum = kStatDecoration;
|
||||
pNSprite->xrepeat = pNSprite->yrepeat = (tileWidth(pTSprite->picnum) * pTSprite->xrepeat) / 64;
|
||||
s = (tileWidth(pTSprite->picnum) * pTSprite->ScaleX()) / 64.;
|
||||
pNSprite->SetScale(s, s);
|
||||
break;
|
||||
}
|
||||
case kViewEffectSmokeHigh:
|
||||
|
@ -339,7 +341,8 @@ static tspritetype* viewAddEffect(tspriteArray& tsprites, int nTSprite, VIEW_EFF
|
|||
pNSprite->pos.Z = top;
|
||||
pNSprite->picnum = 2101;
|
||||
pNSprite->shade = -128;
|
||||
pNSprite->xrepeat = pNSprite->yrepeat = (tileWidth(pTSprite->picnum) * pTSprite->xrepeat) / 32;
|
||||
s = (tileWidth(pTSprite->picnum) * pTSprite->ScaleX()) / 32.;
|
||||
pNSprite->SetScale(s, s);
|
||||
break;
|
||||
}
|
||||
case kViewEffectTorchLow:
|
||||
|
@ -353,7 +356,8 @@ static tspritetype* viewAddEffect(tspriteArray& tsprites, int nTSprite, VIEW_EFF
|
|||
pNSprite->pos.Z = bottom;
|
||||
pNSprite->picnum = 2101;
|
||||
pNSprite->shade = -128;
|
||||
pNSprite->xrepeat = pNSprite->yrepeat = (tileWidth(pTSprite->picnum) * pTSprite->xrepeat) / 32;
|
||||
s = (tileWidth(pTSprite->picnum) * pTSprite->ScaleX()) / 32.;
|
||||
pNSprite->SetScale(s, s);
|
||||
break;
|
||||
}
|
||||
case kViewEffectShadow:
|
||||
|
@ -438,7 +442,7 @@ static tspritetype* viewAddEffect(tspriteArray& tsprites, int nTSprite, VIEW_EFF
|
|||
uint8_t nShade = (uint8_t)clamp(pSector->floorz - pTSprite->pos.Z, 0., 255.);
|
||||
pNSprite->shade = nShade - 32;
|
||||
pNSprite->pal = 2;
|
||||
pNSprite->xrepeat = pNSprite->yrepeat = nShade;
|
||||
pNSprite->SetScale(nShade * REPEAT_SCALE, nShade * REPEAT_SCALE);
|
||||
pNSprite->cstat |= CSTAT_SPRITE_ONE_SIDE | CSTAT_SPRITE_ALIGNMENT_FLOOR | CSTAT_SPRITE_TRANSLUCENT;
|
||||
pNSprite->angle = pTSprite->angle;
|
||||
pNSprite->ownerActor = pTSprite->ownerActor;
|
||||
|
|
|
@ -321,8 +321,7 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
break;
|
||||
}
|
||||
|
||||
act->spr.xrepeat = 4;
|
||||
act->spr.yrepeat = 5;
|
||||
act->spr.SetScale(0.0625, 0.078125);
|
||||
|
||||
act->SetOwner(act);
|
||||
ud.bomb_tag = (ud.bomb_tag + 1) & 32767;
|
||||
|
@ -517,7 +516,7 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
|
||||
if (act->spr.picnum == RESPAWNMARKERRED)
|
||||
{
|
||||
act->spr.xrepeat = act->spr.yrepeat = 24;
|
||||
act->spr.SetScale(0.375, 0.375);
|
||||
if (actj) act->spr.pos.Z = actj->floorz; // -(1<<4);
|
||||
}
|
||||
else
|
||||
|
@ -537,7 +536,7 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
case SPOTLITE:
|
||||
break;
|
||||
case BULLETHOLE:
|
||||
act->spr.xrepeat = act->spr.yrepeat = 3;
|
||||
act->spr.SetScale(0.046875, 0.046875);
|
||||
act->spr.cstat = CSTAT_SPRITE_ALIGNMENT_WALL | randomFlip();
|
||||
insertspriteq(act);
|
||||
[[fallthrough]];
|
||||
|
@ -548,7 +547,7 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
{
|
||||
act->temp_data[0] = krand() & 2047;
|
||||
act->spr.cstat = randomFlip();
|
||||
act->spr.xrepeat = act->spr.yrepeat = 8;
|
||||
act->spr.SetScale(0.125, 0.125);
|
||||
act->spr.angle = randomAngle();
|
||||
}
|
||||
ChangeActorStat(act, STAT_MISC);
|
||||
|
@ -614,13 +613,11 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
else if (act->spr.picnum == SMALLSMOKE || act->spr.picnum == ONFIRE)
|
||||
{
|
||||
// 64 "money"
|
||||
act->spr.xrepeat = 24;
|
||||
act->spr.yrepeat = 24;
|
||||
act->spr.SetScale(0.375, 0.375);
|
||||
}
|
||||
else if (act->spr.picnum == BURNING || act->spr.picnum == BURNING2)
|
||||
{
|
||||
act->spr.xrepeat = 4;
|
||||
act->spr.yrepeat = 4;
|
||||
act->spr.SetScale(0.0625, 0.0625);
|
||||
}
|
||||
|
||||
if (actj)
|
||||
|
@ -673,7 +670,7 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
{
|
||||
if (actj)
|
||||
act->spr.angle = actj->spr.angle;
|
||||
act->spr.xrepeat = act->spr.yrepeat = 4;
|
||||
act->spr.SetScale(0.0625, 0.0625);
|
||||
}
|
||||
else act->spr.SetScale(0.5, 0.5);
|
||||
|
||||
|
@ -695,16 +692,13 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
|
||||
case WATERDRIPSPLASH:
|
||||
|
||||
act->spr.xrepeat = 24;
|
||||
act->spr.yrepeat = 24;
|
||||
|
||||
|
||||
ChangeActorStat(act, 6);
|
||||
act->spr.SetScale(0.375, 0.375);
|
||||
ChangeActorStat(act, STAT_STANDABLE);
|
||||
break;
|
||||
|
||||
case PLUG:
|
||||
act->spr.lotag = 9999;
|
||||
ChangeActorStat(act, 6);
|
||||
ChangeActorStat(act, STAT_STANDABLE);
|
||||
break;
|
||||
case TOUCHPLATE:
|
||||
act->temp_pos.Z = sectp->floorz;
|
||||
|
@ -829,8 +823,7 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
}
|
||||
else
|
||||
{
|
||||
act->spr.xrepeat = 80;
|
||||
act->spr.yrepeat = 80;
|
||||
act->spr.SetScale(1.25, 1.25);
|
||||
act->clipdist = 41;
|
||||
}
|
||||
}
|
||||
|
@ -843,8 +836,7 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
}
|
||||
else
|
||||
{
|
||||
act->spr.xrepeat = 60;
|
||||
act->spr.yrepeat = 60;
|
||||
act->spr.SetScale(0.9375, 0.9375);
|
||||
act->clipdist = 10;
|
||||
}
|
||||
}
|
||||
|
@ -926,10 +918,9 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
|
||||
getglobalz(act);
|
||||
|
||||
int j = int((act->floorz - act->ceilingz) * 0.5);
|
||||
double j = ((act->floorz - act->ceilingz) / 128.);
|
||||
|
||||
act->spr.yrepeat = j;
|
||||
act->spr.xrepeat = 25 - (j >> 1);
|
||||
act->spr.SetScale(max(0., 0.390625 - j * 0.5), j);
|
||||
if (krand() & 4) act->spr.cstat |= CSTAT_SPRITE_XFLIP;
|
||||
|
||||
break;
|
||||
|
@ -938,7 +929,7 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
if (actj) act->SetOwner(actj);
|
||||
else act->SetOwner(act);
|
||||
|
||||
act->spr.xrepeat = act->spr.yrepeat = 9;
|
||||
act->spr.SetScale(0.140625, 0.140625);
|
||||
act->spr.yint = 4;
|
||||
[[fallthrough]];
|
||||
case REACTOR2:
|
||||
|
@ -1058,7 +1049,7 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
case BOUNCEMINE:
|
||||
act->SetOwner(act);
|
||||
act->spr.cstat |= CSTAT_SPRITE_BLOCK_ALL; //Make it hitable
|
||||
act->spr.xrepeat = act->spr.yrepeat = 24;
|
||||
act->spr.SetScale(0.375, 0.375);
|
||||
act->spr.shade = -127;
|
||||
act->spr.extra = gs.impact_damage << 2;
|
||||
ChangeActorStat(act, STAT_ZOMBIEACTOR);
|
||||
|
@ -1094,7 +1085,7 @@ DDukeActor* spawninit_d(DDukeActor* actj, DDukeActor* act, TArray<DDukeActor*>*
|
|||
{
|
||||
act->spr.angle = actj->spr.angle;
|
||||
act->spr.cstat = CSTAT_SPRITE_ALIGNMENT_WALL | CSTAT_SPRITE_YCENTER | CSTAT_SPRITE_TRANSLUCENT;
|
||||
act->spr.xrepeat = act->spr.yrepeat = 1;
|
||||
act->spr.SetScale(REPEAT_SCALE, REPEAT_SCALE);
|
||||
act->vel.X = -0.5;
|
||||
ssp(act, CLIPMASK0);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue