- alterang

This commit is contained in:
Christoph Oelckers 2020-10-22 16:40:48 +02:00
parent 31e5023004
commit 85ea1df76a
5 changed files with 29 additions and 23 deletions

View file

@ -5198,38 +5198,39 @@ int furthestcanseepoint(DDukeActor *actor, DDukeActor* tosee, int* dax, int* day
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void alterang(int a, int g_i, int g_p) void alterang(int ang, DDukeActor* actor, int g_p)
{ {
auto g_sp = &actor->s;
short aang, angdif, goalang, j; short aang, angdif, goalang, j;
int ticselapsed; int ticselapsed;
int* g_t = hittype[g_i].temp_data; int* t = actor->temp_data;
auto* g_sp = &sprite[g_i];
auto moveptr = &ScriptCode[g_t[1]]; auto moveptr = &ScriptCode[t[1]];
ticselapsed = (g_t[0]) & 31; ticselapsed = (t[0]) & 31;
aang = g_sp->ang; aang = g_sp->ang;
g_sp->xvel += (*moveptr - g_sp->xvel) / 5; g_sp->xvel += (*moveptr - g_sp->xvel) / 5;
if (g_sp->zvel < 648) g_sp->zvel += ((*(moveptr + 1) << 4) - g_sp->zvel) / 5; if (g_sp->zvel < 648) g_sp->zvel += ((*(moveptr + 1) << 4) - g_sp->zvel) / 5;
if (isRRRA() && (a & windang)) if (isRRRA() && (ang & windang))
g_sp->ang = WindDir; g_sp->ang = WindDir;
else if (a & seekplayer) else if (ang & seekplayer)
{ {
j = !isRR()? ps[g_p].holoduke_on->GetIndex() : -1; auto holoduke = !isRR()? ps[g_p].holoduke_on : nullptr;
// NOTE: looks like 'owner' is set to target sprite ID... // NOTE: looks like 'owner' is set to target sprite ID...
if (j >= 0 && cansee(sprite[j].x, sprite[j].y, sprite[j].z, sprite[j].sectnum, g_sp->x, g_sp->y, g_sp->z, g_sp->sectnum)) if (holoduke && cansee(holoduke->s.x, holoduke->s.y, holoduke->s.z, holoduke->s.sectnum, g_sp->x, g_sp->y, g_sp->z, g_sp->sectnum))
g_sp->owner = j; actor->SetOwner(holoduke);
else g_sp->owner = ps[g_p].i; else actor->SetOwner(ps[g_p].GetActor());
if (sprite[g_sp->owner].picnum == TILE_APLAYER) auto Owner = actor->GetOwner();
goalang = getangle(hittype[g_i].lastvx - g_sp->x, hittype[g_i].lastvy - g_sp->y); if (Owner->s.picnum == TILE_APLAYER)
goalang = getangle(actor->lastvx - g_sp->x, actor->lastvy - g_sp->y);
else else
goalang = getangle(sprite[g_sp->owner].x - g_sp->x, sprite[g_sp->owner].y - g_sp->y); goalang = getangle(Owner->s.x - g_sp->x, Owner->s.y - g_sp->y);
if (g_sp->xvel && g_sp->picnum != TILE_DRONE) if (g_sp->xvel && g_sp->picnum != TILE_DRONE)
{ {
@ -5241,7 +5242,7 @@ void alterang(int a, int g_i, int g_p)
{ {
j = 128 - (krand() & 256); j = 128 - (krand() & 256);
g_sp->ang += j; g_sp->ang += j;
if (hits(g_i) < 844) if (hits(actor) < 844)
g_sp->ang -= j; g_sp->ang -= j;
} }
} }
@ -5257,16 +5258,16 @@ void alterang(int a, int g_i, int g_p)
if (ticselapsed < 1) if (ticselapsed < 1)
{ {
j = 2; j = 2;
if (a & furthestdir) if (ang & furthestdir)
{ {
goalang = furthestangle(&hittype[g_i], j); goalang = furthestangle(actor, j);
g_sp->ang = goalang; g_sp->ang = goalang;
g_sp->owner = ps[g_p].i; actor->SetOwner(ps[g_p].GetActor());
} }
if (a & fleeenemy) if (ang & fleeenemy)
{ {
goalang = furthestangle(&hittype[g_i], j); goalang = furthestangle(actor, j);
g_sp->ang = goalang; // += angdif; // = getincangle(aang,goalang)>>1; g_sp->ang = goalang; // += angdif; // = getincangle(aang,goalang)>>1;
} }
} }

View file

@ -3918,7 +3918,7 @@ void move_d(int g_i, int g_p, int g_x)
dodge(&hittype[g_i]); dodge(&hittype[g_i]);
if (g_sp->picnum != APLAYER) if (g_sp->picnum != APLAYER)
alterang(a, g_i, g_p); alterang(a, &hittype[g_i], g_p);
if (g_sp->xvel > -6 && g_sp->xvel < 6) g_sp->xvel = 0; if (g_sp->xvel > -6 && g_sp->xvel < 6) g_sp->xvel = 0;

View file

@ -3908,7 +3908,7 @@ void move_r(int g_i, int g_p, int g_x)
dodge(&hittype[g_i]); dodge(&hittype[g_i]);
if (g_sp->picnum != APLAYER) if (g_sp->picnum != APLAYER)
alterang(a, g_i, g_p); alterang(a, &hittype[g_i], g_p);
if (g_sp->xvel > -6 && g_sp->xvel < 6) g_sp->xvel = 0; if (g_sp->xvel > -6 && g_sp->xvel < 6) g_sp->xvel = 0;

View file

@ -289,4 +289,9 @@ inline void callsound(int sect, DDukeActor* a)
callsound(sect, a->GetIndex()); callsound(sect, a->GetIndex());
} }
inline int hits(DDukeActor* snum)
{
return hits(snum->GetIndex());
}
END_DUKE_NS END_DUKE_NS

View file

@ -97,7 +97,7 @@ void handle_se130(DDukeActor* i, int countmax, int EXPLOSION2);
void respawn_rrra(DDukeActor* oldact, DDukeActor* newact); void respawn_rrra(DDukeActor* oldact, DDukeActor* newact);
int dodge(DDukeActor*); int dodge(DDukeActor*);
void alterang(int a, int g_i, int g_p); void alterang(int ang, DDukeActor* actor, int g_p);
void fall_common(int g_i, int g_p, int JIBS6, int DRONE, int BLOODPOOL, int SHOTSPARK1, int squished, int thud, int(*fallspecial)(int, int), void (*falladjustz)(spritetype*)); void fall_common(int g_i, int g_p, int JIBS6, int DRONE, int BLOODPOOL, int SHOTSPARK1, int squished, int thud, int(*fallspecial)(int, int), void (*falladjustz)(spritetype*));
void checkavailweapon(struct player_struct* p); void checkavailweapon(struct player_struct* p);
void deletesprite(DDukeActor* num); void deletesprite(DDukeActor* num);