mirror of
https://github.com/ZDoom/qzdoom.git
synced 2025-01-18 23:21:41 +00:00
- scriptified the weapon's state getter methods - as preparation for the fighter axe.
This commit is contained in:
parent
997e4a2ac4
commit
e541c27622
5 changed files with 104 additions and 52 deletions
|
@ -21,38 +21,6 @@ static FRandom pr_axeatk ("FAxeAtk");
|
||||||
|
|
||||||
// The Fighter's Axe --------------------------------------------------------
|
// The Fighter's Axe --------------------------------------------------------
|
||||||
|
|
||||||
class AFWeapAxe : public AFighterWeapon
|
|
||||||
{
|
|
||||||
DECLARE_CLASS (AFWeapAxe, AFighterWeapon)
|
|
||||||
public:
|
|
||||||
FState *GetUpState ();
|
|
||||||
FState *GetDownState ();
|
|
||||||
FState *GetReadyState ();
|
|
||||||
FState *GetAtkState (bool hold);
|
|
||||||
};
|
|
||||||
|
|
||||||
IMPLEMENT_CLASS(AFWeapAxe, false, false)
|
|
||||||
|
|
||||||
FState *AFWeapAxe::GetUpState ()
|
|
||||||
{
|
|
||||||
return Ammo1->Amount ? FindState ("SelectGlow") : Super::GetUpState();
|
|
||||||
}
|
|
||||||
|
|
||||||
FState *AFWeapAxe::GetDownState ()
|
|
||||||
{
|
|
||||||
return Ammo1->Amount ? FindState ("DeselectGlow") : Super::GetDownState();
|
|
||||||
}
|
|
||||||
|
|
||||||
FState *AFWeapAxe::GetReadyState ()
|
|
||||||
{
|
|
||||||
return Ammo1->Amount ? FindState ("ReadyGlow") : Super::GetReadyState();
|
|
||||||
}
|
|
||||||
|
|
||||||
FState *AFWeapAxe::GetAtkState (bool hold)
|
|
||||||
{
|
|
||||||
return Ammo1->Amount ? FindState ("FireGlow") : Super::GetAtkState(hold);
|
|
||||||
}
|
|
||||||
|
|
||||||
//============================================================================
|
//============================================================================
|
||||||
//
|
//
|
||||||
// A_FAxeCheckReady
|
// A_FAxeCheckReady
|
||||||
|
|
|
@ -335,12 +335,12 @@ public:
|
||||||
virtual bool Use (bool pickup);
|
virtual bool Use (bool pickup);
|
||||||
virtual void Destroy() override;
|
virtual void Destroy() override;
|
||||||
|
|
||||||
virtual FState *GetUpState ();
|
FState *GetUpState ();
|
||||||
virtual FState *GetDownState ();
|
FState *GetDownState ();
|
||||||
virtual FState *GetReadyState ();
|
FState *GetReadyState ();
|
||||||
virtual FState *GetAtkState (bool hold);
|
FState *GetAtkState (bool hold);
|
||||||
virtual FState *GetAltAtkState (bool hold);
|
FState *GetAltAtkState (bool hold);
|
||||||
virtual FState *GetStateForButtonName (FName button);
|
FState *GetStateForButtonName (FName button);
|
||||||
|
|
||||||
virtual void PostMorphWeapon ();
|
virtual void PostMorphWeapon ();
|
||||||
virtual void EndPowerup ();
|
virtual void EndPowerup ();
|
||||||
|
|
|
@ -818,7 +818,16 @@ void AWeapon::CallEndPowerup()
|
||||||
|
|
||||||
FState *AWeapon::GetUpState ()
|
FState *AWeapon::GetUpState ()
|
||||||
{
|
{
|
||||||
return FindState(NAME_Select);
|
IFVIRTUAL(AWeapon, GetUpState)
|
||||||
|
{
|
||||||
|
VMValue params[1] = { (DObject*)this };
|
||||||
|
VMReturn ret;
|
||||||
|
VMFrameStack stack;
|
||||||
|
FState *retval;
|
||||||
|
ret.PointerAt((void**)&retval);
|
||||||
|
stack.Call(func, params, 1, &ret, 1, nullptr);
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
@ -829,7 +838,16 @@ FState *AWeapon::GetUpState ()
|
||||||
|
|
||||||
FState *AWeapon::GetDownState ()
|
FState *AWeapon::GetDownState ()
|
||||||
{
|
{
|
||||||
return FindState(NAME_Deselect);
|
IFVIRTUAL(AWeapon, GetDownState)
|
||||||
|
{
|
||||||
|
VMValue params[1] = { (DObject*)this };
|
||||||
|
VMReturn ret;
|
||||||
|
VMFrameStack stack;
|
||||||
|
FState *retval;
|
||||||
|
ret.PointerAt((void**)&retval);
|
||||||
|
stack.Call(func, params, 1, &ret, 1, nullptr);
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
@ -840,7 +858,16 @@ FState *AWeapon::GetDownState ()
|
||||||
|
|
||||||
FState *AWeapon::GetReadyState ()
|
FState *AWeapon::GetReadyState ()
|
||||||
{
|
{
|
||||||
return FindState(NAME_Ready);
|
IFVIRTUAL(AWeapon, GetReadyState)
|
||||||
|
{
|
||||||
|
VMValue params[1] = { (DObject*)this };
|
||||||
|
VMReturn ret;
|
||||||
|
VMFrameStack stack;
|
||||||
|
FState *retval;
|
||||||
|
ret.PointerAt((void**)&retval);
|
||||||
|
stack.Call(func, params, 1, &ret, 1, nullptr);
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
@ -851,11 +878,16 @@ FState *AWeapon::GetReadyState ()
|
||||||
|
|
||||||
FState *AWeapon::GetAtkState (bool hold)
|
FState *AWeapon::GetAtkState (bool hold)
|
||||||
{
|
{
|
||||||
FState * state=NULL;
|
IFVIRTUAL(AWeapon, GetAtkState)
|
||||||
|
{
|
||||||
if (hold) state = FindState(NAME_Hold);
|
VMValue params[2] = { (DObject*)this, hold };
|
||||||
if (state == NULL) state = FindState(NAME_Fire);
|
VMReturn ret;
|
||||||
return state;
|
VMFrameStack stack;
|
||||||
|
FState *retval;
|
||||||
|
ret.PointerAt((void**)&retval);
|
||||||
|
stack.Call(func, params, 2, &ret, 1, nullptr);
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
@ -866,11 +898,16 @@ FState *AWeapon::GetAtkState (bool hold)
|
||||||
|
|
||||||
FState *AWeapon::GetAltAtkState (bool hold)
|
FState *AWeapon::GetAltAtkState (bool hold)
|
||||||
{
|
{
|
||||||
FState * state=NULL;
|
IFVIRTUAL(AWeapon, GetAltAtkState)
|
||||||
|
{
|
||||||
if (hold) state = FindState(NAME_AltHold);
|
VMValue params[2] = { (DObject*)this, hold };
|
||||||
if (state == NULL) state = FindState(NAME_AltFire);
|
VMReturn ret;
|
||||||
return state;
|
VMFrameStack stack;
|
||||||
|
FState *retval;
|
||||||
|
ret.PointerAt((void**)&retval);
|
||||||
|
stack.Call(func, params, 2, &ret, 1, nullptr);
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
// The Fighter's Axe --------------------------------------------------------
|
// The Fighter's Axe --------------------------------------------------------
|
||||||
|
|
||||||
class FWeapAxe : FighterWeapon native
|
class FWeapAxe : FighterWeapon
|
||||||
{
|
{
|
||||||
Default
|
Default
|
||||||
{
|
{
|
||||||
|
@ -79,6 +79,28 @@ class FWeapAxe : FighterWeapon native
|
||||||
FAXE A 1;
|
FAXE A 1;
|
||||||
Goto ReadyGlow;
|
Goto ReadyGlow;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override State GetUpState ()
|
||||||
|
{
|
||||||
|
return Ammo1.Amount ? FindState ("SelectGlow") : Super.GetUpState();
|
||||||
|
}
|
||||||
|
|
||||||
|
override State GetDownState ()
|
||||||
|
{
|
||||||
|
return Ammo1.Amount ? FindState ("DeselectGlow") : Super.GetDownState();
|
||||||
|
}
|
||||||
|
|
||||||
|
override State GetReadyState ()
|
||||||
|
{
|
||||||
|
return Ammo1.Amount ? FindState ("ReadyGlow") : Super.GetReadyState();
|
||||||
|
}
|
||||||
|
|
||||||
|
override State GetAtkState (bool hold)
|
||||||
|
{
|
||||||
|
return Ammo1.Amount ? FindState ("FireGlow") : Super.GetAtkState(hold);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Axe Puff -----------------------------------------------------------------
|
// Axe Puff -----------------------------------------------------------------
|
||||||
|
|
|
@ -580,6 +580,31 @@ class Weapon : StateProvider native
|
||||||
return FindState('Ready');
|
return FindState('Ready');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
virtual State GetUpState ()
|
||||||
|
{
|
||||||
|
return FindState('Select');
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual State GetDownState ()
|
||||||
|
{
|
||||||
|
return FindState('Deselect');
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual State GetAtkState (bool hold)
|
||||||
|
{
|
||||||
|
State s = null;
|
||||||
|
if (hold) s = FindState('Hold');
|
||||||
|
if (s == null) s = FindState('Fire');
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual State GetAltAtkState (bool hold)
|
||||||
|
{
|
||||||
|
State s = null;
|
||||||
|
if (hold) s = FindState('AltHold');
|
||||||
|
if (s == null) s = FindState('AltFire');
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
native action void A_ZoomFactor(double scale = 1, int flags = 0);
|
native action void A_ZoomFactor(double scale = 1, int flags = 0);
|
||||||
native action void A_SetCrosshair(int xhair);
|
native action void A_SetCrosshair(int xhair);
|
||||||
|
|
Loading…
Reference in a new issue