Getzrange: Difference between revisions
Helixhorned (talk | contribs) created getzrange, only signature for now |
m spritebridge example |
||
(One intermediate revision by one other user not shown) | |||
Line 1: | Line 1: | ||
'''getzrange''' <x> <y> <z> <sector> ''<ceilingz>'' ''<ceilinghit>'' ''<floorz>'' ''<floorhit>'' <walldist> < | '''getzrange''' <x> <y> <z> <sector> ''<ceilingz>'' ''<ceilinghit>'' ''<floorz>'' ''<floorhit>'' <walldist> <clipmask> | ||
Given a starting point and its containing sector, calculate (1) the z coordinates of (2) the objects that would be first hit by a quadratic, floor-aligned sprite pointing parallel to the grid and having side length 2*<walldist>, when travelling in a straight line up- and downwards (respectively for <ceiling...> and <floor...>). The <clipmask> is specified in the same fashion as in [[hitscan]]. | |||
''<ceilinghit>'' and ''<floorhit>'' can take the following values:<br> | |||
* 16384 + sectnum, if a ceiling or floor was hit first<br> | |||
* 49152 + spritenum, if a sprite was hit first<br> | |||
The behaviour in corner cases (sectnum invalid, x/y/z not in sectnum, etc.) should not be relied upon. | |||
===Example: Checking for spritebridges=== | |||
The state below checks if the current actor is on a spritebridge, and if so, "returns" the id of that sprite. | |||
// assumption: relevant variables are declared | |||
defstate check_spritebridge | |||
geta[].x my_x | |||
geta[].y my_y | |||
geta[].z my_z | |||
geta[].sectnum sectnum | |||
getzrange my_x my_y my_z sectnum | |||
ceilingz | |||
ceilinghit | |||
floorz | |||
floorhit | |||
256 | |||
CLIPMASK0 | |||
set outputSpriteId -1 | |||
ifge floorhit 49152 | |||
{ | |||
sub floorhit 49152 | |||
ifvarand sprite[floorhit].cstat 32 | |||
set outputSpriteId floorhit | |||
} | |||
// outputSpriteId now contains either -1 if no spritebridge is detected, or the id of the spritebridge if there is | |||
ends |
Latest revision as of 16:45, 3 December 2020
getzrange <x> <y> <z> <sector> <ceilingz> <ceilinghit> <floorz> <floorhit> <walldist> <clipmask>
Given a starting point and its containing sector, calculate (1) the z coordinates of (2) the objects that would be first hit by a quadratic, floor-aligned sprite pointing parallel to the grid and having side length 2*<walldist>, when travelling in a straight line up- and downwards (respectively for <ceiling...> and <floor...>). The <clipmask> is specified in the same fashion as in hitscan.
<ceilinghit> and <floorhit> can take the following values:
- 16384 + sectnum, if a ceiling or floor was hit first
- 49152 + spritenum, if a sprite was hit first
The behaviour in corner cases (sectnum invalid, x/y/z not in sectnum, etc.) should not be relied upon.
Example: Checking for spritebridges
The state below checks if the current actor is on a spritebridge, and if so, "returns" the id of that sprite.
// assumption: relevant variables are declared defstate check_spritebridge geta[].x my_x geta[].y my_y geta[].z my_z geta[].sectnum sectnum getzrange my_x my_y my_z sectnum ceilingz ceilinghit floorz floorhit 256 CLIPMASK0 set outputSpriteId -1 ifge floorhit 49152 { sub floorhit 49152 ifvarand sprite[floorhit].cstat 32 set outputSpriteId floorhit } // outputSpriteId now contains either -1 if no spritebridge is detected, or the id of the spritebridge if there is ends