mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Tweaked the weapon system to act a bit more like vanilla Duke for great gameplay accuracy and not caring if your mod breaks ;)
git-svn-id: https://svn.eduke32.com/eduke32@46 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
9e711bc90c
commit
257b446320
1 changed files with 37 additions and 71 deletions
|
@ -1969,14 +1969,14 @@ void DoFire(short snum)
|
||||||
p->visibility = 0;
|
p->visibility = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( //!(aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_CHECKATRELOAD) &&
|
/* if( //!(aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_CHECKATRELOAD) &&
|
||||||
aplWeaponReload[p->curr_weapon][snum] > aplWeaponTotalTime[p->curr_weapon][snum]
|
aplWeaponReload[p->curr_weapon][snum] > aplWeaponTotalTime[p->curr_weapon][snum]
|
||||||
&& p->ammo_amount[p->curr_weapon] > 0
|
&& p->ammo_amount[p->curr_weapon] > 0
|
||||||
&& (aplWeaponClip[p->curr_weapon][snum])
|
&& (aplWeaponClip[p->curr_weapon][snum])
|
||||||
&& ((p->ammo_amount[p->curr_weapon]%(aplWeaponClip[p->curr_weapon][snum]))==0))
|
&& ((p->ammo_amount[p->curr_weapon]%(aplWeaponClip[p->curr_weapon][snum]))==0))
|
||||||
{
|
{
|
||||||
p->kickback_pic=aplWeaponTotalTime[p->curr_weapon][snum];
|
p->kickback_pic=aplWeaponTotalTime[p->curr_weapon][snum];
|
||||||
}
|
} */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3575,9 +3575,7 @@ void processinput(short snum)
|
||||||
doincrements(p);
|
doincrements(p);
|
||||||
|
|
||||||
if(*aplWeaponWorksLike[p->curr_weapon] == HANDREMOTE_WEAPON)
|
if(*aplWeaponWorksLike[p->curr_weapon] == HANDREMOTE_WEAPON)
|
||||||
{
|
|
||||||
goto SHOOTINCODE;
|
goto SHOOTINCODE;
|
||||||
}
|
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -4511,8 +4509,6 @@ HORIZONLY:
|
||||||
// HACKS
|
// HACKS
|
||||||
|
|
||||||
SHOOTINCODE:
|
SHOOTINCODE:
|
||||||
//#define WEAPON2_CLIP 20
|
|
||||||
// reload clip
|
|
||||||
if( sb_snum & (1<<19) ) // 'Holster Weapon
|
if( sb_snum & (1<<19) ) // 'Holster Weapon
|
||||||
{
|
{
|
||||||
SetGameVarID(g_iReturnVarID,0,pi,snum);
|
SetGameVarID(g_iReturnVarID,0,pi,snum);
|
||||||
|
@ -4521,18 +4517,14 @@ SHOOTINCODE:
|
||||||
OnEvent(EVENT_HOLSTER, pi, snum, -1);
|
OnEvent(EVENT_HOLSTER, pi, snum, -1);
|
||||||
if(GetGameVarID(g_iReturnVarID,pi,snum) == 0)
|
if(GetGameVarID(g_iReturnVarID,pi,snum) == 0)
|
||||||
{
|
{
|
||||||
|
|
||||||
// now it uses the game definitions...
|
|
||||||
if( aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_HOLSTER_CLEARS_CLIP)
|
if( aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_HOLSTER_CLEARS_CLIP)
|
||||||
{
|
{
|
||||||
if( p->ammo_amount[p->curr_weapon] > aplWeaponClip[p->curr_weapon][snum]
|
if( p->ammo_amount[p->curr_weapon] > aplWeaponClip[p->curr_weapon][snum]
|
||||||
&& (p->ammo_amount[p->curr_weapon] % aplWeaponClip[p->curr_weapon][snum]) != 0 )
|
&& (p->ammo_amount[p->curr_weapon] % aplWeaponClip[p->curr_weapon][snum]) != 0 )
|
||||||
{
|
{
|
||||||
// throw away the remaining clip
|
|
||||||
p->ammo_amount[p->curr_weapon]-=
|
p->ammo_amount[p->curr_weapon]-=
|
||||||
p->ammo_amount[p->curr_weapon] % aplWeaponClip[p->curr_weapon][snum] ;
|
p->ammo_amount[p->curr_weapon] % aplWeaponClip[p->curr_weapon][snum] ;
|
||||||
// (*kb) = aplWeaponFireDelay[p->curr_weapon][snum]+1; // animate, but don't shoot...
|
(*kb) = aplWeaponTotalTime[p->curr_weapon][snum];
|
||||||
(*kb) = aplWeaponTotalTime[p->curr_weapon][snum]; // animate, but don't shoot...
|
|
||||||
sb_snum &= ~(1<<2); // not firing...
|
sb_snum &= ~(1<<2); // not firing...
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
@ -4541,7 +4533,6 @@ SHOOTINCODE:
|
||||||
}
|
}
|
||||||
|
|
||||||
if( aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_GLOWS)
|
if( aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_GLOWS)
|
||||||
//== SHRINKER_WEAPON || p->curr_weapon == GROW_WEAPON )
|
|
||||||
p->random_club_frame += 64; // Glowing
|
p->random_club_frame += 64; // Glowing
|
||||||
|
|
||||||
if(p->rapid_fire_hold == 1)
|
if(p->rapid_fire_hold == 1)
|
||||||
|
@ -4554,7 +4545,6 @@ SHOOTINCODE:
|
||||||
else if ( shrunk == 0 && (sb_snum&(1<<2)) && (*kb) == 0 && p->fist_incs == 0 &&
|
else if ( shrunk == 0 && (sb_snum&(1<<2)) && (*kb) == 0 && p->fist_incs == 0 &&
|
||||||
p->last_weapon == -1 && ( p->weapon_pos == 0 || p->holster_weapon == 1 ) )
|
p->last_weapon == -1 && ( p->weapon_pos == 0 || p->holster_weapon == 1 ) )
|
||||||
{
|
{
|
||||||
|
|
||||||
p->crack_time = 777;
|
p->crack_time = 777;
|
||||||
|
|
||||||
if(p->holster_weapon == 1)
|
if(p->holster_weapon == 1)
|
||||||
|
@ -4574,7 +4564,6 @@ SHOOTINCODE:
|
||||||
OnEvent(EVENT_FIRE, pi, snum, -1);
|
OnEvent(EVENT_FIRE, pi, snum, -1);
|
||||||
if(GetGameVarID(g_iReturnVarID,pi,snum) == 0)
|
if(GetGameVarID(g_iReturnVarID,pi,snum) == 0)
|
||||||
{
|
{
|
||||||
|
|
||||||
switch(aplWeaponWorksLike[p->curr_weapon][snum])
|
switch(aplWeaponWorksLike[p->curr_weapon][snum])
|
||||||
{
|
{
|
||||||
case HANDBOMB_WEAPON:
|
case HANDBOMB_WEAPON:
|
||||||
|
@ -4705,19 +4694,10 @@ SHOOTINCODE:
|
||||||
}
|
}
|
||||||
else if((*kb))
|
else if((*kb))
|
||||||
{
|
{
|
||||||
// already firing...
|
|
||||||
|
|
||||||
//Bsprintf(g_szBuf,"%s %ld, kb=%d %ld",__FILE__,__LINE__,*kb,aplWeaponWorksLike[p->curr_weapon][snum]);
|
|
||||||
//AddLog(g_szBuf);
|
|
||||||
if(aplWeaponWorksLike[p->curr_weapon][snum] == HANDBOMB_WEAPON)
|
if(aplWeaponWorksLike[p->curr_weapon][snum] == HANDBOMB_WEAPON)
|
||||||
{
|
{
|
||||||
if( aplWeaponHoldDelay[p->curr_weapon][snum] // there is a hold delay
|
if( aplWeaponHoldDelay[p->curr_weapon][snum] && ((*kb) == aplWeaponFireDelay[p->curr_weapon][snum]) && (sb_snum&(1<<2)))
|
||||||
&& ((*kb) == aplWeaponFireDelay[p->curr_weapon][snum]) // and we are 'at' hold
|
|
||||||
&& (sb_snum&(1<<2)) // and 'fire' button is still down
|
|
||||||
)
|
|
||||||
// just hold here...
|
|
||||||
{
|
{
|
||||||
//AddLog("Holding HANDBOMB");
|
|
||||||
p->rapid_fire_hold = 1;
|
p->rapid_fire_hold = 1;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -4726,7 +4706,6 @@ SHOOTINCODE:
|
||||||
{
|
{
|
||||||
long lPipeBombControl;
|
long lPipeBombControl;
|
||||||
|
|
||||||
// AddLog("Releasing HANDBOMB");
|
|
||||||
p->ammo_amount[p->curr_weapon]--;
|
p->ammo_amount[p->curr_weapon]--;
|
||||||
|
|
||||||
if(p->on_ground && (sb_snum&2) )
|
if(p->on_ground && (sb_snum&2) )
|
||||||
|
@ -4752,9 +4731,6 @@ SHOOTINCODE:
|
||||||
{
|
{
|
||||||
long lGrenadeLifetime=GetGameVar("GRENADE_LIFETIME", NAM_GRENADE_LIFETIME, -1, snum);
|
long lGrenadeLifetime=GetGameVar("GRENADE_LIFETIME", NAM_GRENADE_LIFETIME, -1, snum);
|
||||||
long lGrenadeLifetimeVar=GetGameVar("GRENADE_LIFETIME_VAR", NAM_GRENADE_LIFETIME_VAR, -1, snum);
|
long lGrenadeLifetimeVar=GetGameVar("GRENADE_LIFETIME_VAR", NAM_GRENADE_LIFETIME_VAR, -1, snum);
|
||||||
//Bsprintf(g_szBuf,"Lifetime=%ld Var=%ld snum=%d",lGrenadeLifetime, lGrenadeLifetimeVar, snum);
|
|
||||||
//AddLog(g_szBuf);
|
|
||||||
// set timer. blows up when at zero....
|
|
||||||
hittype[j].temp_data[7]=lGrenadeLifetime
|
hittype[j].temp_data[7]=lGrenadeLifetime
|
||||||
+ mulscale(krand(),lGrenadeLifetimeVar, 14)
|
+ mulscale(krand(),lGrenadeLifetimeVar, 14)
|
||||||
- lGrenadeLifetimeVar;
|
- lGrenadeLifetimeVar;
|
||||||
|
@ -4776,9 +4752,7 @@ SHOOTINCODE:
|
||||||
sprite[j].zvel /= 3;
|
sprite[j].zvel /= 3;
|
||||||
sprite[j].xvel /= 3;
|
sprite[j].xvel /= 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
p->hbomb_on = 1;
|
p->hbomb_on = 1;
|
||||||
|
|
||||||
}
|
}
|
||||||
else if( (*kb) < aplWeaponHoldDelay[p->curr_weapon][snum] && (sb_snum&(1<<2)) )
|
else if( (*kb) < aplWeaponHoldDelay[p->curr_weapon][snum] && (sb_snum&(1<<2)) )
|
||||||
{
|
{
|
||||||
|
@ -4814,7 +4788,6 @@ SHOOTINCODE:
|
||||||
{
|
{
|
||||||
if(! (aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_NOVISIBLE ))
|
if(! (aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_NOVISIBLE ))
|
||||||
{
|
{
|
||||||
// make them visible if not set...
|
|
||||||
lastvisinc = totalclock+32;
|
lastvisinc = totalclock+32;
|
||||||
p->visibility = 0;
|
p->visibility = 0;
|
||||||
}
|
}
|
||||||
|
@ -4828,7 +4801,6 @@ SHOOTINCODE:
|
||||||
{
|
{
|
||||||
long lPipeBombControl=GetGameVar("PIPEBOMB_CONTROL", PIPEBOMB_REMOTE, -1, snum);
|
long lPipeBombControl=GetGameVar("PIPEBOMB_CONTROL", PIPEBOMB_REMOTE, -1, snum);
|
||||||
(*kb) = 0;
|
(*kb) = 0;
|
||||||
/// WHAT THE HELL DOES THIS DO....?????????????
|
|
||||||
if((p->ammo_amount[HANDBOMB_WEAPON] > 0) && lPipeBombControl == PIPEBOMB_REMOTE)
|
if((p->ammo_amount[HANDBOMB_WEAPON] > 0) && lPipeBombControl == PIPEBOMB_REMOTE)
|
||||||
addweapon(p,HANDBOMB_WEAPON);
|
addweapon(p,HANDBOMB_WEAPON);
|
||||||
else
|
else
|
||||||
|
@ -4873,49 +4845,17 @@ SHOOTINCODE:
|
||||||
if(*kb == aplWeaponSpawnTime[p->curr_weapon][snum])
|
if(*kb == aplWeaponSpawnTime[p->curr_weapon][snum])
|
||||||
DoSpawn(snum);
|
DoSpawn(snum);
|
||||||
|
|
||||||
if ( *kb > aplWeaponFireDelay[p->curr_weapon][snum]
|
if ((*kb) >= aplWeaponTotalTime[p->curr_weapon][snum])
|
||||||
&& (*kb) < aplWeaponTotalTime[p->curr_weapon][snum]
|
|
||||||
&& (aplWeaponWorksLike[p->curr_weapon][snum] & KNEE_WEAPON ? 1 : p->ammo_amount[p->curr_weapon] > 0))
|
|
||||||
{
|
{
|
||||||
if ( aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_AUTOMATIC)
|
if(/*!(aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_CHECKATRELOAD) && */ p->reloading == 1 ||
|
||||||
{
|
(aplWeaponReload[p->curr_weapon][snum] > aplWeaponTotalTime[p->curr_weapon][snum] && p->ammo_amount[p->curr_weapon] > 0
|
||||||
if( ( sb_snum&(1<<2) ) == 0 )
|
&& (aplWeaponClip[p->curr_weapon][snum]) && (((p->ammo_amount[p->curr_weapon]%(aplWeaponClip[p->curr_weapon][snum]))==0))))
|
||||||
{
|
|
||||||
*kb = aplWeaponTotalTime[p->curr_weapon][snum];
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_FIREEVERYTHIRD)
|
|
||||||
{
|
|
||||||
if( ((*(kb))%3) == 0 )
|
|
||||||
{
|
|
||||||
DoFire(snum);
|
|
||||||
DoSpawn(snum);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if( aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_FIREEVERYOTHER)
|
|
||||||
{
|
|
||||||
DoFire(snum);
|
|
||||||
DoSpawn(snum);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if(*kb == aplWeaponFireDelay[p->curr_weapon][snum]
|
|
||||||
&& (aplWeaponWorksLike[p->curr_weapon][snum]==KNEE_WEAPON ? 1 : p->ammo_amount[p->curr_weapon] > 0))
|
|
||||||
{
|
|
||||||
DoFire(snum);
|
|
||||||
}
|
|
||||||
else if ((*kb) >= aplWeaponTotalTime[p->curr_weapon][snum])
|
|
||||||
{
|
|
||||||
if( //!(aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_CHECKATRELOAD) &&
|
|
||||||
(aplWeaponReload[p->curr_weapon][snum] > aplWeaponTotalTime[p->curr_weapon][snum]
|
|
||||||
&& p->ammo_amount[p->curr_weapon] > 0
|
|
||||||
&& (aplWeaponClip[p->curr_weapon][snum])
|
|
||||||
&& (((p->ammo_amount[p->curr_weapon]%(aplWeaponClip[p->curr_weapon][snum]))==0))) || p->reloading == 1 )
|
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
i=aplWeaponReload[p->curr_weapon][snum] - aplWeaponTotalTime[p->curr_weapon][snum];
|
i=aplWeaponReload[p->curr_weapon][snum] - aplWeaponTotalTime[p->curr_weapon][snum];
|
||||||
p->reloading = 1;
|
p->reloading = 1;
|
||||||
if( (*kb) == (aplWeaponTotalTime[p->curr_weapon][snum] + 1))
|
if( (*kb) == (aplWeaponTotalTime[p->curr_weapon][snum]));
|
||||||
|
else if( (*kb) == (aplWeaponTotalTime[p->curr_weapon][snum]+1))
|
||||||
{
|
{
|
||||||
if(aplWeaponReloadSound1[p->curr_weapon][snum])
|
if(aplWeaponReloadSound1[p->curr_weapon][snum])
|
||||||
spritesound(aplWeaponReloadSound1[p->curr_weapon][snum],pi);
|
spritesound(aplWeaponReloadSound1[p->curr_weapon][snum],pi);
|
||||||
|
@ -4926,7 +4866,6 @@ SHOOTINCODE:
|
||||||
if(aplWeaponReloadSound2[p->curr_weapon][snum])
|
if(aplWeaponReloadSound2[p->curr_weapon][snum])
|
||||||
spritesound(aplWeaponReloadSound2[p->curr_weapon][snum],pi);
|
spritesound(aplWeaponReloadSound2[p->curr_weapon][snum],pi);
|
||||||
}
|
}
|
||||||
|
|
||||||
else if( (*kb) >= (aplWeaponReload[p->curr_weapon][snum]) )
|
else if( (*kb) >= (aplWeaponReload[p->curr_weapon][snum]) )
|
||||||
{
|
{
|
||||||
*kb=0;
|
*kb=0;
|
||||||
|
@ -4949,6 +4888,33 @@ SHOOTINCODE:
|
||||||
else *kb=0;
|
else *kb=0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if ( *kb > aplWeaponFireDelay[p->curr_weapon][snum] && (*kb) < aplWeaponTotalTime[p->curr_weapon][snum]
|
||||||
|
&& (aplWeaponWorksLike[p->curr_weapon][snum] & KNEE_WEAPON ? 1 : p->ammo_amount[p->curr_weapon] > 0))
|
||||||
|
{
|
||||||
|
if ( aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_AUTOMATIC)
|
||||||
|
{
|
||||||
|
if( ( sb_snum&(1<<2) ) == 0 )
|
||||||
|
*kb = aplWeaponTotalTime[p->curr_weapon][snum];
|
||||||
|
if ( aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_FIREEVERYTHIRD)
|
||||||
|
{
|
||||||
|
if( ((*(kb))%3) == 0 )
|
||||||
|
{
|
||||||
|
DoFire(snum);
|
||||||
|
DoSpawn(snum);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if( aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_FIREEVERYOTHER)
|
||||||
|
{
|
||||||
|
DoFire(snum);
|
||||||
|
DoSpawn(snum);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(*kb == aplWeaponFireDelay[p->curr_weapon][snum]
|
||||||
|
&& (aplWeaponWorksLike[p->curr_weapon][snum]==KNEE_WEAPON ? 1 : p->ammo_amount[p->curr_weapon] > 0))
|
||||||
|
{
|
||||||
|
DoFire(snum);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue