mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-13 19:40:43 +00:00
Fix max players range check for kModernPlayerControl
Add power up control for kModernPlayerControl
This commit is contained in:
parent
1fa0863a52
commit
a40d036623
2 changed files with 48 additions and 7 deletions
|
@ -658,7 +658,7 @@ void nnExtInitModernStuff(bool bSaveLoad) {
|
||||||
switch (pXSprite->command) {
|
switch (pXSprite->command) {
|
||||||
case kCmdLink:
|
case kCmdLink:
|
||||||
{
|
{
|
||||||
if (pXSprite->data1 < 1 || pXSprite->data1 >= kMaxPlayers)
|
if (pXSprite->data1 < 1 || pXSprite->data1 > kMaxPlayers)
|
||||||
I_Error("\nPlayer Control (SPRITE #%d):\nPlayer out of a range (data1 = %d)", pSprite->index, pXSprite->data1);
|
I_Error("\nPlayer Control (SPRITE #%d):\nPlayer out of a range (data1 = %d)", pSprite->index, pXSprite->data1);
|
||||||
|
|
||||||
//if (numplayers < pXSprite->data1)
|
//if (numplayers < pXSprite->data1)
|
||||||
|
@ -2149,6 +2149,40 @@ void trPlayerCtrlUsePackItem(XSPRITE* pXSource, PLAYER* pPlayer, int evCmd) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void trPlayerCtrlUsePowerup(XSPRITE* pXSource, PLAYER* pPlayer, int evCmd) {
|
||||||
|
|
||||||
|
spritetype* pSource = &sprite[pXSource->reference];
|
||||||
|
bool relative = (pSource->flags & kModernTypeFlag1);
|
||||||
|
|
||||||
|
int nPower = (kMinAllowedPowerup + pXSource->data2) - 1;
|
||||||
|
int nTime = ClipRange(abs(pXSource->data3) * 100, -gPowerUpInfo[nPower].maxTime, gPowerUpInfo[nPower].maxTime);
|
||||||
|
if (pXSource->data3 < 0)
|
||||||
|
nTime = -nTime;
|
||||||
|
|
||||||
|
|
||||||
|
if (pPlayer->pwUpTime[nPower]) {
|
||||||
|
if (!relative && nTime <= 0)
|
||||||
|
powerupDeactivate(pPlayer, nPower);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (nTime != 0) {
|
||||||
|
|
||||||
|
if (pPlayer->pwUpTime[nPower] <= 0)
|
||||||
|
powerupActivate(pPlayer, nPower); // MUST activate first for powerups like kPwUpDeathMask
|
||||||
|
|
||||||
|
// ...so we able to change time amount
|
||||||
|
if (relative) pPlayer->pwUpTime[nPower] += nTime;
|
||||||
|
else pPlayer->pwUpTime[nPower] = nTime;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pPlayer->pwUpTime[nPower] <= 0)
|
||||||
|
powerupDeactivate(pPlayer, nPower);
|
||||||
|
|
||||||
|
return;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
void useObjResizer(XSPRITE* pXSource, short objType, int objIndex) {
|
void useObjResizer(XSPRITE* pXSource, short objType, int objIndex) {
|
||||||
switch (objType) {
|
switch (objType) {
|
||||||
// for sectors
|
// for sectors
|
||||||
|
@ -3662,10 +3696,10 @@ bool condCheckPlayer(XSPRITE* pXCond, int cmpOp, bool PUSH) {
|
||||||
case 5: return (arg1 > 0 && arg1 < 6 && condCmp(pPlayer->packSlots[arg1 - 1].curAmount, arg2, arg3, cmpOp));
|
case 5: return (arg1 > 0 && arg1 < 6 && condCmp(pPlayer->packSlots[arg1 - 1].curAmount, arg2, arg3, cmpOp));
|
||||||
case 6: return (arg1 > 0 && arg1 < 6 && pPlayer->packSlots[arg1 - 1].isActive);
|
case 6: return (arg1 > 0 && arg1 < 6 && pPlayer->packSlots[arg1 - 1].isActive);
|
||||||
case 7: return condCmp(pPlayer->packItemId + 1, arg1, arg2, cmpOp);
|
case 7: return condCmp(pPlayer->packItemId + 1, arg1, arg2, cmpOp);
|
||||||
case 8: // check for powerup amount in %
|
case 8: // check for powerup amount in seconds
|
||||||
if (arg3 > 0 && arg3 < 30) {
|
if (arg3 > 0 && arg3 <= (kMaxAllowedPowerup - (kMinAllowedPowerup << 1) + 1)) {
|
||||||
var = (12 + arg3) - 1; // allowable powerups
|
var = (kMinAllowedPowerup + arg3) - 1; // allowable powerups
|
||||||
return condCmp((kPercFull * pPlayer->pwUpTime[var]) / gPowerUpInfo[var].bonusTime, arg1, arg2, cmpOp);
|
return condCmp(pPlayer->pwUpTime[var] / 100, arg1, arg2, cmpOp);
|
||||||
}
|
}
|
||||||
condError(pXCond, "Unexpected powerup #%d", arg3);
|
condError(pXCond, "Unexpected powerup #%d", arg3);
|
||||||
return false;
|
return false;
|
||||||
|
@ -5091,7 +5125,11 @@ bool modernTypeOperateSprite(int nSprite, spritetype* pSprite, XSPRITE* pXSprite
|
||||||
pPlayer->angle.lockinput();
|
pPlayer->angle.lockinput();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 10: // 74 (print the book)
|
case 10: // 74 (de)activate powerup
|
||||||
|
if (pXSprite->data2 <= 0 || pXSprite->data2 > (kMaxAllowedPowerup - (kMinAllowedPowerup << 1) + 1)) break;
|
||||||
|
trPlayerCtrlUsePowerup(pXSprite, pPlayer, event.cmd);
|
||||||
|
break;
|
||||||
|
// case 11: // 75 (print the book)
|
||||||
// data2: RFF TXT id
|
// data2: RFF TXT id
|
||||||
// data3: background tile
|
// data3: background tile
|
||||||
// data4: font base tile
|
// data4: font base tile
|
||||||
|
@ -5102,7 +5140,7 @@ bool modernTypeOperateSprite(int nSprite, spritetype* pSprite, XSPRITE* pXSprite
|
||||||
// d3: 1: inherit palette for font, 2: inherit palette for background, 3: both
|
// d3: 1: inherit palette for font, 2: inherit palette for background, 3: both
|
||||||
// busyTime: speed of word/letter/line printing
|
// busyTime: speed of word/letter/line printing
|
||||||
// waitTime: if TX ID > 0 and TX ID object is book reader, trigger it?
|
// waitTime: if TX ID > 0 and TX ID object is book reader, trigger it?
|
||||||
break;
|
//break;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -88,6 +88,9 @@ enum
|
||||||
kEffectGenCallbackBase = 200,
|
kEffectGenCallbackBase = 200,
|
||||||
kTriggerSpriteScreen = 0x0001,
|
kTriggerSpriteScreen = 0x0001,
|
||||||
kTriggerSpriteAim = 0x0002,
|
kTriggerSpriteAim = 0x0002,
|
||||||
|
|
||||||
|
kMinAllowedPowerup = kPwUpFeatherFall,
|
||||||
|
kMaxAllowedPowerup = kMaxPowerUps
|
||||||
};
|
};
|
||||||
|
|
||||||
// modern statnums
|
// modern statnums
|
||||||
|
|
Loading…
Reference in a new issue