mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
- Event redirection support for modern types
- New modern type "Condition" (WIP) - Fix damage scale for custom dude - Extend Impact and Vector flags so they can be used with dudes - Impact condition can be triggered with missiles and explosions - Updates for Teleport Target type (gModernMap) - Updates for Effect Gen type - Updates for Wind Gen type # Conflicts: # source/blood/src/actor.cpp # source/blood/src/aiunicult.h
This commit is contained in:
parent
8eef69b1a6
commit
bdca9420f5
8 changed files with 915 additions and 494 deletions
|
@ -2461,11 +2461,13 @@ const int DudeDifficulty[5] = {
|
||||||
void actInit(bool bSaveLoad) {
|
void actInit(bool bSaveLoad) {
|
||||||
|
|
||||||
#ifdef NOONE_EXTENSIONS
|
#ifdef NOONE_EXTENSIONS
|
||||||
if (!gModernMap) initprintf("> This map *does not* provides modern features.\n");
|
if (!gModernMap) {
|
||||||
else {
|
//initprintf("> This map *does not* provides modern features.\n");
|
||||||
initprintf("> This map provides modern features.\n");
|
nnExtResetGlobals();
|
||||||
|
} else {
|
||||||
|
//initprintf("> This map provides modern features.\n");
|
||||||
nnExtInitModernStuff(bSaveLoad);
|
nnExtInitModernStuff(bSaveLoad);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (int nSprite = headspritestat[kStatItem]; nSprite >= 0; nSprite = nextspritestat[nSprite]) {
|
for (int nSprite = headspritestat[kStatItem]; nSprite >= 0; nSprite = nextspritestat[nSprite]) {
|
||||||
|
@ -3979,6 +3981,11 @@ void actImpactMissile(spritetype *pMissile, int hitCode)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef NOONE_EXTENSIONS
|
||||||
|
if (gModernMap && pXSpriteHit && pXSpriteHit->state != pXSpriteHit->restState && pXSpriteHit->Impact)
|
||||||
|
trTriggerSprite(nSpriteHit, pXSpriteHit, kCmdSpriteImpact);
|
||||||
|
#endif
|
||||||
pMissile->cstat &= ~257;
|
pMissile->cstat &= ~257;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5768,21 +5775,6 @@ void actProcessSprites(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef NOONE_EXTENSIONS
|
|
||||||
// add impulse for sprites from physics list
|
|
||||||
if (gPhysSpritesCount > 0 && pExplodeInfo->dmgType != 0 && pXSprite->data1 != 0) {
|
|
||||||
for (int i = 0; i < gPhysSpritesCount; i++) {
|
|
||||||
if (gPhysSpritesList[i] == -1) continue;
|
|
||||||
|
|
||||||
else if (sprite[gPhysSpritesList[i]].sectnum < 0 || (sprite[gPhysSpritesList[i]].flags & kHitagFree) != 0)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
spritetype* pDebris = &sprite[gPhysSpritesList[i]];
|
|
||||||
if (!TestBitString(v24c, pDebris->sectnum) || !CheckProximity(pDebris, x, y, z, nSector, radius)) continue;
|
|
||||||
else debrisConcuss(nOwner, i, x, y, z, pExplodeInfo->dmgType);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
for (int p = connecthead; p >= 0; p = connectpoint2[p])
|
for (int p = connecthead; p >= 0; p = connectpoint2[p])
|
||||||
{
|
{
|
||||||
spritetype *pSprite2 = gPlayer[p].pSprite;
|
spritetype *pSprite2 = gPlayer[p].pSprite;
|
||||||
|
@ -5793,7 +5785,40 @@ void actProcessSprites(void)
|
||||||
int t = divscale16(pXSprite->data2, nDist);
|
int t = divscale16(pXSprite->data2, nDist);
|
||||||
gPlayer[p].flickerEffect += t;
|
gPlayer[p].flickerEffect += t;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef NOONE_EXTENSIONS
|
#ifdef NOONE_EXTENSIONS
|
||||||
|
if (pXSprite->data1 != 0) {
|
||||||
|
|
||||||
|
// add impulse for sprites from physics list
|
||||||
|
if (gPhysSpritesCount > 0 && pExplodeInfo->dmgType != 0) {
|
||||||
|
for (int i = 0; i < gPhysSpritesCount; i++) {
|
||||||
|
if (gPhysSpritesList[i] == -1) continue;
|
||||||
|
else if (sprite[gPhysSpritesList[i]].sectnum < 0 || (sprite[gPhysSpritesList[i]].flags & kHitagFree) != 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
spritetype* pDebris = &sprite[gPhysSpritesList[i]];
|
||||||
|
if (!TestBitString(v24c, pDebris->sectnum) || !CheckProximity(pDebris, x, y, z, nSector, radius)) continue;
|
||||||
|
else debrisConcuss(nOwner, i, x, y, z, pExplodeInfo->dmgType);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// trigger sprites from impact list
|
||||||
|
if (gImpactSpritesCount > 0) {
|
||||||
|
for (int i = 0; i < gImpactSpritesCount; i++) {
|
||||||
|
if (gImpactSpritesList[i] == -1) continue;
|
||||||
|
else if (sprite[gImpactSpritesList[i]].sectnum < 0 || (sprite[gImpactSpritesList[i]].flags & kHitagFree) != 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
spritetype* pImpact = &sprite[gImpactSpritesList[i]]; XSPRITE* pXImpact = &xsprite[pImpact->extra];
|
||||||
|
if (/*pXImpact->state == pXImpact->restState ||*/ !TestBitString(v24c, pImpact->sectnum) || !CheckProximity(pImpact, x, y, z, nSector, radius))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
trTriggerSprite(pImpact->index, pXImpact, kCmdSpriteImpact);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
if (!gModernMap || !(pSprite->flags & kModernTypeFlag1)) {
|
if (!gModernMap || !(pSprite->flags & kModernTypeFlag1)) {
|
||||||
// if data4 > 0, do not remove explosion. This can be useful when designer wants put explosion generator in map manually
|
// if data4 > 0, do not remove explosion. This can be useful when designer wants put explosion generator in map manually
|
||||||
// via sprite statnum 2.
|
// via sprite statnum 2.
|
||||||
|
|
|
@ -179,9 +179,9 @@ GENDUDEEXTRA* genDudeExtra(spritetype* pGenDude) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void genDudeUpdate(spritetype* pSprite) {
|
void genDudeUpdate(spritetype* pSprite) {
|
||||||
|
GENDUDEEXTRA* pExtra = genDudeExtra(pSprite);
|
||||||
for (int i = 0; i < kGenDudePropertyMax; i++) {
|
for (int i = 0; i < kGenDudePropertyMax; i++) {
|
||||||
if (gGenDudeExtra[pSprite->index].updReq[i])
|
if (pExtra->updReq[i]) genDudePrepare(pSprite, i);
|
||||||
genDudePrepare(pSprite, i);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1273,83 +1273,82 @@ void scaleDamage(XSPRITE* pXSprite) {
|
||||||
|
|
||||||
short curWeapon = gGenDudeExtra[sprite[pXSprite->reference].index].curWeapon;
|
short curWeapon = gGenDudeExtra[sprite[pXSprite->reference].index].curWeapon;
|
||||||
short weaponType = gGenDudeExtra[sprite[pXSprite->reference].index].weaponType;
|
short weaponType = gGenDudeExtra[sprite[pXSprite->reference].index].weaponType;
|
||||||
unsigned short* curScale = gGenDudeExtra[sprite[pXSprite->reference].index].dmgControl;
|
signed short* curScale = gGenDudeExtra[sprite[pXSprite->reference].index].dmgControl;
|
||||||
for (int i = 0; i < kDmgMax; i++)
|
for (int i = 0; i < kDmgMax; i++)
|
||||||
curScale[i] = getDudeInfo(kDudeModernCustom)->startDamage[i];
|
curScale[i] = getDudeInfo(kDudeModernCustom)->startDamage[i];
|
||||||
|
|
||||||
// all enemies with vector weapons gets extra resistance to bullet damage
|
switch (weaponType) {
|
||||||
if (weaponType == kGenDudeWeaponHitscan) {
|
// all enemies with vector weapons gets extra resistance to bullet damage
|
||||||
|
case kGenDudeWeaponHitscan:
|
||||||
curScale[kDmgBullet] -= 10;
|
curScale[kDmgBullet] -= 10;
|
||||||
|
break;
|
||||||
// just copy damage resistance of dude that should be summoned
|
// just copy damage resistance of dude that should be summoned
|
||||||
} else if (weaponType == kGenDudeWeaponSummon) {
|
case kGenDudeWeaponSummon:
|
||||||
|
for (int i = 0; i < kDmgMax; i++)
|
||||||
for (int i = 0; i < kDmgMax; i++)
|
curScale[i] = getDudeInfo(curWeapon)->startDamage[i];
|
||||||
curScale[i] = getDudeInfo(curWeapon)->startDamage[i];
|
break;
|
||||||
|
// these does not like the explosions and burning
|
||||||
// these does not like the explosions and burning
|
case kGenDudeWeaponKamikaze:
|
||||||
} else if (weaponType == kGenDudeWeaponKamikaze) {
|
curScale[kDmgBurn] = curScale[kDmgExplode] = curScale[kDmgElectric] = 1024;
|
||||||
|
break;
|
||||||
curScale[kDmgBurn] = curScale[kDmgExplode] = 512;
|
case kGenDudeWeaponMissile:
|
||||||
|
case kGenDudeWeaponThrow:
|
||||||
} else if (weaponType == kGenDudeWeaponMissile || weaponType == kGenDudeWeaponThrow) {
|
switch (curWeapon) {
|
||||||
|
case kMissileButcherKnife:
|
||||||
switch (curWeapon) {
|
curScale[kDmgBullet] = 100;
|
||||||
case kMissileButcherKnife:
|
fallthrough__;
|
||||||
curScale[kDmgBullet] = 100;
|
case kMissileEctoSkull:
|
||||||
fallthrough__;
|
curScale[kDmgSpirit] = 32;
|
||||||
case kMissileEctoSkull:
|
break;
|
||||||
curScale[kDmgSpirit] = 32;
|
case kMissileLifeLeechAltNormal:
|
||||||
break;
|
case kMissileLifeLeechAltSmall:
|
||||||
case kMissileLifeLeechAltNormal:
|
case kMissileArcGargoyle:
|
||||||
case kMissileLifeLeechAltSmall:
|
curScale[kDmgSpirit] = 32;
|
||||||
case kMissileArcGargoyle:
|
curScale[kDmgElectric] = 52;
|
||||||
curScale[kDmgSpirit] = 32;
|
break;
|
||||||
curScale[kDmgElectric] = 52;
|
case kMissileFlareRegular:
|
||||||
break;
|
case kMissileFlareAlt:
|
||||||
case kMissileFlareRegular:
|
case kMissileFlameSpray:
|
||||||
case kMissileFlareAlt:
|
case kMissileFlameHound:
|
||||||
case kMissileFlameSpray:
|
case kThingArmedSpray:
|
||||||
case kMissileFlameHound:
|
case kThingPodFireBall:
|
||||||
case kThingArmedSpray:
|
case kThingNapalmBall:
|
||||||
case kThingPodFireBall:
|
curScale[kDmgBurn] = 32;
|
||||||
case kThingNapalmBall:
|
curScale[kDmgExplode] -= 20;
|
||||||
curScale[kDmgBurn] = 32;
|
break;
|
||||||
curScale[kDmgExplode] -= 20;
|
case kMissileLifeLeechRegular:
|
||||||
break;
|
case kThingDroppedLifeLeech:
|
||||||
case kMissileLifeLeechRegular:
|
case kModernThingEnemyLifeLeech:
|
||||||
case kThingDroppedLifeLeech:
|
curScale[kDmgSpirit] = 32 + Random(18);
|
||||||
case kModernThingEnemyLifeLeech:
|
curScale[kDmgBurn] = 60 + Random(4);
|
||||||
curScale[kDmgSpirit] = 32 + Random(18);
|
for (int i = 2; i < kDmgMax; i++) {
|
||||||
curScale[kDmgBurn] = 60 + Random(4);
|
if (Chance(0x1000) && i != kDmgSpirit)
|
||||||
for (int i = 2; i < kDmgMax; i++) {
|
curScale[i] = 48 + Random(32);
|
||||||
if (Chance(0x1000) && i != kDmgSpirit)
|
}
|
||||||
curScale[i] = 48 + Random(32);
|
break;
|
||||||
}
|
case kMissileFireball:
|
||||||
break;
|
case kMissileFireballNapam:
|
||||||
case kMissileFireball:
|
case kMissileFireballCerberus:
|
||||||
case kMissileFireballNapam:
|
case kMissileFireballTchernobog:
|
||||||
case kMissileFireballCerberus:
|
curScale[kDmgBurn] = 50;
|
||||||
case kMissileFireballTchernobog:
|
curScale[kDmgExplode] = 32;
|
||||||
curScale[kDmgBurn] = 50;
|
curScale[kDmgFall] = 65 + Random(15);
|
||||||
curScale[kDmgExplode] = 32;
|
break;
|
||||||
curScale[kDmgFall] = 65 + Random(15);
|
case kThingTNTBarrel:
|
||||||
break;
|
case kThingArmedProxBomb:
|
||||||
case kThingTNTBarrel:
|
case kThingArmedRemoteBomb:
|
||||||
case kThingArmedProxBomb:
|
case kThingArmedTNTBundle:
|
||||||
case kThingArmedRemoteBomb:
|
case kThingArmedTNTStick:
|
||||||
case kThingArmedTNTBundle:
|
case kModernThingTNTProx:
|
||||||
case kThingArmedTNTStick:
|
curScale[kDmgExplode] = 32;
|
||||||
case kModernThingTNTProx:
|
curScale[kDmgFall] = 65 + Random(15);
|
||||||
curScale[kDmgExplode] = 32;
|
break;
|
||||||
curScale[kDmgFall] = 65 + Random(15);
|
case kMissileTeslaAlt:
|
||||||
break;
|
case kMissileTeslaRegular:
|
||||||
case kMissileTeslaAlt:
|
curScale[kDmgElectric] = 32 + Random(8);
|
||||||
case kMissileTeslaRegular:
|
break;
|
||||||
curScale[kDmgElectric] = 32 + Random(8);
|
}
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1395,7 +1394,6 @@ void scaleDamage(XSPRITE* pXSprite) {
|
||||||
|
|
||||||
// take surface type into account
|
// take surface type into account
|
||||||
int surfType = tileGetSurfType(sprite[pXSprite->reference].index + 0xc000);
|
int surfType = tileGetSurfType(sprite[pXSprite->reference].index + 0xc000);
|
||||||
//int surfType = 4;
|
|
||||||
switch (surfType) {
|
switch (surfType) {
|
||||||
case 1: // stone
|
case 1: // stone
|
||||||
curScale[kDmgFall] = 0;
|
curScale[kDmgFall] = 0;
|
||||||
|
@ -1944,11 +1942,11 @@ int genDudeSeqStartId(XSPRITE* pXSprite) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool genDudePrepare(spritetype* pSprite, int propId) {
|
bool genDudePrepare(spritetype* pSprite, int propId) {
|
||||||
if (!(pSprite->index >= 0 && pSprite->index < kMaxSprites)) {
|
if (!spriRangeIsFine(pSprite->index)) {
|
||||||
consoleSysMsg("pSprite->index >= 0 && pSprite->index < kMaxSprites");
|
consoleSysMsg("!spriRangeIsFine(pSprite->index)");
|
||||||
return false;
|
return false;
|
||||||
} else if (!(pSprite->extra >= 0 && pSprite->extra < kMaxXSprites)) {
|
} else if (!xspriRangeIsFine(pSprite->extra)) {
|
||||||
consoleSysMsg("pSprite->extra >= 0 && pSprite->extra < kMaxXSprites");
|
consoleSysMsg("!xspriRangeIsFine(pSprite->extra)");
|
||||||
return false;
|
return false;
|
||||||
} else if (pSprite->type != kDudeModernCustom) {
|
} else if (pSprite->type != kDudeModernCustom) {
|
||||||
consoleSysMsg("pSprite->type != kDudeModernCustom");
|
consoleSysMsg("pSprite->type != kDudeModernCustom");
|
||||||
|
@ -1974,8 +1972,8 @@ bool genDudePrepare(spritetype* pSprite, int propId) {
|
||||||
case kGenDudePropertyWeapon: {
|
case kGenDudePropertyWeapon: {
|
||||||
pExtra->curWeapon = pXSprite->data1;
|
pExtra->curWeapon = pXSprite->data1;
|
||||||
switch (pXSprite->data1) {
|
switch (pXSprite->data1) {
|
||||||
case 19: pExtra->curWeapon = 2; break;
|
case VECTOR_TYPE_19: pExtra->curWeapon = VECTOR_TYPE_2; break;
|
||||||
case 310: pExtra->curWeapon = kMissileArcGargoyle; break;
|
case kMissileUnused: pExtra->curWeapon = kMissileArcGargoyle; break;
|
||||||
case kThingDroppedLifeLeech: pExtra->curWeapon = kModernThingEnemyLifeLeech; break;
|
case kThingDroppedLifeLeech: pExtra->curWeapon = kModernThingEnemyLifeLeech; break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -156,7 +156,6 @@ extern const GENDUDESND gCustomDudeSnd[];
|
||||||
struct GENDUDEEXTRA {
|
struct GENDUDEEXTRA {
|
||||||
unsigned short initVals[3]; // xrepeat, yrepeat, clipdist
|
unsigned short initVals[3]; // xrepeat, yrepeat, clipdist
|
||||||
unsigned short availDeaths[kDamageMax]; // list of seqs with deaths for each damage type
|
unsigned short availDeaths[kDamageMax]; // list of seqs with deaths for each damage type
|
||||||
unsigned short dmgControl[kDamageMax]; // depends of current weapon, drop armor item, sprite yrepeat and surface type
|
|
||||||
unsigned int moveSpeed;
|
unsigned int moveSpeed;
|
||||||
unsigned int fireDist; // counts from sprite size
|
unsigned int fireDist; // counts from sprite size
|
||||||
unsigned int throwDist; // counts from sprite size
|
unsigned int throwDist; // counts from sprite size
|
||||||
|
@ -166,6 +165,7 @@ struct GENDUDEEXTRA {
|
||||||
unsigned short slaveCount; // how many dudes is summoned
|
unsigned short slaveCount; // how many dudes is summoned
|
||||||
signed short nLifeLeech; // spritenum of dropped dude's leech
|
signed short nLifeLeech; // spritenum of dropped dude's leech
|
||||||
signed short slave[kGenDudeMaxSlaves]; // index of the ones dude is summon
|
signed short slave[kGenDudeMaxSlaves]; // index of the ones dude is summon
|
||||||
|
signed short dmgControl[kDamageMax]; // depends of current weapon, drop armor item, sprite yrepeat and surface type
|
||||||
bool updReq[kGenDudePropertyMax]; // update requests
|
bool updReq[kGenDudePropertyMax]; // update requests
|
||||||
bool sndPlaying; // indicate if sound of AISTATE currently playing
|
bool sndPlaying; // indicate if sound of AISTATE currently playing
|
||||||
bool forcePunch; // indicate if there is no fire trigger in punch state seq
|
bool forcePunch; // indicate if there is no fire trigger in punch state seq
|
||||||
|
|
|
@ -327,6 +327,7 @@ enum {
|
||||||
kMissileEctoSkull = 307,
|
kMissileEctoSkull = 307,
|
||||||
kMissileFlameHound = 308,
|
kMissileFlameHound = 308,
|
||||||
kMissilePukeGreen = 309,
|
kMissilePukeGreen = 309,
|
||||||
|
kMissileUnused = 310,
|
||||||
kMissileArcGargoyle = 311,
|
kMissileArcGargoyle = 311,
|
||||||
kMissileFireballNapam = 312,
|
kMissileFireballNapam = 312,
|
||||||
kMissileFireballCerberus = 313,
|
kMissileFireballCerberus = 313,
|
||||||
|
|
|
@ -124,6 +124,10 @@ inline bool playerRXRngIsFine(int rx) {
|
||||||
return (rx >= kChannelPlayer0 && rx < kChannelPlayer7);
|
return (rx >= kChannelPlayer0 && rx < kChannelPlayer7);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline bool channelRangeIsFine(int channel) {
|
||||||
|
return (channel >= kChannelUser && channel < kChannelUserMax);
|
||||||
|
}
|
||||||
|
|
||||||
struct EVENT {
|
struct EVENT {
|
||||||
unsigned int index: 14; // index
|
unsigned int index: 14; // index
|
||||||
unsigned int type: 3; // type
|
unsigned int type: 3; // type
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -52,16 +52,23 @@ BEGIN_BLD_NS
|
||||||
#define kPhysDebrisExplode 0x0800 // *debris* can be affected by explosions
|
#define kPhysDebrisExplode 0x0800 // *debris* can be affected by explosions
|
||||||
|
|
||||||
// *modern types only hitag*
|
// *modern types only hitag*
|
||||||
#define kModernTypeFlag0 0x0
|
#define kModernTypeFlag0 0x0000
|
||||||
#define kModernTypeFlag1 0x1
|
#define kModernTypeFlag1 0x0001
|
||||||
#define kModernTypeFlag2 0x2
|
#define kModernTypeFlag2 0x0002
|
||||||
#define kModernTypeFlag3 0x3
|
#define kModernTypeFlag3 0x0003
|
||||||
|
#define kModernTypeFlag4 0x0004
|
||||||
|
|
||||||
#define kMaxRandomizeRetries 16
|
#define kMaxRandomizeRetries 16
|
||||||
|
|
||||||
// modern sprite types
|
// modern statnums
|
||||||
enum {
|
enum {
|
||||||
kStatModernDudeTargetChanger = 20,
|
kStatModernDudeTargetChanger = 20,
|
||||||
|
kStatModernCondition = 21,
|
||||||
|
kStatModernEventRedirector = 22,
|
||||||
|
};
|
||||||
|
|
||||||
|
// modern sprite types
|
||||||
|
enum {
|
||||||
kModernCustomDudeSpawn = 24,
|
kModernCustomDudeSpawn = 24,
|
||||||
kModernRandomTX = 25,
|
kModernRandomTX = 25,
|
||||||
kModernSequentialTX = 26,
|
kModernSequentialTX = 26,
|
||||||
|
@ -87,6 +94,7 @@ kModernThingTNTProx = 433, // detects only players
|
||||||
kModernThingThrowableRock = 434, // does small damage if hits target
|
kModernThingThrowableRock = 434, // does small damage if hits target
|
||||||
kModernThingEnemyLifeLeech = 435, // the same as normal, except it aims in specified target only
|
kModernThingEnemyLifeLeech = 435, // the same as normal, except it aims in specified target only
|
||||||
kModernPlayerControl = 500, /// WIP
|
kModernPlayerControl = 500, /// WIP
|
||||||
|
kModernCondition = 501, /// WIP, sends command only if specified conditions == true
|
||||||
kGenModernMissileUniversal = 704,
|
kGenModernMissileUniversal = 704,
|
||||||
kGenModernSound = 708,
|
kGenModernSound = 708,
|
||||||
};
|
};
|
||||||
|
@ -105,7 +113,6 @@ OBJ_SPRITE = 3,
|
||||||
OBJ_SECTOR = 6,
|
OBJ_SECTOR = 6,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
// - STRUCTS ------------------------------------------------------------------
|
// - STRUCTS ------------------------------------------------------------------
|
||||||
struct SPRITEMASS { // sprite mass info for getSpriteMassBySize();
|
struct SPRITEMASS { // sprite mass info for getSpriteMassBySize();
|
||||||
int seqId;
|
int seqId;
|
||||||
|
@ -135,6 +142,13 @@ struct VECTORINFO_EXTRA {
|
||||||
struct MISSILEINFO_EXTRA {
|
struct MISSILEINFO_EXTRA {
|
||||||
int fireSound[2]; // predefined fire sounds. used by kDudeModernCustom, but can be used for something else.
|
int fireSound[2]; // predefined fire sounds. used by kDudeModernCustom, but can be used for something else.
|
||||||
bool dmgType[kDamageMax]; // list of damages types missile can use
|
bool dmgType[kDamageMax]; // list of damages types missile can use
|
||||||
|
bool allowImpact; // allow to trigger object with Impact flag enabled with this missile
|
||||||
|
};
|
||||||
|
|
||||||
|
struct DUDEINFO_EXTRA {
|
||||||
|
bool flying; // used by kModernDudeTargetChanger (ai fight)
|
||||||
|
bool melee; // used by kModernDudeTargetChanger (ai fight)
|
||||||
|
bool annoying; // used by kModernDudeTargetChanger (ai fight)
|
||||||
};
|
};
|
||||||
|
|
||||||
struct TRPLAYERCTRL { // this one for controlling the player using triggers (movement speed, jumps and other stuff)
|
struct TRPLAYERCTRL { // this one for controlling the player using triggers (movement speed, jumps and other stuff)
|
||||||
|
@ -144,19 +158,23 @@ struct TRPLAYERCTRL { // this one for controlling the player using triggers (mov
|
||||||
// - VARIABLES ------------------------------------------------------------------
|
// - VARIABLES ------------------------------------------------------------------
|
||||||
extern bool gModernMap;
|
extern bool gModernMap;
|
||||||
extern bool gTeamsSpawnUsed;
|
extern bool gTeamsSpawnUsed;
|
||||||
|
extern bool gEventRedirectsUsed;
|
||||||
extern ZONE gStartZoneTeam1[kMaxPlayers];
|
extern ZONE gStartZoneTeam1[kMaxPlayers];
|
||||||
extern ZONE gStartZoneTeam2[kMaxPlayers];
|
extern ZONE gStartZoneTeam2[kMaxPlayers];
|
||||||
extern THINGINFO_EXTRA gThingInfoExtra[kThingMax];
|
extern THINGINFO_EXTRA gThingInfoExtra[kThingMax];
|
||||||
extern VECTORINFO_EXTRA gVectorInfoExtra[kVectorMax];
|
extern VECTORINFO_EXTRA gVectorInfoExtra[kVectorMax];
|
||||||
extern MISSILEINFO_EXTRA gMissileInfoExtra[kMissileMax];
|
extern MISSILEINFO_EXTRA gMissileInfoExtra[kMissileMax];
|
||||||
|
extern DUDEINFO_EXTRA gDudeInfoExtra[kDudeMax];
|
||||||
extern TRPLAYERCTRL gPlayerCtrl[kMaxPlayers];
|
extern TRPLAYERCTRL gPlayerCtrl[kMaxPlayers];
|
||||||
extern SPRITEMASS gSpriteMass[kMaxXSprites];
|
extern SPRITEMASS gSpriteMass[kMaxXSprites];
|
||||||
extern short gProxySpritesList[kMaxSuperXSprites];
|
extern short gProxySpritesList[kMaxSuperXSprites];
|
||||||
extern short gSightSpritesList[kMaxSuperXSprites];
|
extern short gSightSpritesList[kMaxSuperXSprites];
|
||||||
extern short gPhysSpritesList[kMaxSuperXSprites];
|
extern short gPhysSpritesList[kMaxSuperXSprites];
|
||||||
|
extern short gImpactSpritesList[kMaxSuperXSprites];
|
||||||
extern short gProxySpritesCount;
|
extern short gProxySpritesCount;
|
||||||
extern short gSightSpritesCount;
|
extern short gSightSpritesCount;
|
||||||
extern short gPhysSpritesCount;
|
extern short gPhysSpritesCount;
|
||||||
|
extern short gImpactSpritesCount;
|
||||||
|
|
||||||
// - FUNCTIONS ------------------------------------------------------------------
|
// - FUNCTIONS ------------------------------------------------------------------
|
||||||
bool nnExtEraseModernStuff(spritetype* pSprite, XSPRITE* pXSprite);
|
bool nnExtEraseModernStuff(spritetype* pSprite, XSPRITE* pXSprite);
|
||||||
|
@ -164,6 +182,7 @@ void nnExtInitModernStuff(bool bSaveLoad);
|
||||||
void nnExtProcessSuperSprites(void);
|
void nnExtProcessSuperSprites(void);
|
||||||
bool nnExtIsImmune(spritetype* pSprite, int dmgType, int minScale = 16);
|
bool nnExtIsImmune(spritetype* pSprite, int dmgType, int minScale = 16);
|
||||||
int nnExtRandom(int a, int b);
|
int nnExtRandom(int a, int b);
|
||||||
|
void nnExtResetGlobals();
|
||||||
// ------------------------------------------------------------------------- //
|
// ------------------------------------------------------------------------- //
|
||||||
spritetype* randomDropPickupObject(spritetype* pSprite, short prevItem);
|
spritetype* randomDropPickupObject(spritetype* pSprite, short prevItem);
|
||||||
spritetype* randomSpawnDude(spritetype* pSprite);
|
spritetype* randomSpawnDude(spritetype* pSprite);
|
||||||
|
@ -190,9 +209,7 @@ bool aiFightIsMeleeUnit(spritetype* pDude);
|
||||||
bool aiFightDudeIsAffected(XSPRITE* pXDude);
|
bool aiFightDudeIsAffected(XSPRITE* pXDude);
|
||||||
bool aiFightMatesHaveSameTarget(XSPRITE* pXLeader, spritetype* pTarget, int allow);
|
bool aiFightMatesHaveSameTarget(XSPRITE* pXLeader, spritetype* pTarget, int allow);
|
||||||
bool aiFightGetDudesForBattle(XSPRITE* pXSprite);
|
bool aiFightGetDudesForBattle(XSPRITE* pXSprite);
|
||||||
inline bool aiFightIsMateOf(XSPRITE* pXDude, XSPRITE* pXSprite) {
|
bool aiFightIsMateOf(XSPRITE* pXDude, XSPRITE* pXSprite);
|
||||||
return (pXDude->rxID == pXSprite->rxID);
|
|
||||||
}
|
|
||||||
void aiFightAlarmDudesInSight(spritetype* pSprite, int max);
|
void aiFightAlarmDudesInSight(spritetype* pSprite, int max);
|
||||||
void aiFightActivateDudes(int rx);
|
void aiFightActivateDudes(int rx);
|
||||||
void aiFightFreeTargets(int nSprite);
|
void aiFightFreeTargets(int nSprite);
|
||||||
|
@ -216,6 +233,10 @@ void useSectorLigthChanger(XSPRITE* pXSource, XSECTOR* pXSector);
|
||||||
void useTargetChanger(XSPRITE* pXSource, spritetype* pSprite);
|
void useTargetChanger(XSPRITE* pXSource, spritetype* pSprite);
|
||||||
void usePictureChanger(XSPRITE* pXSource, int objType, int objIndex);
|
void usePictureChanger(XSPRITE* pXSource, int objType, int objIndex);
|
||||||
void usePropertiesChanger(XSPRITE* pXSource, short objType, int objIndex);
|
void usePropertiesChanger(XSPRITE* pXSource, short objType, int objIndex);
|
||||||
|
void useSequentialTx(XSPRITE* pXSource, COMMAND_ID cmd, bool setState);
|
||||||
|
void useRandomTx(XSPRITE* pXSource, COMMAND_ID cmd, bool setState);
|
||||||
|
bool txIsRanged(XSPRITE* pXSource);
|
||||||
|
void seqTxSendCmdAll(XSPRITE* pXSource, int nIndex, COMMAND_ID cmd, bool modernSend);
|
||||||
// ------------------------------------------------------------------------- //
|
// ------------------------------------------------------------------------- //
|
||||||
void trPlayerCtrlLink(XSPRITE* pXSource, PLAYER* pPlayer);
|
void trPlayerCtrlLink(XSPRITE* pXSource, PLAYER* pPlayer);
|
||||||
void trPlayerCtrlSetRace(XSPRITE* pXSource, PLAYER* pPlayer);
|
void trPlayerCtrlSetRace(XSPRITE* pXSource, PLAYER* pPlayer);
|
||||||
|
@ -265,6 +286,8 @@ void windGenStopWindOnSectors(XSPRITE* pXSource);
|
||||||
int getSpriteMassBySize(spritetype* pSprite);
|
int getSpriteMassBySize(spritetype* pSprite);
|
||||||
bool ceilIsTooLow(spritetype* pSprite);
|
bool ceilIsTooLow(spritetype* pSprite);
|
||||||
void levelEndLevelCustom(int nLevel);
|
void levelEndLevelCustom(int nLevel);
|
||||||
|
XSPRITE* eventRedirected(int objType, int objXIndex, bool byRx);
|
||||||
|
bool pointingAt(XSPRITE* pXSource, int destType);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////
|
||||||
|
|
|
@ -2148,7 +2148,9 @@ void trInit(void)
|
||||||
case kModernRandom:
|
case kModernRandom:
|
||||||
case kModernRandom2:
|
case kModernRandom2:
|
||||||
if (!gModernMap || pXSprite->state == pXSprite->restState) break;
|
if (!gModernMap || pXSprite->state == pXSprite->restState) break;
|
||||||
else evPost(i, 3, (120 * pXSprite->busyTime) / 10, kCmdRepeat);
|
evPost(i, 3, (120 * pXSprite->busyTime) / 10, kCmdRepeat);
|
||||||
|
if (pXSprite->waitTime > 0)
|
||||||
|
evPost(i, 3, (pXSprite->waitTime * 120) / 10, pXSprite->restState ? kCmdOn : kCmdOff);
|
||||||
break;
|
break;
|
||||||
case kModernSeqSpawner:
|
case kModernSeqSpawner:
|
||||||
case kModernObjDataAccumulator:
|
case kModernObjDataAccumulator:
|
||||||
|
@ -2156,7 +2158,9 @@ void trInit(void)
|
||||||
case kModernEffectSpawner:
|
case kModernEffectSpawner:
|
||||||
case kModernWindGenerator:
|
case kModernWindGenerator:
|
||||||
if (pXSprite->state == pXSprite->restState) break;
|
if (pXSprite->state == pXSprite->restState) break;
|
||||||
else evPost(i, 3, 0, kCmdRepeat);
|
evPost(i, 3, 0, kCmdRepeat);
|
||||||
|
if (pXSprite->waitTime > 0)
|
||||||
|
evPost(i, 3, (pXSprite->waitTime * 120) / 10, pXSprite->restState ? kCmdOn : kCmdOff);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
case kGenTrigger:
|
case kGenTrigger:
|
||||||
|
|
Loading…
Reference in a new issue