Enhanced Duke Nukem3D - CON guide v1-01-2000 Release 1
© RTCM Cyborg
Introduction |
Basics |
Variables and Operators |
Events |
Weapons
Sector, Sprite, Wall and Player
Structures | Miscellaneous Commands |
Index
Official EDuke Site
This guide is a bit outdated an inaccurate in places and is being totally re-rewritten. I leave this guide up because people have found it useful in the past.
Please see
eduke-con-guide2 for the work in progress of the rewrite.
Basics
First things first, all the old stuff from Duke Nukem Atomic has pretty much remained
intact (although the properties of some primitives may change later). Thus, it would be a
pretty good idea to know about the Duke Nukem Atomic CONs before you get started with
EDuke. The article I'm writing on standard CON effects will not cover this: that's an
article for experienced people who are looking to spice up their CONs. No, what you want
is a CON FAQ written for beginners. You might find the one at MapFAQ Central
a good start, I learnt all the commands pretty quickly using it.
Once you've absorbed the basics of the CON language and tried out some of the stuff in my
other article you are ready to start here.
New stuff
The new stuff added so far:
* CON additions from WWII GI,
including Events, Weapon Changes, Weapon Settings.
* Global variables and mathematical
operators
* Texture detection for floors (not
quite walls yet)
* System Variables
* Access to the tags
* Access to Sector, sprite, wall and
player structures
There are also a few other miscellaneous things like being able to change the MIDI track
and such.
Contents
Variables and operators
Usage
Syntax
Eh?
Examples
Bitstrip
Sector
height
Appendix
Gamevar
Flags
Operators
Addendum
Events
Usage
Syntax
Eh?
Examples
Event
defines
Change
load tile
Appendix
Events
Weapons
Usage
Syntax
Eh?
Examples
Change pistol clip
amount
Appendix
Weapon
properties
Addendum
Sector,
sprite, wall and player structures
Usage
Syntax
Eh?
Examples
Raise
floor
Tricolour
Appendix
Actor member properties
Sector member
properties
Wall member properties
Player member
properties
Addendum
Miscellaneous commands
Audio
commands
Texture
commands
Tag
commands
Actor/player commands
Miscellaneous commands
Index
^
Variables and operators
Useage
Variables and operators open up a whole load of new possibilities for Eduke. With previous
versions of Duke Nukem keeping track of variables for things like the score in a CTF game
required the use of inventory items or other methods. Now we can simply define a variable
for the score and do any operation with it we wish, quickly and easily.
Variables are numbers which vary. They are assigned tags so that you can keep track of
their values. Operators are devices which alter the numbers stored by a variable. The end
result of using variables and operators is to perform a mathematical function of
some sort.
How complex or how simple that is depends entirely on the programmer.
^
Syntax
gamevar <name> <value> <flag>
operatorvar <var1> <value>
operatorvarvar <var1> <var2>
^
Eh?
Gamevar tells Eduke to set up a new variable with a name and value you give it. The flag
value tells it how to use the variable. It can either be a global variable, i.e. used
everywhere, per-player, for multiplayer values etc, or per actor, for individual enemy
settings etc...
Performing an operation either occurs with a variable and a value or another variable.
They all take the form of the operator's name then var for a variable and number operation
or varvar for variable and variable operation. See the appendix for information on these
operators.
^
Examples
Here is the code to perform a 'bitstrip'. A bitstrip is a way of obtaining the values of
the individual bits of a variable which is being used as a flag. That is to say, the value
of the flag has no meaning in its decimal form, only the binary form gives us useful
information. You'll need this code later on.
Outside the actor code...
// Bitstrip - by Cyborg
gamevar BIT 0 0 // This variable is used to check the bits that are set
gamevar FLAGVAR 0 0 // The variable stores the value of the flags you are checking
In the actor code...
getactor[THISACTOR].cstat FLAGVAR // Get the cstat flag for this actor
setvar BIT 1 // Set the first bit of the variable BIT
andvarvar BIT FLAGVAR // Check to see if bit 1 is set in FLAGVAR too
ifvare BIT 1 { ...rest of code, you know that bit one is set } else { ...do something else
or... }
setvar BIT 2 // Set the second bit of the variable BIT
andvarvar BIT FLAGVAR // Check to see if bit 2 is set in FLAGVAR too
ifvare BIT 2 { ...bit 2 is set, do something } else { ...it's not set... }
setvar BIT 4 // Ser the third bit of the variable BIT
andvarvar BIT FLAGVAR // Check to see if bit 3 is set in FLAGVAR too
and so on... using values of 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384,
32768 to check all the bits of a 16 bit variable. You will not need to use all these
values for cstat however, not all the bits contain usefull informaiton.
The code above works by performing an AND operator on the variable BIT that stores the
value you want to check for. The AND function works by checking each of the bits in both
variables and the result returned will only have the bits that are set in both. In the
first line the BIT variable has bit 1 set by the decimal number 1. If the FLAGVAR variable
also has bit 1 set then on performing an AND operation the value returned for BIT will be
the same as it was before, otherwise it will be zero.
// Sector height - By Cyborg
gamevar CEILINGZ 0 2 // This is used to store the ceiling height
gamevar FLOORZ 0 2 // This will store the floor height
In the actor code...
getsector[THISACTOR].floorz FLOORZ // Get the floor height in FLOORZ
getsector[THISACTOR].ceilingz CEILINGZ // Get the ceiling height in CEILINGZ
mulvar CEILINGZ -1
addvarvar FLOORZ CEILINGZ // This will take the value of the ceilingz away from the floorz
and store the result in the variable floorz. As the ceilingz is always less than the
floorz this will produce a positive result that is the relative height of the sector.
^
Appendix
Gamevar flags
0 - Global variable
1 - Perplayer variable
2 - Peractor variable
Operators
Note that the variable that is altered is always the first one written. The second
variable for varvar operations is never altered. The argument is either a variable or a
value.
set - set the value of the variable with the argument
add - add the value of the variable with the argument
if...e - returns true if the argument is equal
if...l - returns true if the variable is less than the
argument
if...g - returns true if the variable is greater than the
argument
mul - multiplies the value of the variable with the
argument
div - divides the value of the variable with the argument
mod - gives the remainder of a division of the variable with the
argument
and - gives the result of an AND function of the variable with the
argument. An AND function checks the bits of each of the two values being compared and
the bits in the result are set only if they were set in both of the values being operated
on.
or - gives the result of an OR function of the variable with the
argument. An OR function checks the bits of each of the two values being compared and the
bits in the result are set if they were set in either of the values being operated on.
rand - gives a random number from 0 to the argument. Does not have
a varvar yet, only numbers are valid agreements.
^ Addendum
Note on System Variables:
System variables are variables which you can alter like other variables above but are not
defined by gamevar. They are used internally for several settings. The easiest way to
explain is to tell you what they are and what they do.
RESPAWN_MONSTERS, RESPAWN_ITEMS, RESPAWN_INVENTORY, MONSTERS_OFF, COOP, MARKER and FFIRE
are all variables associated with multiplay. They are the respawn times for monsters,
items and inventory, monsters on or off, co-op play or not, respawn markers on or off and
friendly fire on or off. You can change these dynamically in game. It's hard to see how
some of them may be used but there you are...
LEVEL and VOLUME refer to the current map you are playing. They cannot be altered, only
read.
TRIPBOMB_CONTROL changes the action of the tripbomb using 1 for a Trip wire (default), 2
for a timer and 3 for both (it's another flag system).
^ Events
^ Usage
Events are, well, events that happen in the game. Just read the stuff below to get an idea
of what to use them for.
^ Syntax
onevent EVENT_NAME
{ ...do something... }
endevent
^ Eh?
Basically if the event with EVENT_NAME occurs the code in the curly brackets is executed.
Many events have system variables associated with them that can alter their effects, maybe
disable an effect or change its use. Look in the appendix for the full list.
^ Examples
Before you do anything else, cut and paste this into your DEFS.CON
^
// Event value defines - By Cyborg
define EVENT_INIT 0
define EVENT_ENTERLEVEL 1
define EVENT_RESETWEAPONS 2
define EVENT_RESETINVENTORY 3
define EVENT_HOLSTER 4
define EVENT_LOOKLEFT 5
define EVENT_LOOKRIGHT 6
define EVENT_SOARUP 7
define EVENT_SOARDOWN 8
define EVENT_CROUCH 9
define EVENT_JUMP 10
define EVENT_RETURNTOCENTER 11
define EVENT_LOOKUP 12
define EVENT_LOOKDOWN 13
define EVENT_AIMUP 14
define EVENT_AIMDOWN 15
define EVENT_FIRE 16
define EVENT_CHANGEWEAPON 17
define EVENT_GETSHOTRANGE 18
define EVENT_GETAUTOAIMANGLE 19
define EVENT_GETLOADTILE 20
define EVENT_CHEATGETSTEROIDS 21
define EVENT_CHEATGETHEAT 22
define EVENT_CHEATGETBOOT 23
define EVENT_CHEATGETSHIELD 24
define EVENT_CHEATGETSCUBA 25
define EVENT_CHEATGETHOLODUKE 26
define EVENT_CHEATGETJETPACK 27
define EVENT_CHEATGETFIRSTAID 28
define EVENT_QUICKKICK 29
define EVENT_INVENTORY 30
define EVENT_USENIGHTVISION 31
define EVENT_USESTEROIDS 32
define EVENT_INVENTORYLEFT 33
define EVENT_INVENTORYRIGHT 34
define EVENT_HOLODUKEON 35
define EVENT_HOLODUKEOFF 36
define EVENT_USEMEDKIT 37
define EVENT_USEJETPACK 38
define EVENT_TURNAROUND 39
Don't like using the current load tile?
^ // Change load tile - By Cyborg
onevent EVENT_GETLOADTILE // The entry tile for a level
setvar RETURN 1 // The entry tile will be set to tile 1
endevent // That's all folks...
^ Appendix
^ Events
EVENT_INIT - called just when the game is initiated, only called
once.
EVENT_ENTERLEVEL - called upon entering a level. The system
variables LEVEL and VOLUME return the map being used.
EVENT_RESETWEAPONS - called when the player's weapons are
reset when they enter a level or die.
EVENT_RESETINVENTORY - similar to RESETWEAPONS but for
inventory instead.
EVENT_HOLSTER - the player has pressed the key for holster as
defined in the setup file. Set the system variable RETURN to zero to allow default
processing.
EVENT_LOOKLEFT - similar to HOLSTER but the player has
pressed the look left key.
EVENT_LOOKRIGHT - similar to HOLSTER but the player has
pressed the look right key.
EVENT_SOARUP - similar to HOLSTER but the player has pressed
the jump key whilst using the jetpack.
EVENT_SOARDOWN - similar to HOLSTER but the player has
pressed the crouch key whilst using the jetpack.
EVENT_CROUCH - similar to HOLSTER but the player has pressed
the crouch key.
EVENT_JUMP - similar to HOLSTER but the player has pressed the
jump key.
EVENT_RETURNTOCENTER - similar to HOLSTER but the
player has pressed the center view key.
EVENT_LOOKUP - similar to HOLSTER but the player has pressed
the look up key.
EVENT_LOOKDOWN - similar to HOLSTER but the player has
pressed the look down key.
EVENT_AIMUP - similar to HOLSTER but the player has pressed the
aim up key.
EVENT_AIMDOWN - similar to HOLSTER but the player has pressed
the aim down key.
EVENT_FIRE - called when the player has pressed the fire key. The
system variable WEAPON gives the weapon ID of the weapon being fired and the system
variable WORKSLIKE is the weapon's works like setting. See the Weapons section. Set RETURN
to zero to allow default processing.
EVENT_CHANGEWEAPON - called when the player is changing
their weapon. The system variables WEAPON and WORKSLIKE give the same results as for the
event FIRE. A value -1 means no weapon and there is no system variable RETURN.
EVENT_GETSHOTRANGE - called when the player is shooting.
Again the system variables WEAPON and WORKSLIKE act the same as for the FIRE event. The
system variables ANGRANGE and ZRANGE alter the spread of fire using polar co-ordinates.
That is an angle and a distance from the center of the shot. A ZRANGE of 0 would always
produce a shot on target. The numbers must be in powers of 2 however.
EVENT_GETAUTOAIMANGLE - called when weapon autoaim is
being used. The system variable AUTOAIMANGLE sets the aim tracking, 0 would disable it, 48
is the default.
EVENT_GETLOADTILE - the tile to be used as the loading
background. The value is set in the system variable RETURN.
EVENT_CHEATGETSTEROIDS - the player has used a cheat
to get steroids. Set RETURN to the amount of steroids to give.
EVENT_CHEATGETHEAT - the player has used a cheat to get
nightvision. Set RETURN to the amount of nightvision to give.
EVENT_CHEATGETBOOT - the player has used a cheat to get
boots. Set RETURN to the amount of boots to give.
EVENT_CHEATGETSHEILD - the player has used a cheat to
get armour. Set RETURN to the amount of armour to give.
EVENT_CHEATGETSCUBA - the player has used a cheat to get
SCUBA gear. Set RETURN to the amount of SCUBA gear to give.
^ Weapons
^ Useage
The weapon controls for Eduke have been vastly improved and gives a lot more freedom over
what you can do. I'm sure you don't need me to give you ideas about new weapons...
^ Syntax
gamevar WEAPONx_PROPERTY <value> 1
^ Eh?
Set the weapon property for weapon x with the value, x will be in the range 0-11, valid
values are variable. See the appendix for the list of properties possible.
^ Examples
How many times has it been asked to change the pistol clip amount? Well now it's simpleas:
^ // Set pistol clip amount
gamevar WEAPON1_CLIP 30 0
^ Appendix
^ Properties
SHOOTS - what the weapon shoots, i.e., what tile number.
FIREDELAY - the number of animation frames before a shot actually
takes place.
HOLDDELAY - the number of animation frames between shooting and
reloading.
TOTALTIME - delay after firing before the weapon can be refired.
SPAWN - item to spawn, like bullet shells. If zero nothing is spawned.
SPAWNTIME - the number of frames before the item is spawned.
CLIP - the amount of ammo in the weapon's clip. 0 means there is no
clip.
SHOTSPERBURST - number of shots per press of the fire button.
WORKSLIKE - how the weapon works, e.g. 9 would mean the weapon
works like a trip bomb.
INITIALSOUND - the sound made initially. 0 means nothing is
sounded.
FIRESOUND - sound made on the firing frame. 0 means nothing is
sounded.
SOUND2TIME - as used in the shotgun for reloading sound. This is
the time before it is heard.
SOUND2SOUND - sound made when SOUND2TIME is reached. 0 means
nothing is sounded.
FLAGS - controls weapon operation using a flag system. From the list
below add up all the values of the flags you want set to get the value to set FLAGS to.
1 - 'holstering' clears the current clip and gives you a fresh one.
2 - the weapon 'glows', like the shrinker and expander.
4 - automatic fire.
8 - during 'hold time' fire every frame.
16 - during 'hold time' fire every third frame.
32 - restart for automatic is 'randomized' by RND 3.
64 - uses ammo for each shot.
128 - weapon is the bomb trigger for the pipebomb.
256 - weapon use does not cause user to become 'visible'.
512 - weapon throws the shot item, like the pipebomb.
1024 - check weapon availability at 'reload' time.
2048 - player stops jumping.
^ Addendum
Most weapons work exactly the same. The pipebomb and tripbomb being the major exceptions.
The weapon display for the moment is still the same so the tile numbers and the way the
tiles are used is still the same. Certain combinations of settings may cause the program
to crash. The weapon system currently uses 'worklike' to control how the weapon works so
there is not a major change from the old weapon system there. Not all settings are
supported by all weapon 'modes'. For example, SOUND2TIME is only supported by the shotgun.
^ Sector, sprite, wall and player structures
^ Useage
With these commands you can alter a whole plethora of properties related to actors, walls,
the player and sectors. I can't possibly begin to list what can be done, instead I will
write some example code for you to try with some of the ideas I have come up with. When
the first version of Eduke is released I will have a level pack available to show off
these CONs.
^ Syntax
getthing[<var>].member <var2> setthing[<var>].member <var2>
^ Eh?
Get/set the property member for the thing with number var and place its value in var2.
Note that many of the possible .members already have CON control, whereas a few certainly
don't.
^ Examples
This example creates an actor for the first tile which will increase the floor height of
the sector with number 0 by one every game cycle.
^ // Raise floor - By Cyborg gamevar SECTOR 0 2 // Create a per actor
variable called SECTOR (first value is amount to set second is a flag to set the variable
as a per actor variable.)
gamevar PROPERTY 0 2 // Create a per actor variable called PROPERTY
useractor notenemy 0 0 // Create the useractor
getsector[SECTOR].floorz PROPERTY // Get the floor height of the sector with number set in
SECTOR and place the value in PROPERTY
addvar PROPERTY 1 // Increase the value of PROPERTY by 1, experiment with this bit to get
different effects for the sectors rate of rise. A negative fall will make it fall,
multiplying the value causes an exponential increase.
setsector[SECTOR].floorz PROPERTY // Set the floor height of the sector with number set in
SECTOR with PROPERTY
enda
Why cycle through only two colours?
^ // Tricolour - By cyborg gamevar SECTOR 0 2
gamevar PAL 1 2
define TIME 30
useractor notenemy 0 0
setsector[THISACTOR].ceilingpal PAL
setsector[THISACTOR].floorpal PAL
ifcount TIME { addvar PAL 1 } // Set the speed of colour change to TIME
ifvarg PAL 8 { setvar PAL 1 } // If the palette is green set back to blue
ifvarg PAL 2 { setvar PAL 8 } // Palette goes from blue-red-green
enda
More examples to come as I think of them... possible ones to thing about include Doom
style falling pillars that drop underwater...
^ Appendix
^ getactor/setactor .member values.
x - the x position of the actor
y - the y position of the actor
z - the z position of the actor
cstat - the properties of the actor, the same for the cstat CON
command.
picnum - the actor's texture
shade - the shade of the actor
pal - the palette of the actor
clipdist - the clipping distance of the actor
filler - un-used bytes used to pad the next member variable out to
an even alignment - Matteus.
xrepeat - the x size of the actor
yrepeat - the y size of the actor
xoffset - the x orientation of the actor texture
yoffset - the y orientation of the actor texture
sectnum - the number of the sector the actor is in
statnum - internal list that the actor is on (active, inactive,
etc). - Matteus ang - the direction the sprite faces
owner - 'owner' for actor is used to determine who shot something.
This is used to give proper credit when a pipebomb blows somebody up, for instance. -
Matteus.
xvel - the x velocity of the actor
yvel - the y velocity of the actor
zvel - the z velocity of the actor
lotag - the actor's lotag
hitag - the actor's hitag
extra - extra is used for actors to point to the offset in the
compiled code for the start of the 'actor' or 'useractor'. - Matteus.
^ getsector/setsector .member values.
wallptr - the number for the first wall, i.e. the one used for
slopes
wallnum - the number of walls in the sector
ceilingz - the height of the ceiling
floorz - the height of the floor
ceilingstat - miscellaneous information on the sector see
addendum after this section
floorstat - miscellaneous information on the sector see addendum
after this section
ceilingpicnum - the texture for the ceiling
ceilingheinum - the slope of the ceiling
ceilingshade - the shade for the ceiling
ceilingpal - the pallete for the ceiling
ceilingxpanning - the x panning for the ceiling texture
ceilingypanning - the y panning for the ceiling texture
floorpicnum - the texture for the floor
floorheinum - the slope for the floor
floorshade - the shade for the floor
floorpal - the pallete for the floor
floorxpanning - the x panning for the floor texture
floorypanning - the y panning for the floor texture
visibility - the sector visibility
filler - un-used bytes used to pad the next member variable out to
an even alignment - Matteus.
lotag - the sector lotag
hitag - the sector hitag
extra - something Silverman left open to the game programmer,
according to TerminX
^ getwall/setwall .member values.
x - the x co-ord of the first point of the wall
y - the y co-orf of the first point of the wall
point2 - the wall number that gives the second point's co-ords in
it's x and y members
nextwall - for double sided walls, the wall number assigned to the
other side, else -1
nextsector - for double sided walls, the sector number assigned
to the other side, else -1
cstat - the propeties for the wall, as with the cstat for sprites.
Note that some have no effect unless the wall is a red line wall. picnum - the texture used for the normal wall
overpicnum - the texture used for the top wall
shade - the wall shade
pal - the wall palette
xrepeat - the x size of the texture
yrepeat - the y size of the texture
xpanning - the x panning of the texture
ypanning - the y panning of the texture
lotag - the wall lotag
hitag - the wall hitag
extra - something Silverman left open to the game programmer,
according to TerminX
^ getplayer/setplayer .member values.
i - this is the player's sprite ID.
inven_icon - returns the value of the current icon for the
inventory. 0 for no graphic.
invdisptime - counter for displaying inventory icon when
pressing inventory left or right keys. It is set to 52.
shield_amount - this value stores the armor amount.
steroids_amount - this value stores the steroids amount.
jetpack_amount - this value stores the jetpack amount.
scuba_amount - this value stores the SCUBA gear amount.
airleft - player's breath amount. Used when the player does not
have scuba equipment and is underwater. Is set to 390 initially. When it reaches zero
health is taken and extra_extra8 is incremented by 32.
heat_amount - this value stores the nightvision amount.
holoduke_amount - this value stores the holoduke amount.
firstaid_amount - inventory amount of med kit.
boot_amount - boot item amount.
holoduke_on - returns a value of 2 if the holoduke is on, else
it is -1. Not a good idea to set it.
scuba_on - 1 if the scuba gear is being used, set to zero if not
in water or if scuba_amount is zero. Not a good idea to set probably.
jetpack_on - works a bit differently, value changes when it is
activated and then returns to zero. The value seems to change from 0 to 2 to 8 when
activating the jetpack.
heat_on - 1 if it's on.
hbomb_on - 1 if a hbomb is thrown and detonator is ready. If the
weapon is set to time detonate (no remote) this value remains 1.
over_shoulder_on - view mode, 1 means it's on, 0 means
it's not.
look_ang - the angle that you are looking, not facing, i.e. when
you use the lookleft or lookright keys.
ang - the angle that you are facing.
oang - the last angle you were facing. Used for interpolation of
frames. Don't alter.
actors_killed - number of monsters you have killed.
max_actors_killed - maximum number of monsters to kill.
secret_rooms - number of secrets you have found. Now we can
set secrets to things other than rooms by adding one to this value.
max_secret_rooms - maximum number of secrets to find.
player_par - the time the player has been in the level as
displayed on the end level screen.
holster_weapon - 1 if holstered. Setting it to one has the
same effect as pressing the holster key except the fact that the animation is not executed
and the gun still appears to be draw.
curr_weapon - the value of the current weapon being used.
last_weapon - the value of last weapon used. Used if you switch
to a weapon with no ammo, it will switch back to this weapon. Is set to -1 if there was no
last weapon or if weapon change was successful.
rapid_fire_hold - 0 unless you're holding fire whilst
holding a pipebomb. Nothing seems to happen when you set it.
transporter_hold - similiar to the lockplayer command,
counter for teleporter hold.
weapon_sway - value set refers to a position in the weapon's
sway pattern.
bobcounter - stores the value of weapon_sway when the sway ends
and returns its value when the swaying starts again so that the sway will continue at its
last position.
footprintpal - pallette used for current footprints.
footprintshade - set the shade of your footprints.
footprintcount - counter for the number of foot prints you
make.
crack_time - counter for knuckle cracking.
last_pissed_time - counter for the time since you last
used a toilet. Used to determine whether you get health or not when you use another.
newowner - the actor ID of the view cam being used. If none is
being used the value is -1. Setting it will force the view to the view cam with the
appropriate actor ID. If forced an attempt to move or press esc will force the camview to
the player's view. Thus if forced I would advise detecting an attempt to break the forced
view and allow a return to normal viewing.
quick_kick - appears to store the information on whether a quick
kick is being executed or not.
cheat_phase - 0 is none is happening, -1 when you press M, 1
when you press S and the rest of the cheat code and then back to 0. M and S are the
current cheat keys. They were DN in other Duke Nukem versions.
somethingonplayer - 0 when a slimer is on you, -1 when
not.
on_ground - 1 if you are on ground, 0 if you are not.
on_crane - -1 if you're not on a crane, 1 if you are: setting the
value to 1 will lock the player like they are on a crane.
jumping_toggle - 1 if you are jumping, 0 if you are not.
jumping_counter - counts the lenght of time the player has
been jumping.
cursectnum - the sector the player is in.
spritebridge - gives 1 if you are on a floor flattened sprite.
zoom - the map view zoom, starts at 768, minimum is 48, maximum is
2048.
exitx - set to the wall x aof the sector that contains a lotag of -1(65535). Is not used by the code however.
exity - set to the wall y of the sector that contains a lotag of -1
(65535). Is not used by the code however.
loogiex[64] - lizard spit random x position on the screen.
Currently not accessible.
loogiey[64] - lizard spit random y position on the screen.
Currently not accessible.
numloogs - is set to 3 a random amount from 0 to 8 to give the
number of lizard spits shown. The tile displayed is given by the LOOGIE tile.
loogcnt - is set to 96. Is the counter for the spits display.
posx - the player's x position.
posy - the player's y position.
posz - the player's z position.
oposx - the player's old x position. Used for interpolation of
frames. Don't alter.
oposy - the player's old y position. Used for interpolation of
frames. Don't alter.
oposz - the player's old z position. Used for interpolation of
frames. Don't alter.
horiz - the player's look up or down value. Added to horizoff to give
the player's view.
horizoff - the look up or down value based on the slope of a
sector.
ohoriz - holds old view vlaue. Used for interpolation of frames.
Don't alter.
ohorizoff - holds old view vlaue. Used for interpolation of
frames. Don't alter.
bobposx - relates to circular motion of a rotating sector. Used to
calculate the velocity the player should be moving around the circle.
bobposy - relates to circular motion of a rotating sector. Used to
calculate the velocity the player should be moving around the circle.
truefz - the z value of the floor. This is also modified by a SE
with a lotag of 17, elevator transport.
truecz - the z value of the ceiling. This is also modified by a SE
with a lotag of 17, elevator transport.
visibility - visibility of the player. If the player is near an
explosion, it is set to -127 (negative max). Weapons without the NOVISIBLE flag set this
to zero. Nothing uses this value in Duke which suggests it is a dormant feature. Probably
associated with how visible you are to enemies.
*palette - pointer to the palette offset in the memory.
posxv - Untested/unknown at this time.
posyv - Untested/unknown at this time.
poszv - Untested/unknown at this time.
randomflamex - Unused. Feel free to do anything with it.
weapon_ang - It used as a negative offset from the weapon
position display. It is not set by any other code. It appears to be a false attempt at
weapon-bob that never got used or removed.
refresh_inventory - refresh_inventory is initialized to
zero when a map is loaded. If set to non-zero, then a 'inventoryleft' is performed once
and refresh_inventory is reset to zero.
angvel - Untested/unknown at this time.
wackedbyactor - This is a spriteID. This stores which actor
killed the player. It is initialized to -1 when a map is loaded and on resetplayer
frag_ps - the player ID of the player that killed the current
player. Initially this is set to the current player's own ID.
frag - the number of frags the player has.
fraggedself - the number of suicides the player has.
pals_time - Given by the first number in the PALFROM command.
Counter for the length of time screen flashes last.
pals[3] - Pals[0-2] give the RED GREEN and BLUE values for
palette flashes.
last_full_weapon - initially 0, is set to the weapon ID of
the previous weapon when a new weapon is picked up.
subweapon - this flag is set if the last_full_weapon was the
shrinker otherwise it is zero. This determines whether the expander is being used or not.
show_empty_weapon - counter set to 32 when a new weapon
is picked up.
on_warping_sector - initially zero it is set to 1 by a
transporter sector effector, it is reset to zero when processed.
ammo_amount[MAX_WEAPONS] - Specify the ammo
amounts for each weapon. Currently inaccessible.
gotweapon[MAX_WEAPONS] - Specify whether tCurrently
inaccessible.
extra - extra contains the player's health.
last_extra - last_extra contains the previous value of extra.
tipincs - counter for the tip animation. It is set to 26 by the tip
command and executes the tip animation when non-zero.
wantweaponfire - set to the ID of the weapon that is being
selected.
hurt_delay - provides a delay for items that automatically hurt
the player. CACTUS: set to 16. Delay until 8. Set, but don't delay FORCEFIELD: 16,
BIGFORCE: 26.
hbomb_hold_delay - this is used for display purposes. It
is > 0 when the player is throwing a pipe bomb. it sequences through the animation and
then is reset to zero.
knee_incs - This is used to control sequencing of the knee
animation (mighty foot) (max value for animations is 11)This is a non-zero count-up timer
(if set to non-zero, it counts up). It is reset to zero after is reachces 15
access_incs - similar to tip_incs, this is used to sequence the
key-card access display. access_incs is a non-zero count-up timer. Max value is 20. When
'using' a wall or sprite that needs access, it checks to see if the player has the correct
access card and then starts the access animation by setting access_incs to one. It also
sets the access_walnum or access_spritenum to itself. For sprites, the access card
animation takes on the palette of the 'target' access sprite. got_access bits are UN-set
for the access after it is granted:(pal0, bit 0) (Pal21, Bit 2) (Pal23, Bit 3).
access_wallnum - see access_incs.
access_spritenum - see access_incs.
fta - count-down timer for the time to display a quote.
ftq - the quote to display.
kickback_pic - Untested/unknown at this time.
got_access - Untested/unknown at this time.
one_parallax_sectnum - For SE with a lotag of 13, the
sector's ceilingpicnum and ceilingshade is set to this sector's ceilingpic and
ceilingshade. This only comes from playerID of zero. This is set for player 0 only when a
level is loaded to the first sector found with ceilingstat with bit 0 set.
random_club_frame - This is initialized to zero. The
comment in the code says 'Glowing'.... For WW2GI, this is incremented by 64 each frame if
the current has the WEAPON_FLAG_GLOWS flag. Also, if it's not zero, you can't fire the
shotgun (I don't know why...) When the shrinker or grower are dispalyed on the screen,
tile SHRINKER +2 is drawn using this as a modifier, then the normal weapon is drawn.
fist_incs - This is a non-zero count-up timer. This is used to
sequence display of the FIST tile on the screen. It holds at 32 Set to 1 to start
animation of fist.
one_eighty_count - If one_eighty_count is less than zero,
then 128 is added to one_eighty_count and ang. (this lets the player turn a set angle over
time...) This is set on key TURNAROUND to -1024. To completely emulate what is being done
during EVENT_TURNAROUND, just set one_eighty_count to -1024.
dummyplayersprite - When going underwater, a
dummyplayersprite of PLAYERUNDERWATER is spawned. This sprite ID is tracked in dummy
player sprite. This sprite is made to follow the player's position. The sprite is killed
when the player moves back out of water.
extra_extra8 - This is initialized to zero. The player is
given this amount of damage divded by 256 (shift right by 8). If no actual damage is done,
then the value is not cleared. The actual damage applied to the player is modified by
shield_amount
actorsqu - This is initialized to -1. Actor Squished... This is
the actor that you are stepping on when they are shrunk. When knee_incs is > 0 then the
player is made to face the squishee The actor is actually killed when knee_incs reaches
>15 In multiplayer, you auto-squish other players who are shrunk. This is done by
setting knee_incs = 1; weapon_pos = -1; actorsqu = ps[otherp].i; This is also set by the
CON command pstomp .
timebeforeexit - This is a non-zero count-down timer. At
26*5, all sounds are stopped and the customexitsound is played if it is > 0. If
customexitsound, quote 102 is displayed. At one, all players are set to end of level mode
(.gm) (MODE_EOL) and the next level number is set... Hmm.. Fun stuff could happen here if
I hade an event...
customexitsound - Untested/unknown at this time. weaprecs[16] - These have something to do with picking up a
(active?) handbomb sprite only once... It's used (only used and set) by the CON command
ifgetweaponce (so [16] should actually be [MAXWEAPONS]...)
weapreccnt - Untested/unknown at this time.
interface_toggle_flag - This is used to dis-allow
commands from being processed when the menus are up. (or something) Set to zero it allows
normal processing. Set to 1, it disables processing. It seems to be set when a multiplayer
game is starting. More research needed...
rotscrnang - This controls the angle warping of the screen. To
emulate LOOKLEFT, subtract 152 from look_ang add 24 to rotscrnang
dead_flag - This is initalized to zero. This is used to control
one-time processing when player dies. When health (extra) is < 0, then dead_flag is
checked and then set.
pycount - pycount is used to modify pyoff. It is an increasing
angle that is used to get sin for use in pyoff (resulting in a bobbing effect). It's
incremented by 32 or 52 if the jetpack isn't on, etc...
pyoff - see pycount.
opyoff - stores old pyoff values for interpolation. Do not alter.
weapon_pos - weapon_pos is used to control display placement and
sequencing. When set to -9, it stops counting and checks for reseting last weapon when set
to any other non-zero value, it is decrmented until it reaches zero or -9 It's also used
when placing the weapon tile(s) on the screen for raising and lowering of the weapon(s)
gm -GameMode. Valid values are MODE_MENU 1 Menu is being dispalyed
MODE_DEMO 2 Demo is being played back MODE_GAME 4 Game is running MODE_EOL 8 End of Level
has been signaled MODE_TYPE 16 User is typing chat message MODE_RESTART 32 Level is
restarting MODE_SENDTOWHOM 64 Choosing who to send message to MODE_END 128 Game is
ending(exit main game loop)
name[32] - This was probably meant to be the player's name, but
it's not used.
buttonpalette - This saves the palette of the hit NUKEBUTTON.
It's used when fist_incs reaches 42 and the next level is calculated.
lastrandomspot - This is initialized to zero and is not
used.
toggle_key_flag - This seems to be used for 'hitting'
things with the space key. Cameras and queue balls..
knuckle_incs - Initialized to one. This is used for animating
the knuckle cracks. If it is 10 and the game has been going for a while
(totalclock>1024), then knuckle cracking is started. When it reaches 22, or when a
weapon is fired, it resets to zero. .
select_dir - This is not used and is not initialized.
walking_snd_toggle - This is initialized to zero. It is
a non-zero count-down timer This is used to delay making walking sounds to that they occur
every 'other' frame.
palookup - This seems to be used as a pal when the sector doesn'thave a pal set... Hmm. This is the player's 'color'/'team'?. When a level is loaded, it is
set to the pal of the player sprite for that player if it is non-zero. If sprite's pal is
zero, then it increments from 9 to 16 and back again.
hard_landing - This is a non-zero count-down timer. When the
player lands on ground with a large velocity, hard_landing is set with the velocity. This
causes the display to 'bounce' down as if in a hard landing on the ground.
fire_flag - Untested/unknown at this time.
^ Addendum
Note on [THISACTOR]:
A very useful little flag, this will get the .member value for the current actor or the
sector which the actor is in.
It's use is very simple, getactor[THISACTOR].x XPOS, will get the current actor's X
position. getsector[THISACTOR].floorz FLOOR is a faster way of writing:
getactor[THISACTOR].sectnum SECTOR
getsector[SECTOR].floorz FLOORZ
Which would have the same effect.
Note on floorstat/ceilingstat:
bit 0: 1 = parallaxing, 0 = not
bit 1: 1 = sloped, 0 = not
bit 2: 1 = swap x&y, 0 = not
bit 3: 1 = double smooshiness, i.e. change the size of the floor textures
bit 4: 1 = x-flip
bit 5: 1 = y-flip
bit 6: 1 = Align texture to first wall of sector
bits 7-15: reserved
Thus the numbers stored in the stat's are binary flags. To read them you'll need to do a
'bitstrip', which is mentioned in the variables section.
^ Miscellaneous commands
^ Audio commands:
ifsound <sound> - returns true if the current sound with
number given by <sound> is playing.
starttrack <value> - start the midi track with the number
value defined sequentially by the music command.
^ Texture commands:
gettexturefloor - get the current sector's floor texture in
the variable TEXTURE
gettextureceiling - get the current sector's ceiling
texture in the variable TEXTURE
gettexturewall - not yet implemented
Note :- these commands are achieveable using member structures.
^ lowtag/httag commands:
spgetlotag - get the current actor's lotag in the variable LOTAG
spgethitag - get the current actor's hitag in the variable HITAG
sectgetlotag - get the current sector's lotag in the variable
LOTAG sectgethitag - get the current sector's hitag in the variable
HITAG
Note: these commands are achieveable using member structures.
^ Actor/player commands:
getplayerangle <var> - get the player's current angle
in the variable var
setplayerangle <var> - set the player's current angle
with the variable var
lockplayer <var> - lock the player's movement for a count
of var.
getangletotarget <var> - get the angle to face the
nearest or current player in the variable var
setactorangle <var> - set the actor's angle with the
variable var
getactorangle <var> - get the actor's angle in the variable var
espawn <value> - works like spawn but the actor's ID is placed
in the variable RETURN
findnearactor <type> <maxdist> <var> - finds
the actor of type (e.g. PIGCOP) within the maximum distance defined and returns its actor
ID into var. If none are found the value of the variable will be -1. Only works in current
sector.
findnearactorvar <type> <var1> <var2> -similar to findnearactor but the distance to look is given by var1.
setactorvar[<actorID>].<avar> <var> - for the
actor with the actorID set the per actor variable avar with the variable var.
getactorvar[<actorID>].<avar> <var> - for the
actor with the actorID get the per actor variable avar into the variable var.
^ Miscellaneous commands:
enhance <value> - compares value with the current build
version of Eduke. If the value given is greater than the current build number the user is
instructed to update their executable file. Placed right at the start of the executable
code. This is used so any released cons know which exe version they will work with.
^ Index
Primitives
[get/set]actor
[get/set]sector
[get/set]wall
addvar
andvar
divvar
endevent
enhance
espawn
findnearactor
findnearactorvar
gamevar
getactorvar
getangletotarget
getplayerangle
gettextureceiling
gettexturefloor
gettexturewall
ifsound
ifvare
ifvarg
ifvarl
lockplayer
modvar
mulvar
onevent
orvar
randvar
sectgetlotag
sectgethitag
setactorvar
setactorangle
setplayerangle
setvar
spgethitag
spgetlotag
starttrack
Events
EVENT_INIT
EVENT_ENTERLEVEL
EVENT_RESETWEAPONS
EVENT_RESETINVENTORY
EVENT_HOLSTER
EVENT_LOOKLEFT
EVENT_LOOKRIGHT
EVENT_SOARUP
EVENT_SOARDOWN
EVENT_CROUCH
EVENT_JUMP
EVENT_RETURNTOCENTER
EVENT_LOOKUP
EVENT_LOOKDOWN
EVENT_AIMUP
EVENT_AIMDOWN
EVENT_FIRE
EVENT_CHANGEWEAPON
EVENT_GETSHOTRANGE
EVENT_GETAUTOAIMANGLE
EVENT_GETLOADTILE
EVENT_CHEATGETSTEROIDS
EVENT_CHEATGETHEAT
EVENT_CHEATGETBOOT
EVENT_CHEATGETSHEILD
EVENT_CHEATGETSCUBA
Weapon properties
SHOOTS
FIREDELAY
HOLDDELAY
TOTALTIME
SPAWN
SPAWNTIME
CLIP
SHOTSPERBURST
WORKSLIKE
INITIALSOUND
FIRESOUND
SOUND2TIME
SOUND2SOUND
FLAGS
Actor members
x
y
z
cstat
picnum
shade
pal
clipdist
filler
xrepeat
yrepeat
xoffset
yoffset
sectnum
statnum
ang
owner
xvel
yvel
zvel
lotag
hitag
extra
Sector members
wallptr
wallnum
ceilingz
floorz
ceilingstat
floorstat
ceilingpicnum
ceilingheinum
ceilingshade
ceilingpal
ceilingxpanning
ceilingypanning
floorpicnum
floorheinum
floorshade
floorpal
floorxpanning
floorypanning
visibility
filler
lotag
hitag
extra
Wall members
x
y
point2
nextwall
nextsector
cstat
picnum
overpicnum
shade
pal
xrepeat
yrepeat
xpanning
ypanning
lotag
hitag
extra
Player members
shield_amount
steroids_amount
jetpack_amount
scuba_amount
heat_amount
holoduke_amount
look_ang
ang
last_pissed_time
weapon_sway
bobcounter
curr_weapon
last_weapon
newowner
quick_kick
holoduke_on
actors_killed
max_actors_killed
secret_rooms
max_secret_room
holster_weapon
scuba_on
jetpack_on
heat_on
hbomb_on
footprintpal
transporter_hold
inven_icon
cheat_phase
somethingonplayer
on_ground
footprintshade
on_crane
firstaid_amount
rapid_fire_hold
jumping_toggle
footprintcount
jumping_counter
boot_amount
cursectnum
crack_time
spritebridge
over_shoulder_on
zoom
exitx
exity
loogiex[64]
loogiey[64]
numloogs
loogcnt
posx
posy
posz
horiz
ohoriz
ohorizoff
invdisptime
bobposx
bobposy
oposx
oposy
oposz
pyoff
opyoff
osxv
posyv
poszv
truefz
truecz
player_par
visibility
pals_time
randomflamex
weapon_ang
refresh_inventory
angvel
wackedbyactor
frag
fraggedself
last_full_weapon
on_warping_sector
ammo_amount[MAX_WEAPONS]
gotweapon[MAX_WEAPONS]
oang
last_extra
subweapon
tipincs
horizoff
wantweaponfire
hurt_delay
bomb_hold_delay
airleft
knee_incs
access_incs
fta
ftq
access_wallnum
access_spritenum
kickback_pic
got_access
i
one_parallax_sectnum
random_club_frame
fist_incs
one_eighty_count
dummyplayersprite
extra_extra8
extra
actorsqu
timebeforeexit
customexitsound
weaprecs[16]
weapreccnt
interface_toggle_flag
rotscrnang
dead_flag
show_empty_weapon
pycount
weapon_pos
frag_ps
gm
name[32]
buttonpalette
lastrandomspot
*palette
toggle_key_flag
knuckle_incs
select_dir
walking_snd_toggle
palookup
hard_landing
/*fire_flag
*/pals[3]
Copyright © 2000 James Hollidge
|