mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-19 05:40:48 +00:00
- interpolate p->hard_landing
for Duke 3D.
This commit is contained in:
parent
43ff42b330
commit
531df48d38
3 changed files with 20 additions and 16 deletions
|
@ -124,7 +124,7 @@ int animatefist(int gs, int snum)
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
int animateknee(int gs, int snum)
|
int animateknee(int gs, int snum, double hard_landing)
|
||||||
{
|
{
|
||||||
static const short knee_y[] = { 0,-8,-16,-32,-64,-84,-108,-108,-108,-72,-32,-8 };
|
static const short knee_y[] = { 0,-8,-16,-32,-64,-84,-108,-108,-108,-72,-32,-8 };
|
||||||
short pal;
|
short pal;
|
||||||
|
@ -134,7 +134,7 @@ int animateknee(int gs, int snum)
|
||||||
|
|
||||||
looking_arc = knee_y[ps[snum].knee_incs] + (fabs(ps[snum].q16look_ang / (double)(FRACUNIT)) / 9.);
|
looking_arc = knee_y[ps[snum].knee_incs] + (fabs(ps[snum].q16look_ang / (double)(FRACUNIT)) / 9.);
|
||||||
|
|
||||||
looking_arc -= (ps[snum].hard_landing << 3);
|
looking_arc -= hard_landing * 8.;
|
||||||
|
|
||||||
if (sprite[ps[snum].i].pal == 1)
|
if (sprite[ps[snum].i].pal == 1)
|
||||||
pal = 1;
|
pal = 1;
|
||||||
|
@ -156,7 +156,7 @@ int animateknee(int gs, int snum)
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
int animateknuckles(int gs, int snum)
|
int animateknuckles(int gs, int snum, double hard_landing)
|
||||||
{
|
{
|
||||||
static const short knuckle_frames[] = { 0,1,2,2,3,3,3,2,2,1,0 };
|
static const short knuckle_frames[] = { 0,1,2,2,3,3,3,2,2,1,0 };
|
||||||
short pal;
|
short pal;
|
||||||
|
@ -168,7 +168,7 @@ int animateknuckles(int gs, int snum)
|
||||||
|
|
||||||
looking_arc = fabs(ps[snum].q16look_ang / (double)(FRACUNIT)) / 9.;
|
looking_arc = fabs(ps[snum].q16look_ang / (double)(FRACUNIT)) / 9.;
|
||||||
|
|
||||||
looking_arc -= (ps[snum].hard_landing << 3);
|
looking_arc -= hard_landing * 8.;
|
||||||
|
|
||||||
if (sprite[ps[snum].i].pal == 1)
|
if (sprite[ps[snum].i].pal == 1)
|
||||||
pal = 1;
|
pal = 1;
|
||||||
|
@ -210,7 +210,7 @@ void displaymasks_d(int snum)
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
static int animatetip(int gs, int snum)
|
static int animatetip(int gs, int snum, double hard_landing)
|
||||||
{
|
{
|
||||||
int p;
|
int p;
|
||||||
double looking_arc;
|
double looking_arc;
|
||||||
|
@ -219,7 +219,7 @@ static int animatetip(int gs, int snum)
|
||||||
if (ps[snum].tipincs == 0) return 0;
|
if (ps[snum].tipincs == 0) return 0;
|
||||||
|
|
||||||
looking_arc = fabs(ps[snum].q16look_ang / (double)(FRACUNIT)) / 9.;
|
looking_arc = fabs(ps[snum].q16look_ang / (double)(FRACUNIT)) / 9.;
|
||||||
looking_arc -= (ps[snum].hard_landing << 3);
|
looking_arc -= hard_landing * 8.;
|
||||||
|
|
||||||
if (sprite[ps[snum].i].pal == 1)
|
if (sprite[ps[snum].i].pal == 1)
|
||||||
p = 1;
|
p = 1;
|
||||||
|
@ -243,7 +243,7 @@ static int animatetip(int gs, int snum)
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
int animateaccess(int gs,int snum)
|
int animateaccess(int gs,int snum,double hard_landing)
|
||||||
{
|
{
|
||||||
static const short access_y[] = {0,-8,-16,-32,-64,-84,-108,-108,-108,-108,-108,-108,-108,-108,-108,-108,-96,-72,-64,-32,-16};
|
static const short access_y[] = {0,-8,-16,-32,-64,-84,-108,-108,-108,-108,-108,-108,-108,-108,-108,-108,-96,-72,-64,-32,-16};
|
||||||
double looking_arc;
|
double looking_arc;
|
||||||
|
@ -252,7 +252,7 @@ int animateaccess(int gs,int snum)
|
||||||
if(ps[snum].access_incs == 0 || sprite[ps[snum].i].extra <= 0) return 0;
|
if(ps[snum].access_incs == 0 || sprite[ps[snum].i].extra <= 0) return 0;
|
||||||
|
|
||||||
looking_arc = access_y[ps[snum].access_incs] + (fabs(ps[snum].q16look_ang / (double)(FRACUNIT)) / 9.);
|
looking_arc = access_y[ps[snum].access_incs] + (fabs(ps[snum].q16look_ang / (double)(FRACUNIT)) / 9.);
|
||||||
looking_arc -= (ps[snum].hard_landing<<3);
|
looking_arc -= hard_landing * 8.;
|
||||||
|
|
||||||
if(ps[snum].access_spritenum >= 0)
|
if(ps[snum].access_spritenum >= 0)
|
||||||
p = sprite[ps[snum].access_spritenum].pal;
|
p = sprite[ps[snum].access_spritenum].pal;
|
||||||
|
@ -279,7 +279,7 @@ void displayweapon_d(int snum, double smoothratio)
|
||||||
int cw;
|
int cw;
|
||||||
int i, j;
|
int i, j;
|
||||||
int o,pal;
|
int o,pal;
|
||||||
double weapon_sway, weapon_xoffset, gun_pos, looking_arc, kickback_pic, random_club_frame;
|
double weapon_sway, weapon_xoffset, gun_pos, looking_arc, kickback_pic, random_club_frame, hard_landing;
|
||||||
signed char gs;
|
signed char gs;
|
||||||
struct player_struct *p;
|
struct player_struct *p;
|
||||||
|
|
||||||
|
@ -293,14 +293,15 @@ void displayweapon_d(int snum, double smoothratio)
|
||||||
weapon_sway = p->oweapon_sway + fmulscale16(p->weapon_sway - p->oweapon_sway, smoothratio);
|
weapon_sway = p->oweapon_sway + fmulscale16(p->weapon_sway - p->oweapon_sway, smoothratio);
|
||||||
kickback_pic = p->okickback_pic + fmulscale16(*kb - p->okickback_pic, smoothratio);
|
kickback_pic = p->okickback_pic + fmulscale16(*kb - p->okickback_pic, smoothratio);
|
||||||
random_club_frame = p->orandom_club_frame + fmulscale16(p->random_club_frame - p->orandom_club_frame, smoothratio);
|
random_club_frame = p->orandom_club_frame + fmulscale16(p->random_club_frame - p->orandom_club_frame, smoothratio);
|
||||||
|
hard_landing = p->ohard_landing + fmulscale16(p->hard_landing - p->ohard_landing, smoothratio);
|
||||||
|
|
||||||
gs = sprite[p->i].shade;
|
gs = sprite[p->i].shade;
|
||||||
if(gs > 24) gs = 24;
|
if(gs > 24) gs = 24;
|
||||||
|
|
||||||
if(p->newowner >= 0 || ud.camerasprite >= 0 || p->over_shoulder_on > 0 || (sprite[p->i].pal != 1 && sprite[p->i].extra <= 0) || animatefist(gs,snum) || animateknuckles(gs,snum) || animatetip(gs,snum) || animateaccess(gs,snum) )
|
if(p->newowner >= 0 || ud.camerasprite >= 0 || p->over_shoulder_on > 0 || (sprite[p->i].pal != 1 && sprite[p->i].extra <= 0) || animatefist(gs,snum) || animateknuckles(gs,snum,hard_landing) || animatetip(gs,snum,hard_landing) || animateaccess(gs,snum,hard_landing) )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
animateknee(gs,snum);
|
animateknee(gs,snum,hard_landing);
|
||||||
|
|
||||||
int opos = p->oweapon_pos * p->oweapon_pos;
|
int opos = p->oweapon_pos * p->oweapon_pos;
|
||||||
int npos = p->weapon_pos * p->weapon_pos;
|
int npos = p->weapon_pos * p->weapon_pos;
|
||||||
|
@ -313,7 +314,7 @@ void displayweapon_d(int snum, double smoothratio)
|
||||||
gun_pos -= fabs(calcSinTableValue(weapon_sway * 4.) / 512.);
|
gun_pos -= fabs(calcSinTableValue(weapon_sway * 4.) / 512.);
|
||||||
else gun_pos -= fabs(calcSinTableValue(weapon_sway / 2.) / 1024.);
|
else gun_pos -= fabs(calcSinTableValue(weapon_sway / 2.) / 1024.);
|
||||||
|
|
||||||
gun_pos -= (p->hard_landing<<3);
|
gun_pos -= hard_landing * 8.;
|
||||||
|
|
||||||
if (isWW2GI())
|
if (isWW2GI())
|
||||||
{
|
{
|
||||||
|
@ -1130,7 +1131,7 @@ void displayweapon_d(int snum, double smoothratio)
|
||||||
|
|
||||||
hud_drawpal(weapon_xoffset + 184 - p->lookanghalf(),
|
hud_drawpal(weapon_xoffset + 184 - p->lookanghalf(),
|
||||||
looking_arc + 240 - gun_pos, SHRINKER + 2,
|
looking_arc + 240 - gun_pos, SHRINKER + 2,
|
||||||
16 - (xs_CRoundToInt(calcSinTableValue(random_club_frame)) >> 10),
|
16 - xs_CRoundToInt(calcSinTableValue(random_club_frame) / 1024.),
|
||||||
o, 0);
|
o, 0);
|
||||||
|
|
||||||
hud_drawpal(weapon_xoffset + 188 - p->lookanghalf(),
|
hud_drawpal(weapon_xoffset + 188 - p->lookanghalf(),
|
||||||
|
@ -1287,7 +1288,7 @@ void displayweapon_d(int snum, double smoothratio)
|
||||||
{
|
{
|
||||||
hud_drawpal(weapon_xoffset + 184 - p->lookanghalf(),
|
hud_drawpal(weapon_xoffset + 184 - p->lookanghalf(),
|
||||||
looking_arc + 240 - gun_pos, SHRINKER + 2,
|
looking_arc + 240 - gun_pos, SHRINKER + 2,
|
||||||
16 - (xs_CRoundToInt(calcSinTableValue(random_club_frame)) >> 10),
|
16 - xs_CRoundToInt(calcSinTableValue(random_club_frame) / 1024.),
|
||||||
o, 2);
|
o, 2);
|
||||||
|
|
||||||
hud_drawpal(weapon_xoffset + 188 - p->lookanghalf(),
|
hud_drawpal(weapon_xoffset + 188 - p->lookanghalf(),
|
||||||
|
@ -1297,7 +1298,7 @@ void displayweapon_d(int snum, double smoothratio)
|
||||||
{
|
{
|
||||||
hud_drawpal(weapon_xoffset + 184 - p->lookanghalf(),
|
hud_drawpal(weapon_xoffset + 184 - p->lookanghalf(),
|
||||||
looking_arc + 240 - gun_pos, SHRINKER + 2,
|
looking_arc + 240 - gun_pos, SHRINKER + 2,
|
||||||
16 - (xs_CRoundToInt(calcSinTableValue(random_club_frame)) >> 10),
|
16 - xs_CRoundToInt(calcSinTableValue(random_club_frame) / 1024.),
|
||||||
o, 0);
|
o, 0);
|
||||||
|
|
||||||
hud_drawpal(weapon_xoffset + 188 - p->lookanghalf(),
|
hud_drawpal(weapon_xoffset + 188 - p->lookanghalf(),
|
||||||
|
|
|
@ -906,6 +906,7 @@ void backupweapon(player_struct* p)
|
||||||
p->oweapon_pos = p->weapon_pos;
|
p->oweapon_pos = p->weapon_pos;
|
||||||
p->okickback_pic = p->kickback_pic;
|
p->okickback_pic = p->kickback_pic;
|
||||||
p->orandom_club_frame = p->random_club_frame;
|
p->orandom_club_frame = p->random_club_frame;
|
||||||
|
p->ohard_landing = p->hard_landing;
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
|
@ -121,6 +121,8 @@ struct player_struct
|
||||||
int oweapon_sway;
|
int oweapon_sway;
|
||||||
short weapon_pos, kickback_pic, random_club_frame;
|
short weapon_pos, kickback_pic, random_club_frame;
|
||||||
short oweapon_pos, okickback_pic, orandom_club_frame;
|
short oweapon_pos, okickback_pic, orandom_club_frame;
|
||||||
|
unsigned char hard_landing;
|
||||||
|
unsigned char ohard_landing;
|
||||||
|
|
||||||
|
|
||||||
// From here on it is unaltered from JFDuke with the exception of a few fields that are no longer needed and were removed.
|
// From here on it is unaltered from JFDuke with the exception of a few fields that are no longer needed and were removed.
|
||||||
|
@ -172,7 +174,7 @@ struct player_struct
|
||||||
unsigned char refresh_inventory;
|
unsigned char refresh_inventory;
|
||||||
|
|
||||||
unsigned char toggle_key_flag, knuckle_incs; // ,select_dir;
|
unsigned char toggle_key_flag, knuckle_incs; // ,select_dir;
|
||||||
unsigned char walking_snd_toggle, palookup, hard_landing;
|
unsigned char walking_snd_toggle, palookup;
|
||||||
unsigned char return_to_center;
|
unsigned char return_to_center;
|
||||||
bool quick_kick_msg;
|
bool quick_kick_msg;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue