mirror of
https://github.com/ZDoom/Raze.git
synced 2025-01-18 22:51:50 +00:00
- fixed last commit
This commit is contained in:
parent
f433c6ee11
commit
86082d4c10
5 changed files with 19 additions and 23 deletions
|
@ -919,7 +919,7 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
|
|||
pXSprite->waitTime = bitReader.readUnsigned(12);
|
||||
pXSprite->restState = bitReader.readUnsigned(1);
|
||||
pXSprite->Interrutable = bitReader.readUnsigned(1);
|
||||
bitReader.readUnsigned(2);
|
||||
pXSprite->unused1 = bitReader.readUnsigned(2);
|
||||
pXSprite->respawnPending = bitReader.readUnsigned(2);
|
||||
pXSprite->unused2 = bitReader.readUnsigned(1);
|
||||
pXSprite->lT = bitReader.readUnsigned(1);
|
||||
|
|
|
@ -131,6 +131,7 @@ struct XSPRITE {
|
|||
uint8_t lSkill; // Launch 12345
|
||||
uint8_t lockMsg; // Lock msg
|
||||
int8_t dodgeDir; // Dude dodge direction
|
||||
uint8_t unused1; // modern flags
|
||||
|
||||
};
|
||||
|
||||
|
|
|
@ -567,6 +567,7 @@ FSerializer& Serialize(FSerializer& arc, const char* keyname, XSPRITE& w, XSPRIT
|
|||
("lskill", w.lSkill, def->lSkill)
|
||||
("lockmsg", w.lockMsg, def->lockMsg)
|
||||
("dodgedir", w.dodgeDir, def->dodgeDir)
|
||||
("modernflags", w.unused1, def->unused1)
|
||||
.EndObject();
|
||||
}
|
||||
return arc;
|
||||
|
|
|
@ -991,10 +991,10 @@ void nnExtProcessSuperSprites() {
|
|||
if ((gSpriteHit[pPlayer->pSprite->extra].hit & 0xc000) == 0xc000 && (gSpriteHit[pPlayer->pSprite->extra].hit & 0x3fff) == idx) {
|
||||
|
||||
int nSpeed = approxDist(xvel[pPlayer->pSprite->index], yvel[pPlayer->pSprite->index]);
|
||||
nSpeed = ClipLow(nSpeed - mulscale(nSpeed, mass, 6), 0x9000 - (mass << 3));
|
||||
nSpeed = ClipLow(nSpeed - MulScale(nSpeed, mass, 6), 0x9000 - (mass << 3));
|
||||
|
||||
xvel[idx] += mulscale30(nSpeed, Cos(pPlayer->pSprite->ang));
|
||||
yvel[idx] += mulscale30(nSpeed, Sin(pPlayer->pSprite->ang));
|
||||
xvel[idx] += MulScale(nSpeed, Cos(pPlayer->pSprite->ang), 30);
|
||||
yvel[idx] += MulScale(nSpeed, Sin(pPlayer->pSprite->ang), 30);
|
||||
|
||||
gSpriteHit[pDebris->extra].hit = pPlayer->pSprite->index | 0xc000;
|
||||
|
||||
|
@ -1208,10 +1208,10 @@ void debrisBubble(int nSprite) {
|
|||
GetSpriteExtents(pSprite, &top, &bottom);
|
||||
for (int i = 0; i < 1 + Random(5); i++) {
|
||||
|
||||
int nDist = (pSprite->xrepeat * (tilesiz[pSprite->picnum].x >> 1)) >> 2;
|
||||
int nDist = (pSprite->xrepeat * (tileWidth(pSprite->picnum) >> 1)) >> 2;
|
||||
int nAngle = Random(2048);
|
||||
int x = pSprite->x + mulscale30(nDist, Cos(nAngle));
|
||||
int y = pSprite->y + mulscale30(nDist, Sin(nAngle));
|
||||
int x = pSprite->x + MulScale(nDist, Cos(nAngle), 30);
|
||||
int y = pSprite->y + MulScale(nDist, Sin(nAngle), 30);
|
||||
int z = bottom - Random(bottom - top);
|
||||
spritetype* pFX = gFX.fxSpawn((FX_ID)(FX_23 + Random(3)), pSprite->sectnum, x, y, z, 0);
|
||||
if (pFX) {
|
||||
|
@ -1312,7 +1312,7 @@ void debrisMove(int listIndex) {
|
|||
|
||||
if (gLowerLink[nSector] >= 0) cz += (cz < 0) ? 0x500 : -0x500;
|
||||
if (top > cz && (!(pXDebris->physAttr & kPhysDebrisFloat) || fz <= bottom << 2))
|
||||
zvel[nSprite] -= divscale8((bottom - ceilZ) >> 6, mass);
|
||||
zvel[nSprite] -= DivScale((bottom - ceilZ) >> 6, mass, 8);
|
||||
|
||||
if (fz < bottom)
|
||||
vc = 58254 + ((bottom - fz) * -80099) / div;
|
||||
|
@ -1378,7 +1378,7 @@ void debrisMove(int listIndex) {
|
|||
if ((pFX2 = gFX.fxSpawn(FX_14, pFX->sectnum, pFX->x, pFX->y, pFX->z, 0)) == NULL) continue;
|
||||
xvel[pFX2->index] = Random2(0x6aaaa);
|
||||
yvel[pFX2->index] = Random2(0x6aaaa);
|
||||
zvel[pFX2->index] = -Random(0xd5555);
|
||||
zvel[pFX2->index] = -(int)Random(0xd5555);
|
||||
}
|
||||
break;
|
||||
case kSurfWater:
|
||||
|
@ -1405,7 +1405,7 @@ void debrisMove(int listIndex) {
|
|||
gSpriteHit[nXSprite].ceilhit = moveHit = ceilHit;
|
||||
pSprite->z += ClipLow(ceilZ - top, 0);
|
||||
if (zvel[nSprite] <= 0 && (pXDebris->physAttr & kPhysFalling))
|
||||
zvel[nSprite] = MulScale(-zvel[nSprite], 0x2000);
|
||||
zvel[nSprite] = MulScale(-zvel[nSprite], 0x2000, 16);
|
||||
|
||||
} else {
|
||||
|
||||
|
@ -3443,6 +3443,7 @@ bool condCheckSprite(XSPRITE* pXCond, int cmpOp, bool PUSH) {
|
|||
|
||||
spritetype* pSpr = &sprite[objIndex];
|
||||
XSPRITE* pXSpr = (xspriRangeIsFine(pSpr->extra)) ? &xsprite[pSpr->extra] : NULL;
|
||||
DBloodActor* spractor = &bloodActors[pXSpr->reference];
|
||||
|
||||
if (cond < (kCondRange >> 1)) {
|
||||
switch (cond) {
|
||||
|
@ -3487,7 +3488,7 @@ bool condCheckSprite(XSPRITE* pXCond, int cmpOp, bool PUSH) {
|
|||
if ((pPlayer = getPlayerById(pSpr->type)) != NULL)
|
||||
var = HitScan(pSpr, pPlayer->zWeapon - pSpr->z, pPlayer->aim.dx, pPlayer->aim.dy, pPlayer->aim.dz, arg1, arg3 << 1);
|
||||
else if (IsDudeSprite(pSpr))
|
||||
var = HitScan(pSpr, pSpr->z, Cos(pSpr->ang) >> 16, Sin(pSpr->ang) >> 16, (!xspriRangeIsFine(pSpr->extra)) ? 0 : gDudeSlope[pSpr->extra], arg1, arg3 << 1);
|
||||
var = HitScan(pSpr, pSpr->z, Cos(pSpr->ang) >> 16, Sin(pSpr->ang) >> 16, (!xspriRangeIsFine(pSpr->extra)) ? 0 : spractor->dudeSlope, arg1, arg3 << 1);
|
||||
else if (var2 & CSTAT_SPRITE_ALIGNMENT_FLOOR) {
|
||||
|
||||
if (var3 == 0) {
|
||||
|
@ -4132,7 +4133,7 @@ void sectorContinueMotion(int nSector, EVENT event) {
|
|||
|
||||
if (!xsectRangeIsFine(sector[nSector].extra)) return;
|
||||
else if (gBusyCount >= kMaxBusyCount) {
|
||||
consoleSysMsg("Failed to continue motion for sector #%d. Max (%d) busy objects count reached!", nSector, kMaxBusyCount);
|
||||
Printf(PRINT_HIGH, "Failed to continue motion for sector #%d. Max (%d) busy objects count reached!", nSector, kMaxBusyCount);
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
|
@ -49,19 +49,12 @@ enum
|
|||
kMaxTracedObjects = 32, // per one tracking condition
|
||||
|
||||
// additional physics attributes for debris sprites
|
||||
kPhysDebrisFly = 0x0008, // *debris* affected by negative gravity (fly instead of falling, DO NOT mess with kHitagAutoAim)
|
||||
kPhysDebrisSwim = 0x0016, // *debris* can swim underwater (instead of drowning)
|
||||
kPhysDebrisFloat = 0x0008, // *debris* slowly goes up and down from it's position
|
||||
kPhysDebrisFly = 0x0010, // *debris* affected by negative gravity (fly instead of falling)
|
||||
kPhysDebrisSwim = 0x0020, // *debris* can swim underwater (instead of drowning)
|
||||
kPhysDebrisTouch = 0x0040, // *debris* can be moved via touch
|
||||
kPhysDebrisVector = 0x0400, // *debris* can be affected by vector weapons
|
||||
kPhysDebrisExplode = 0x0800, // *debris* can be affected by explosions
|
||||
/*
|
||||
// additional physics attributes for debris sprites
|
||||
#define kPhysDebrisFloat 0x0008 // *debris* slowly goes up and down from it's position
|
||||
#define kPhysDebrisFly 0x0010 // *debris* affected by negative gravity (fly instead of falling)
|
||||
#define kPhysDebrisSwim 0x0020 // *debris* can swim underwater (instead of drowning)
|
||||
#define kPhysDebrisTouch 0x0040 // *debris* can be moved via touch
|
||||
//#define kPhysDebrisPush 0x0080 // *debris* can be moved via push
|
||||
#define kPhysDebrisVector 0x0400 // *debris* can be affected by vector weapons
|
||||
*/
|
||||
|
||||
// *modern types only hitag*
|
||||
kModernTypeFlag0 = 0x0000,
|
||||
|
|
Loading…
Reference in a new issue