Fixed Scientist Hunt weapons to work with some of the new weapon base stuff

This commit is contained in:
Marco Cawthorne 2019-08-21 16:06:14 -07:00
parent 8fd19cddc0
commit 929b7668e0
3 changed files with 66 additions and 65 deletions

View file

@ -83,11 +83,12 @@ void w_cannon_pickup(void)
void w_cannon_draw(void)
{
Weapons_SetModel("models/v_cannon.mdl");
Weapons_ViewAnimation(CANNON_DEPLOY);
#ifdef SSQC
player pl = (player)self;
Weapons_UpdateAmmo(pl, pl.cannon_mag, pl.ammo_buckshot, __NULL__);
#endif
Weapons_ViewAnimation(CANNON_DEPLOY);
}
void w_cannon_holster(void)

View file

@ -46,11 +46,12 @@ string w_chainsaw_deathmsg(void)
void w_chainsaw_draw(void)
{
Weapons_SetModel("models/v_chainsaw.mdl");
Weapons_ViewAnimation(CHAINSAW_DEPLOY);
#ifdef SSQC
player pl = (player)self;
Weapons_UpdateAmmo(pl, __NULL__, __NULL__, __NULL__);
#endif
Weapons_ViewAnimation(CHAINSAW_DEPLOY);
}
void w_chainsaw_holster(void)

View file

@ -47,6 +47,7 @@ string w_hammer_deathmsg(void)
void w_hammer_draw(void)
{
Weapons_SetModel("models/v_hammer.mdl");
Weapons_ViewAnimation(HAMMER_DRAW);
#ifdef SSQC
player pl = (player)self;
@ -98,41 +99,15 @@ void w_hammer_release(void)
return;
}
if (pl.a_ammo1 == 1) {
Weapons_ViewAnimation(HAMMER_ATTACK1);
pl.w_attack_next = 1.0f;
} else if (pl.a_ammo1 == 2) {
Weapons_ViewAnimation(HAMMER_ATTACK2);
pl.w_attack_next = 0.75f;
}
/* Pure cosmetics start here */
if (pl.w_idle_next) {
return;
}
int r = floor(random(0,3));
switch (r) {
case 0:
Weapons_ViewAnimation(HAMMER_IDLE1);
break;
case 1:
Weapons_ViewAnimation(HAMMER_IDLE2);
break;
case 2:
Weapons_ViewAnimation(HAMMER_IDLE3);
break;
}
pl.w_idle_next = 10.0f;
#ifdef SSQC
int hitsound = 0;
vector src = pl.origin + pl.view_ofs;
makevectors(pl.v_angle);
traceline(src, src + v_forward * 64, FALSE, self);
#endif
/* Standard attack */
if (pl.a_ammo1 == 1) {
#ifdef SSQC
if (trace_ent.takedamage) {
hitsound = floor(random(1, 4));
@ -152,8 +127,11 @@ void w_hammer_release(void)
hitsound = 4;
}
}
#endif
Weapons_ViewAnimation(HAMMER_ATTACK1);
pl.w_attack_next = 1.0f;
} else if (pl.a_ammo1 == 2) {
#ifdef SSQC
if (trace_ent.takedamage) {
hitsound = floor(random(1, 4));
Damage_Apply(trace_ent, self, 200, trace_endpos, FALSE);
@ -162,11 +140,12 @@ void w_hammer_release(void)
hitsound = 4;
}
}
#endif
Weapons_ViewAnimation(HAMMER_ATTACK2);
pl.w_attack_next = 0.75f;
} else {
return;
}
#ifdef SSQC
switch (hitsound) {
case 1:
Weapons_PlaySound(pl, CHAN_WEAPON, "sh/ham_hitbod1.wav", 1, ATTN_NORM);
@ -183,10 +162,30 @@ void w_hammer_release(void)
default:
Weapons_PlaySound(pl, CHAN_WEAPON, "sh/ham_swing.wav", 1, ATTN_NORM);
}
#endif
/* Reset the hack */
#endif
pl.a_ammo1 = 0;
/* Pure cosmetics start here */
if (pl.w_idle_next) {
return;
}
int r = floor(random(0,3));
switch (r) {
case 0:
Weapons_ViewAnimation(HAMMER_IDLE1);
break;
case 1:
Weapons_ViewAnimation(HAMMER_IDLE2);
break;
case 2:
Weapons_ViewAnimation(HAMMER_IDLE3);
break;
}
pl.w_idle_next = 10.0f;
}
float w_hammer_aimanim(void)