mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-17 21:10:53 +00:00
- alterang
This commit is contained in:
parent
31e5023004
commit
85ea1df76a
5 changed files with 29 additions and 23 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue