From 06914b1d6352ecd11be56885f8c2db552ca31781 Mon Sep 17 00:00:00 2001 From: Mircea Kitsune Date: Mon, 3 May 2010 17:21:40 +0300 Subject: [PATCH] Remove test map and fix one last comment. entities.def moved to its own branch. To be merged with the branch with the same name in xonotic-maps.pk3dir --- maps/gravity_test.bsp | Bin 564808 -> 0 bytes maps/gravity_test.map | 108 --- qcsrc/server/g_triggers.qc | 2 + scripts/entities.def | 1786 ------------------------------------ 4 files changed, 2 insertions(+), 1894 deletions(-) delete mode 100644 maps/gravity_test.bsp delete mode 100644 maps/gravity_test.map delete mode 100644 scripts/entities.def diff --git a/maps/gravity_test.bsp b/maps/gravity_test.bsp deleted file mode 100644 index bf3838ffee56d2393931d85851de10092ef287d6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 564808 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 diff --git a/maps/gravity_test.map b/maps/gravity_test.map deleted file mode 100644 index 75b5f22a6..000000000 --- a/maps/gravity_test.map +++ /dev/null @@ -1,108 +0,0 @@ - -// entity 0 -{ -"classname" "worldspawn" -// brush 0 -{ -( 256 256 256 ) ( 256 -256 256 ) ( -256 256 256 ) trak5/base1b 0 0 0 0.5 0.5 0 0 0 -( 256 512 256 ) ( -256 512 256 ) ( 256 512 0 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 512 256 256 ) ( 512 256 0 ) ( 512 -256 256 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -256 -256 0 ) ( 256 -256 0 ) ( -256 256 0 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -256 -512 0 ) ( -256 -512 256 ) ( 256 -512 0 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -512 -256 0 ) ( -512 256 0 ) ( -512 -256 256 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -} -// brush 1 -{ -( -512 256 512 ) ( -512 -256 512 ) ( -512 256 1024 ) trak5/wall6a 0 0 0 1 1 0 0 0 -( -512 512 512 ) ( -512 512 1024 ) ( -768 512 512 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -512 256 256 ) ( -768 256 256 ) ( -512 -256 256 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -768 -256 1024 ) ( -768 -256 512 ) ( -768 256 1024 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -768 -512 1024 ) ( -512 -512 1024 ) ( -768 -512 512 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -768 -256 1280 ) ( -768 256 1280 ) ( -512 -256 1280 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -} -// brush 2 -{ -( 768 256 512 ) ( 768 -256 512 ) ( 768 256 1024 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 768 512 512 ) ( 768 512 1024 ) ( 512 512 512 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 768 256 256 ) ( 512 256 256 ) ( 768 -256 256 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 512 -256 1024 ) ( 512 -256 512 ) ( 512 256 1024 ) trak5/wall6a 0 0 0 1 1 0 0 0 -( 512 -512 1024 ) ( 768 -512 1024 ) ( 512 -512 512 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 512 -256 1280 ) ( 512 256 1280 ) ( 768 -256 1280 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -} -// brush 3 -{ -( -256 -512 512 ) ( 256 -512 512 ) ( -256 -512 1024 ) trak5/wall6a 0 0 0 1 1 0 0 0 -( -512 -512 512 ) ( -512 -512 1024 ) ( -512 -768 512 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -256 -512 256 ) ( -256 -768 256 ) ( 256 -512 256 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 256 -768 1024 ) ( 256 -768 512 ) ( -256 -768 1024 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 512 -768 1024 ) ( 512 -512 1024 ) ( 512 -768 512 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 256 -768 1280 ) ( -256 -768 1280 ) ( 256 -512 1280 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -} -// brush 4 -{ -( -256 768 512 ) ( 256 768 512 ) ( -256 768 1024 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -512 768 512 ) ( -512 768 1024 ) ( -512 512 512 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -256 768 256 ) ( -256 512 256 ) ( 256 768 256 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 256 512 1024 ) ( 256 512 512 ) ( -256 512 1024 ) trak5/wall6a 0 0 0 1 1 0 0 0 -( 512 512 1024 ) ( 512 768 1024 ) ( 512 512 512 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 256 512 1280 ) ( -256 512 1280 ) ( 256 768 1280 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -} -// brush 5 -{ -( 256 256 1536 ) ( 256 -256 1536 ) ( -256 256 1536 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 256 512 1536 ) ( -256 512 1536 ) ( 256 512 1280 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 512 256 1536 ) ( 512 256 1280 ) ( 512 -256 1536 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -256 -256 1280 ) ( 256 -256 1280 ) ( -256 256 1280 ) newskies/asteroids 0 0 0 0.5 0.5 0 0 0 -( -256 -512 1280 ) ( -256 -512 1536 ) ( 256 -512 1280 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -512 -256 1280 ) ( -512 256 1280 ) ( -512 -256 1536 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -} -// brush 6 -{ -( 0 512 272 ) ( 0 0 272 ) ( -512 512 272 ) trak5/ceil1a 0 0 0 1 1 0 0 0 -( 0 512 512 ) ( -512 512 512 ) ( 0 512 256 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( 0 512 512 ) ( 0 512 256 ) ( 0 0 512 ) trak5/basictrim1a 0 0 90 0.125 0.125 0 0 0 -( -512 0 256 ) ( 0 0 256 ) ( -512 512 256 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -512 -512 256 ) ( -512 -512 512 ) ( 0 -512 256 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -( -512 0 256 ) ( -512 512 256 ) ( -512 0 512 ) common/caulk 0 0 0 0.5 0.5 0 0 0 -} -} -// entity 1 -{ -"classname" "info_player_deathmatch" -"origin" "256.000000 -256.000000 320.000000" -"angle" "-179.999985" -} -// entity 2 -{ -"classname" "trigger_gravity" -"gravity" "0.25" -// brush 0 -{ -( 0 512 1280 ) ( 0 0 1280 ) ( -512 512 1280 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -( 0 512 512 ) ( -512 512 512 ) ( 0 512 256 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -( 0 512 512 ) ( 0 512 256 ) ( 0 0 512 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -( -512 0 272 ) ( 0 0 272 ) ( -512 512 272 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -( -512 0 256 ) ( -512 0 512 ) ( 0 0 256 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -( -512 0 256 ) ( -512 512 256 ) ( -512 0 512 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -} -} -// entity 3 -{ -"classname" "light" -"origin" "0.000000 0.000000 768.000000" -"light" "2000" -} -// entity 4 -{ -"classname" "trigger_gravity" -"gravity" "2" -// brush 0 -{ -( 0 0 1280 ) ( 0 -512 1280 ) ( -512 0 1280 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -( 0 0 512 ) ( -512 0 512 ) ( 0 0 256 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -( 0 0 512 ) ( 0 0 256 ) ( 0 -512 512 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -( -512 -512 272 ) ( 0 -512 272 ) ( -512 0 272 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -( -512 -512 256 ) ( -512 -512 512 ) ( 0 -512 256 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -( -512 -512 256 ) ( -512 0 256 ) ( -512 -512 512 ) common/trigger 0 0 0 0.5 0.5 0 0 0 -} -} diff --git a/qcsrc/server/g_triggers.qc b/qcsrc/server/g_triggers.qc index 446a4b7eb..1a1e41480 100644 --- a/qcsrc/server/g_triggers.qc +++ b/qcsrc/server/g_triggers.qc @@ -588,6 +588,8 @@ void spawnfunc_trigger_gravity() precache_sound(self.noise); }; +//============================================================================= + // TODO add a way to do looped sounds with sound(); then complete this entity .float volume, atten; void target_speaker_use() {sound(self, CHAN_TRIGGER, self.noise, VOL_BASE * self.volume, self.atten);} diff --git a/scripts/entities.def b/scripts/entities.def deleted file mode 100644 index de58a37fd..000000000 --- a/scripts/entities.def +++ /dev/null @@ -1,1786 +0,0 @@ -/*QUAKED _skybox (0.77 0.88 1.0) (-4 -4 -4) (4 4 4) -Compiler-only entity that specifies a the origin of a sky box (a wholly contained, separate area of the map), similar to some games' portal skies. When compiled with Q3Map2, the sky box surfaces will be visible from any place where sky is normally visible. It will cast shadows on the normal parts of the map, and can be used with cloud layers and other effects. As it is compiler-only, it can't "scale up" entities in its box. -To use this, carve a small box in some larger structure on your map, place this entity inside that box hole, and make a small version on what should be seen in the sky there. --------- KEYS -------- -angle: rotation angle of the sky surfaces. -angles: Individual control of PITCH, YAW, and ROLL (default 0 0 0). -_scale: scaling factor (default 64), good values are between 50 and 300, depending on the map. -*/ - -/*QUAKED dom_controlpoint (.3 .3 1) (-16 -16 -16) (16 16 16) -Domination control point -In order to get Domination working well in your map, you need to place dom_team and dom_controlpoint entities. You *must* have at least 3 dom_team entities - 2 minimum teams and one blank one (empty netname and no team). You can have up to 4 teams (5 dom_team entities). --------- KEYS -------- -message: message to be displayed to all players when this point is captured, preceded by the team's name. This defaults to " has captured a control point". You can specify different names for each point, for example " has captured the Lava Room". -wait: How often this point gives its controlling team frags. -frags: How many frags this point gives each wait cycle. --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -zbqry="zbqryf/qbzvangvba/qbz_hapynvzrq.zq3" - -*/ - -/*QUAKED dom_team (.3 .3 1) (-16 -16 -16) (16 16 16) -Domination team. -In order to get Domination working well in your map, you need to place dom_team and dom_controlpoint entities. You *must* have at least 3 dom_team entities - 2 minimum teams and one blank one (empty netname and no team). You can have up to 4 teams (5 dom_team entities). --------- KEYS -------- -netname: name of team (Red Team). Set to "" or don't define for the required blank team. -cnt: color of the team. See the "Helpful Extras" section for info. -model: When this team captures control points, the points turn to this model. If this is the neutral team, points start out as this model. -noise: Sound to be played on the control point when it's captured. Only players nearby will hear it. -noise1: Sound to be played to all players when the control point is captured. Also good for an announcer voice ("Red Team has captured a control point") -*/ - -/*QUAKED func_assault_destructible (.5 0 .5) ? - - - - - - - - NOSPLASH -This is a brush model which can be damaged. Once triggered it's active and will happily receive damage players inflict upon it. Once all health is consumed it'll disappear and trigger the targeted entity/entities. As damage is received the brush model will be tinted in an increasingly visible flavor of red to give visible feedback. --------- KEYS -------- -health: The damage this trigger can take -target: The entity/entities to be triggered once this entity gets invisible -targetname: The name other entities can use to target this entity -mdl: particle effect name to show when destroyed -count: particle effect multiplier -mdl_dead: optional replacement model to show when destroyed -debris: names of debris models to show when destroyed, separated by spaces -noise: sound to play when destroyed -dmg: damage to deal to the environment when destroyed -dmg_edge: edge damage to deal to the environment when destroyed -dmg_radius: damage radius -dmg_force: damage force -message: death message when a player gets hit by the explosion -message2: death message when someone gets pushed into this (default: "was pushed into an explosion by"). The # character is replaced by the attacker name if present (and it instead does not get appended to the end) -debrismovetype: way in which the debris moves: one of 1 = ANGLENOCLIP, 2 = ANGLECLIP, 3 = WALK, 4 = STEP, 5 = FLY, 6 = TOSS, 7 = PUSH, 8 = NOCLIP, 9 = FLYMISSILE, 10 = BOUNCE, 11 = BOUNCEMISSILE -debrissolid: solidity of the debris: one of 0 = NOT, 1 = TRIGGER, 2 = BBOX, 3 = SLIDEBOX, 4 = BSP, 5 = CORPSE -debrisvelocity: initial velocity vector of the debris (static part) -debrisvelocityjitter: initial velocity vector of the debris (random part) -debrisavelocityjitter: initial angular velocity vector of the debris (random part) -debristime: time till the debris fades (average) -debristimejitter: time till the debris fades (random part) -debrisfadetime: how long debris takes to fade -debrisdamageforcescale: how much debris is affected by damage force (e.g. explosions) -debrisskin: skin number of debris --------- SPAWNFLAGS -------- -NOSPLASH: if set, splash damage cannot activate the door, only direct damage can (requires health to be set) -*/ - -/*QUAKED func_assault_wall (.5 0 .5) ? -Brush model that will disappear once the targeted target_objective is fulfilled. This can be used to restrict access to parts of the map until a certain objective has been conquered. --------- KEYS -------- -target: targetname of a target_objective -*/ - -/*QUAKED func_bobbing (0 .5 .8) ? X_AXIS Y_AXIS -Solid entity that oscillates back and forth in a linear motion. By default, it will have an amount of displacement in either direction equal to the dimension of the brush in the axis in which it's bobbing. Entity bobs on the Z axis (up-down) by default. It can also emit sound if the "noise" key is set. Will crush the player when blocked. --------- KEYS -------- -speed: amount of time in seconds for one complete oscillation cycle (default 4). -height: sets the amount of travel of the oscillation movement (default 32). -phase: sets the start offset of the oscillation cycle. Values must be 0 < phase < 1. Any integer phase value is the same as no offset (default 0). -noise: path/name of .wav or .ogg file to play. Use looping sounds only (e.g. sound/world/drone6.wav - See Notes). -dmg: damage a player who gets crushed by it receives -dmgtime: interval to apply dmg to a player who is s in the way -message: death message when a player gets crushed -message2: death message when someone gets pushed into this (default: "was thrown into a world of hurt by"). The # character is replaced by the attacker name if present (and it instead does not get appended to the end) --------- SPAWNFLAGS -------- -X_AXIS: entity will bob along the X axis. -Y_AXIS: entity will bob along the Y axis. -*/ - -/*QUAKED func_button (0 .5 .8) ? - - - - - - - - NOSPLASH -When a button is touched by a player, it moves in the direction set by the "angle" key, triggers all its targets, stays pressed by an amount of time set by the "wait" key, then returns to it's original position where it can be operated again. --------- KEYS -------- -angle: determines the direction in which the button will move (up = -1, down = -2). -target: all entities with a matching targetname will be triggered. -target2: all entities with a matching targetname will be triggered. -target3: all entities with a matching targetname will be triggered. -target4: all entities with a matching targetname will be triggered. -speed: speed of button's displacement (default 40). -wait: number of seconds button stays pressed (default 1, -1 = return immediately). -lip: lip remaining at end of move (default 4 units). -health: (default 0) if set to any non-zero value, the button must take damage (any amount) to activate. --------- SPAWNFLAGS -------- -NOSPLASH: if set, splash damage cannot activate the door, only direct damage can (requires health to be set) -*/ - -/*QUAKED func_door (0 .5 .8) ? START_OPEN - DOOR_DONT_LINK - - TOGGLE - - NOSPLASH -Normal sliding door entity. By default, the door will activate when player walks close to it or when damage is inflicted to it. -If DOOR_DONT_LINK is not set, the door will be linked with all doors it touches. Note however that for linked doors to work properly, it is necessary that ALL linked doors have SOME volume of common area (that is, there must be a point that is part of ALL doors). --------- KEYS -------- -message: is printed when the door is touched if it is a trigger door and it hasn't been fired yet, or death message if dmg is set -message2: death message when someone gets pushed into this (default: "was thrown into a world of hurt by"). The # character is replaced by the attacker name if present (and it instead does not get appended to the end) -angle: determines the opening direction -targetname: if set, no touch field will be spawned and a remote button or trigger field activates the door. -health: if set, door must be shot open -speed: movement speed (100 default) -wait: wait before returning (3 default, -1 = never return) -lip: lip remaining at end of move (8 default) -dmg: damage to inflict when blocked (when triggered and someone is in the way) -sounds: when 1, use default door sounds -noise1: sound when the door opens -noise2: sound when the door closes --------- SPAWNFLAGS -------- -START_OPEN: causes the door to move to its destination when spawned, and operate in reverse. It is used to temporarily or permanently close off an area when triggered (not useful for touch or damage triggered doors). -DOOR_DONT_LINK: the door won't link with another door it touches -TOGGLE: causes the door to wait in both the start and end states for a trigger event. -NOSPLASH: if set, splash damage cannot activate the door, only direct damage can (requires health to be set) -*/ - -/*QUAKED func_door_rotating (0 .5 .8) ? START_OPEN BIDIR DOOR_DONT_LINK BIDIR_IN_DOWN - TOGGLE X_AXIS Y_AXIS NOSPLASH -Normal rotating door entity that opens by rotating around an axis (default: Z). Use an origin brush to specify the rotation axis. -By default, the door will activate when player walks close to it or when damage is inflicted to it. -If DOOR_DONT_LINK is not set, the door will be linked with all doors it touches. -BIDIR makes the door work bidirectional, so that the opening direction is always away from the requestor. -The usage of bidirectional doors requires two manually instantiated triggers (trigger_multiple), the one to open it in the other direction -must have set trigger_reverse to 1. -BIDIR_IN_DOWN will the door prevent from reopening while closing if it is triggered from the other side. --------- KEYS -------- -message: is printed when the door is touched if it is a trigger door and it hasn't been fired yet, or death message if dmg is set -message2: death message when someone gets pushed into this (default: "was thrown into a world of hurt by"). The # character is replaced by the attacker name if present (and it instead does not get appended to the end) -angle: determines the destination angle for opening. negative values reverse the direction (90 default) -targetname: if set, no touch field will be spawned and a remote button or trigger field activates the door. -health: if set, door must be shot open -speed: speed to rotate (in degrees per second) -wait: wait before returning (3 default, -1 = never return) -dmg: damage to inflict when blocked (when triggered and someone is in the way) -sounds: when 1, use default door sounds -noise1: sound when the door opens -noise2: sound when the door closes --------- SPAWNFLAGS -------- -START_OPEN: causes the door to move to its destination when spawned, and operate in reverse. It is used to temporarily or permanently close off an area when triggered (not useful for touch or damage triggered doors). -DOOR_DONT_LINK: the door won't link with another door it touches -TOGGLE: causes the door to wait in both the start and end states for a trigger event. -NOSPLASH: if set, splash damage cannot activate the door, only direct damage can (requires health to be set) -*/ - -/*QUAKED func_door_secret (0 .5 .8) ? OPEN_ONCE 1ST_LEFT 1ST_DOWN NO_SHOOT ALWAYS_SHOOT -Basic secret door. Slides back, then to the side. Angle determines direction. Opens when targeted or when shot; does not create its own trigger field like func_door does. --------- KEYS -------- -wait: # of seconds before coming back -key1: first entity key with one-line description -key2: second entity key with one-line description -t_width: override WIDTH to move back (or height if going down) -t_length: override LENGTH to move sideways -dmg: damage to inflict when blocked (2 default) -message: text to display when activating the door, or death message if dmg is set -message2: death message when someone gets pushed into this (default: "was thrown into a world of hurt by"). The # character is replaced by the attacker name if present (and it instead does not get appended to the end) -noise1: sound when opening backwards or closing -noise2: sound when opening sideways -noise3: sound when stopping --------- SPAWNFLAGS -------- -OPEN_ONCE: only work once, then stay open -1ST_LEFT: 1st move is left of arrow -1ST_DOWN: 1st move is down from arrow -NO_SHOOT: never respond to shots -ALWAYS_SHOOT: even if targetname is set, respond to shots -*/ - -/*QUAKED func_group (0 .5 .8) ? -This is not an entity as such. It is strictly an editor utility to group world brushes and patches together for convenience (selecting, moving, copying, etc). You cannot group entities with this. --------- Q3MAP2 KEYS -------- -_lightmapscale: light map resolution factor -_castshadows: Allows per-entity control over shadow casting. Defaults to 0 on entities, 1 on world. 0 = no shadow casting. 1 = cast shadows on world. > 1 = cast shadows on entities with _rs (or _receiveshadows) with the corresponding value, AND world. Negative values imply same, but DO NOT cast shadows on world. -_receiveshadows: Allows per-entity control over shadow reception. Defaults to 1 on everything (world shadows). 0 = receives NO shadows. > 1 = receive shadows only from corresponding keyed entities (see above) and world. < 1 = receive shadows ONLY from corresponding keyed entities. -_celshader: Sets the cel shader used for this geometry. Note: omit the "textures/" prefix. --------- KEYS -------- -_indexmap: Path/name for the TGA file used to guide the mapping of textures on the terrain surface. -_layers: number of unique root shaders that will be use on the terrain. -_shader: Path to the metashader used to assign textures to the terrain entity. Note: Omit the "textures/" prefix. -_offsets: space separated list of height offsets for the index map -*/ - -/*QUAKED func_ladder (0 .5 .8) ? -a ladder, need i say no more -grab a trigger brush and put it in front of the part that you want the player to climb -*/ - -/*QUAKED func_plat (0 .5 .8) ? - - CRUSH -Rising platform the player can ride to reach higher places. Plats must always be drawn in the raised position, so they will operate and be lighted correctly but they spawn in the lowered position. The plat will stay in the raised position until the player steps off. --------- KEYS -------- -speed: determines how fast the plat moves (default 150). -lip: lip remaining at end of move (default 16). Has no effect if "height" is set. -height: if set, this will determine the total amount of vertical travel of the plat. -dmg: damage to inflict on player when he blocks operation of plat. Plat will reverse direction when blocked. -targetname: if set, the trigger that points to this will lower the plat each time it fires. The plat lowers and lifts someone up later. -sounds: 2 for alternate sound set, -1 for silence, or use the fields below -sound1: platform starts moving sound -sound2: platform stop sound -message: kill message, when someone gets killed by this plat -message2: death message when someone gets pushed into this (default: "was thrown into a world of hurt by"). The # character is replaced by the attacker name if present (and it instead does not get appended to the end) --------- SPAWNFLAGS -------- -CRUSH: crush players hit by the platform instantly --------- NOTES -------- -By default, the total amount of vertical travel of a platform is implicitly determined by the overall vertical size of the brushes of which it's made minus the lip value. But if the "height" key is used, then the total amount of vertical travel of the plat will be exactly that value regardless of the shape and size of the plat and regardless of the value of the "lip" key. Using the "height" key is the best method for any kind of platforms and the only possible one for thin plats which need to travel vertical distances many times their own thickness. Setting the origin key is simply an alternate method to using an origin brush. When using the model2 key, the origin point of the model will correspond to the origin point defined by either the origin brush or the origin coordinate value. -*/ - -/*QUAKED func_rain (0 .5 .8) ? -This is an invisible area like a trigger, which rain falls inside of. --------- KEYS -------- -velocity: falling direction (should be something like '0 0 -700', use the X and Y velocity for wind) -cnt: sets color of rain in the Quake palette (default 12 - white) -count: adjusts density, this many particles fall every second for a 1024x1024 area, default is 2000 -*/ - -/*QUAKED func_rotating (0 .5 .8) ? - - X_AXIS Y_AXIS -Brush entity that spins in place on one axis (default Z). Use an origin brush to specify the rotation axis. -To rotate around another axis, make a func_wall with an explicit avelocity given. --------- KEYS -------- -speed: speed to rotate (in degrees per second) -noise: path/name of looping .wav file to play. -dmg: Do this much dmg every .dmgtime interval when blocked -dmgtime: See above. (0.25s default) -message: kill message when crushed by this -message2: death message when someone gets pushed into this (default: "was thrown into a world of hurt by"). The # character is replaced by the attacker name if present (and it instead does not get appended to the end) --------- SPAWNFLAGS -------- -X_AXIS: rotate around the X axis -Y_AXIS: rotate around the Y axis -*/ - -/*QUAKED func_snow (0 .5 .8) ? -This is an invisible area like a trigger, which snow falls inside of. --------- KEYS -------- -velocity: falling direction (should be something like '0 0 -300', use the X and Y velocity for wind) -cnt: sets color of snow in the Quake palette (default 12 - white) -count: adjusts density, this many particles fall every second for a 1024x1024 area, default is 2000 -*/ - -/*QUAKED func_stardust (.5 .5 .5) (-8 -8 -8) (8 8 8) -Point entity with EF_STARDUST applied. This will spawn a particle cloud with mostly golden particles. Used as eye-candy. -*/ - -/*QUAKED func_train (0 .5 .8) ? -Trains are moving solids that follow a cycle of path_corner entities. Origin brushes are NOT supported; they use the "mins" corner as reference (that is, lowest x, y, and z coordinates). -At each node, the train's mins corner hits exactly the path_corner. -Trains always start on in the game. -Trains do not damage the played when blocked. -Trains cannot emit sound. -Trains are not trigger-able or toggle-able. -Trains cannot be block-stopped just by getting in their way, the player must be wedged between the train and another obstacle to block it. --------- KEYS -------- -speed: default/initial speed of train (default 100 or overridden by speed value of targeted path_corner) -target: targetname of first path_corner to move to at the default speed; ideally, this path_corner shall be exactly where the train starts -noise: path/name of .wav or .ogg file to play while moving. Use looping sounds only (e.g. sound/world/drone6.wav - See Notes). -dmg: damage a player who gets crushed by it receives -dmgtime: interval to apply dmg to a player who is s in the way -message: death message when a player gets crushed -message2: death message when someone gets pushed into this (default: "was thrown into a world of hurt by"). The # character is replaced by the attacker name if present (and it instead does not get appended to the end) -*/ - -/*QUAKED info_location (1 1 0) (-8 -8 -8) (8 8 8) -Location for use by the %l escape in "say" messages. -The closest "visible" info_location entity is chosen to find the right location name for a point. --------- KEYS -------- -netname: name of location, possibly with color codes -*/ - -/*QUAKED info_notnull (0 .5 0) (-8 -8 -8) (8 8 8) -Entity that does nothing, but may be targeted (e.g. to use its position) --------- KEYS -------- -targetname: must match the target key of entity that uses this for pointing. -*/ - -/*QUAKED info_null (0 .5 0) (-8 -8 -8) (8 8 8) -Aiming target for q3map2-internal entities like _decal or light. Removes itself when loaded, so it can NOT be used for in-game stuff! --------- KEYS -------- -targetname: the entity that requires an aiming direction points to this. -*/ - -/*QUAKED info_player_attacker (1 0.5 0) (-16 -16 -24) (16 16 45) -Attacking team's player spawning location in Assault. Should touch the floor, but not the walls, and should point where the player should look when he spawns there. --------- KEYS -------- -target: this should point to a target_objective to decide when this spawning point is active. -target2: trigger all entities with this targetname when someone spawns -cnt: weight of spawn point for random selection. Set to a lower value if you have many spawn points close together. Default value is 1. -restriction: when 1, only bots can spawn here; when 2, only humans can spawn here (be careful with these, or the game will crash because someone cannot spawn) -*/ - -/*QUAKED info_player_deathmatch (0 1 0) (-16 -16 -24) (16 16 45) -Normal player spawning location in game types without team spawns. Should touch the floor, but not the walls, and should point where the player should look when he spawns there. --------- KEYS -------- -cnt: weight of spawn point for random selection. Set to a lower value if you have many spawn points close together. Default value is 1. -target: trigger all entities with this targetname when someone spawns -targetname: when targeted by a func_button, pressing the button will assign the spawn point to the team of the activator as an additional spawn point, or reassign it if it was already assigned. Also used to assign spawn points to Onslaught control points. -restriction: when 1, only bots can spawn here; when 2, only humans can spawn here (be careful with these, or the game will crash because someone cannot spawn) -*/ - -/*QUAKED info_player_defender (.5 .5 .5) (-16 -16 -24) (16 16 45) -Defending team's player spawning location in Assault. Should touch the floor, but not the walls, and should point where the player should look when he spawns there. --------- KEYS -------- -target: this should point to a target_objective to decide when this spawning point is active. -target2: trigger all entities with this targetname when someone spawns -cnt: weight of spawn point for random selection. Set to a lower value if you have many spawn points close together. Default value is 1. -restriction: when 1, only bots can spawn here; when 2, only humans can spawn here (be careful with these, or the game will crash because someone cannot spawn) -*/ - -/*QUAKED info_player_team1 (1 0 0) (-16 -16 -24) (16 16 45) -Red team's player spawning location in e.g. CTF and Onslaught. Should touch the floor, but not the walls, and should point where the player should look when he spawns there. --------- KEYS -------- -cnt: weight of spawn point for random selection. Set to a lower value if you have many spawn points close together. Default value is 1. -target: trigger all entities with this targetname when someone spawns -targetname: when targeted by a func_button, pressing the button will reassign the spawn point to the team of the activator. If a team has no more spawn point left, it immediately loses. -restriction: when 1, only bots can spawn here; when 2, only humans can spawn here (be careful with these, or the game will crash because someone cannot spawn) -*/ - -/*QUAKED info_player_team2 (0 0 1) (-16 -16 -24) (16 16 45) -Blue team's player spawning location in e.g. CTF and Onslaught. Should touch the floor, but not the walls, and should point where the player should look when he spawns there. --------- KEYS -------- -cnt: weight of spawn point for random selection. Set to a lower value if you have many spawn points close together. Default value is 1. -target: trigger all entities with this targetname when someone spawns -targetname: when targeted by a func_button, pressing the button will reassign the spawn point to the team of the activator. If a team has no more spawn point left, it immediately loses. -restriction: when 1, only bots can spawn here; when 2, only humans can spawn here (be careful with these, or the game will crash because someone cannot spawn) -*/ - -/*QUAKED info_player_team3 (1 1 0) (-16 -16 -24) (16 16 45) -Yellow team's player spawning location, but there is no game mode to use this yet. Anyway, should touch the floor, but not the walls, and should point where the player should look when he spawns there. --------- KEYS -------- -cnt: weight of spawn point for random selection. Set to a lower value if you have many spawn points close together. Default value is 1. -target: trigger all entities with this targetname when someone spawns -targetname: when targeted by a func_button, pressing the button will reassign the spawn point to the team of the activator. If a team has no more spawn point left, it immediately loses. -restriction: when 1, only bots can spawn here; when 2, only humans can spawn here (be careful with these, or the game will crash because someone cannot spawn) -*/ - -/*QUAKED info_player_team4 (1 0 1) (-16 -16 -24) (16 16 45) -Pink team's player spawning location, but there is no game mode to use this yet. Anyway, should touch the floor, but not the walls, and should point where the player should look when he spawns there. --------- KEYS -------- -cnt: weight of spawn point for random selection. Set to a lower value if you have many spawn points close together. Default value is 1. -target: trigger all entities with this targetname when someone spawns -targetname: when targeted by a func_button, pressing the button will reassign the spawn point to the team of the activator. If a team has no more spawn point left, it immediately loses. -restriction: when 1, only bots can spawn here; when 2, only humans can spawn here (be careful with these, or the game will crash because someone cannot spawn) -*/ - -/*QUAKED item_armor_large (.4 .8 .4) (-30 -30 0) (30 30 32) FLOATING -Large Armor (default 100 armor points) --------- KEYS -------- -respawntime: time till it respawns (default: 30) -armorvalue: amount of armor it gives (default: 100 (g_pickup_armorlarge)) -max_armorvalue: max of armor it increases to (default: 999 (g_pickup_armorlarge_max)) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/g_a25.md3" -*/ - -/*QUAKED item_armor_big (.4 .8 .4) (-30 -30 0) (30 30 32) FLOATING -Big Armor (default 50 armor points) --------- KEYS -------- -respawntime: time till it respawns (default: 20) -armorvalue: amount of armor it gives (default: 50 (g_pickup_armorlarge)) -max_armorvalue: max of armor it increases to (default: 999 (g_pickup_armorlarge_max)) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/g_a50.md3" -*/ - -/*QUAKED item_armor_medium (.4 .8 .4) (-30 -30 0) (30 30 32) FLOATING -Medium Armor (default 25 armor points) --------- KEYS -------- -respawntime: time till it respawns (default: 20) -armorvalue: amount of armor it gives (default: 25 (g_pickup_armormedium)) -max_armorvalue: max of armor it increases to (default: 999 (g_pickup_armormedium_max)) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/g_armormedium.md3" -*/ - -/*QUAKED item_armor_small (.4 .8 .4) (-30 -30 0) (30 30 32) FLOATING -Small Armor (default 5 armor points) --------- KEYS -------- -respawntime: time till it respawns (default: 15) -armorvalue: amount of armor it gives (default: 5 (g_pickup_armorsmall)) -max_armorvalue: max of armor it increases to (default: 999 (g_pickup_armorsmall_max)) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/g_a1.md3" -*/ - -/*QUAKED item_bullets (.3 .3 1) (-30 -30 0) (30 30 32) FLOATING -Machine Gun ammo --------- KEYS -------- -ammo_nails: bullets gained by this item (if unset, g_pickup_nails is used) -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/a_bullets.md3" -*/ - -/*QUAKED item_cells (.3 .3 1) (-30 -30 0) (30 30 32) FLOATING -Nex, Electro and Crylink ammo --------- KEYS -------- -ammo_cells: cells gained by this item (if unset, g_pickup_cells is used) -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/a_cells.md3" -*/ - -/*QUAKED item_flag_team1 (1 0 0) (-32 -32 0) (32 32 74) -CTF flag for team one (Red). Use more than one if you really insist. --------- KEYS -------- -model: model to use -scale: scaling factor (DO set this when using your own model!) -noise: sound played when flag is picked up -noise1: sound played when flag is returned -noise2: sound played when flag is captured -noise3: sound played when flag is lost in the field and respawns itself --------- ZBQRY SBE ENQVNAG BAYL - QB ABG FRG GUVF NF N XRL -------- -zbqry="zbqryf/pgs/enqvnag/synt_erq_enqvnag.zq3" -*/ - -/*QUAKED item_flag_team2 (0 0 1) (-32 -32 0) (32 32 74) -CTF flag for team two (Blue). Use more than one if you really insist. --------- KEYS -------- -model: model to use -scale: scaling factor (DO set this when using your own model!) -noise: sound played when flag is picked up -noise1: sound played when flag is returned -noise2: sound played when flag is captured -noise3: sound played when flag is lost in the field and respawns itself --------- ZBQRY SBE ENQVNAG BAYL - QB ABG FRG GUVF NF N XRL -------- -zbqry="zbqryf/pgs/enqvnag/synt_oyhr_enqvnag.zq3" -*/ - -/*QUAKED item_health_large (.9 .3 .3) (-30 -30 0) (30 30 48) FLOATING -Large Health (default 50 health points) --------- KEYS -------- -respawntime: time till it respawns (default: 20) -health: amount of health it gives (default: 50 (g_pickup_healthlarge)) -max_health: max of health it increases to (default: 999 (g_pickup_healthlarge_max)) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/g_h50.md3" -*/ - -/*QUAKED item_health_medium (.9 .3 .3) (-30 -30 0) (30 30 48) FLOATING -Medium Health (default 25 health points) --------- KEYS -------- -respawntime: time till it respawns (default: 15) -health: amount of health it gives (default: 25 (g_pickup_healthmedium)) -max_health: max of health it increases to (default: 999 (g_pickup_healthmedium_max)) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/g_h25.md3" -*/ - -/*QUAKED item_health_mega (.9 .3 .3) (-30 -30 0) (30 30 48) FLOATING -Mega Health (default 100 health points) -In Minstagib, this randomly turns into either an invisibility, an extra lives or a speed power-up with a default respawn time of 120. --------- KEYS -------- -respawntime: time till it respawns (default: 30) -health: amount of health it gives (default: 100 (g_pickup_healthmega)) -max_health: max of health it increases to (default: 999 (g_pickup_healthmega_max)) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/g_h100.md3" -*/ - -/*QUAKED item_health_small (.9 .3 .3) (-30 -30 0) (30 30 48) FLOATING -Small Health (default 5 health points) --------- KEYS -------- -respawntime: time till it respawns (default: 15) -health: amount of health it gives (default: 5 (g_pickup_healthsmall)) -max_health: max of health it increases to (default: 5 (g_pickup_healthsmall_max)) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/g_h1.md3" -*/ - -/*QUAKED item_invincible (.3 .3 1) (-30 -30 0) (30 30 48) FLOATING -Strong Shield -In Minstagib, this randomly turns into either an invisibility, an extra lives or a speed power-up with a default respawn time of 120. --------- KEYS -------- -respawntime: time till it respawns (default: 120) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/g_invincible.md3" -*/ - -/*QUAKED item_minst_cells (.3 .3 1) (-30 -30 0) (30 30 32) FLOATING -Minstagib ammo. -Always contains 5 (g_minstagib_ammo_drop) shots. -It only appears when playing Minstagib and prevents auto-replacement of weapon_nex & weapon_rocketlauncher when used. --------- KEYS -------- -respawntime: time till it respawns (default: 45) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/a_cells.md3" -*/ - -/*QUAKED item_rockets (.3 .3 1) (-30 -30 0) (30 30 32) FLOATING -Rocket Launcher, Hagar and Mortar ammo --------- KEYS -------- -ammo_rockets: rockets gained by this item (if unset, g_pickup_rockets is used) -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/a_rockets.md3" -*/ - -/*QUAKED item_shells (.3 .3 1) (-30 -30 0) (30 30 32) FLOATING -Shotgun ammo --------- KEYS -------- -ammo_shells: shells gained by this item (if unset, g_pickup_shells is used) -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/a_shells.md3" -*/ - -/*QUAKED item_strength (.3 .3 1) (-30 -30 0) (30 30 48) FLOATING -Strength aka Quad damage -In Minstagib, this randomly turns into either an invisibility, an extra lives or a speed power-up with a default respawn time of 120. --------- KEYS -------- -respawntime: time till it respawns (default: 120) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/items/g_strength.md3" -*/ - -/*QUAKED light (.65 .65 1) (-8 -8 -8) (8 8 8) LINEAR NOANGLE - - NOGRIDLIGHT -Non-displayed point light source. The -pointscale and -scale arguments to Q3Map2 affect the brightness of these lights. The -skyscale argument affects brightness of entity sun lights. -Maximum intensity (in a radius 16 sphere around the light): regular lights have light/256, linear lights have light/8000-16*fade. -Falloff radius to a negligible light amount: regular lights have light have 16*sqrt(light), linear lights have light/(fade*8000). -By this you see that you HAVE to specify fade for a linear light... use values below 0.01 there. --------- KEYS -------- -light: intensity factor (default: 300). A linear -_color: weighted RGB value of light color (default white - 1.0 1.0 1.0). -target: Lights pointed at a target will be spotlights. -radius: radius of a spotlight at the target point (default: 64) -_anglescale: scales angle attenuation -fade: Fade factor of light attenuation of linear lights. Linear lights completely vanish at distance light/(fade*8000), so if you want the light to vanish at distance X, specify light/(8000*X) here. -_filterradius: filter radius for this light, similar to -light -filter -_sun: if 1, this light is an infinite sun light -_samples: number of samples to use to get soft shadows from a light -_deviance: position deviance of the samples of a regular light (distributes the light samples in a cube of side length 2*_deviance around the origin), or angle deviance of the sun light samples in radians --------- SPAWNFLAGS -------- -LINEAR: Use a linear falloff. Default is inverse distance squared (more realistic). -NOANGLE: Ignore angle attenuation. -NOGRIDLIGHT: Do not affect the light grid (dynamic entity lighting). -*/ - -/*QUAKED lightJunior (.65 .65 1) (-8 -8 -8) (8 8 8) LINEAR NOANGLE -Non-displayed point light source that JUST APPLIES TO THE LIGHT GRID. No idea what this is good for. The -pointscale and -scale arguments to Q3Map2 affect the brightness of these lights. The -skyscale argument affects brightness of entity sun lights. -Maximum intensity (in a radius 16 sphere around the light): regular lights have light/256, linear lights have light/8000-16*fade. -Falloff radius to a negligible light amount: regular lights have light have 16*sqrt(light), linear lights have light/(fade*8000). -By this you see that you HAVE to specify fade for a linear light... use values below 0.01 there. --------- KEYS -------- -light: intensity factor (default: 300). A linear -_color: weighted RGB value of light color (default white - 1.0 1.0 1.0). -target: Lights pointed at a target will be spotlights. -radius: radius of a spotlight at the target point (default: 64) -_anglescale: scales angle attenuation -fade: Fade factor of light attenuation of linear lights. Linear lights completely vanish at distance light/(fade*8000), so if you want the light to vanish at distance X, specify light/(8000*X) here. -_filterradius: filter radius for this light, similar to -light -filter -_sun: if 1, this light is an infinite sun light -_samples: number of samples to use to get soft shadows from a light -_deviance: position deviance of the samples of a regular light (distributes the light samples in a cube of side length 2*_deviance around the origin), or angle deviance of the sun light samples in radians --------- SPAWNFLAGS -------- -LINEAR: Use a linear falloff. Default is inverse distance squared (more realistic). -NOANGLE: Ignore angle attenuation. -*/ - -/*QUAKED misc_laser (.5 .5 .5) (-8 -8 -8) (8 8 8) START_ON FINITE -Laser beam emitter. Note that for the laser to be deadly, it has to start OUTSIDE the player's collision box. To ensure this, you may want to put this entity inside the walls (or directly on their surface), or cover it with a playerclip brush. --------- KEYS -------- -target: target_position the laser targets (may be another entity, preferably target_position, possibly controlled by misc_follow) -mdl: name of particle effect for the beam end point (see effectinfo.txt; default is laser_deadly if dmg is set, and none if not) -colormod: color of the laser beam (default: red, that is, 1 0 0) -dmg: damage inflicted by the beam per second, or -1 for an instant-death ray -targetname: name to target this (then its state is toggled) -alpha: when set, makes a dark laser of the given strength; may be combined with colormod -scale: scales the beam thickness (default 1) -modelscale: scales the dynamic light radius at the endpoint (default 1, -1 to turn off) --------- SPAWNFLAGS -------- -START_ON: when targeted, the laser will start switched on -FINITE: the laser does not extend over its target like light would do, but stops there (takes more bandwidth) --------- NOTES -------- -Use trigger_monoflop if you want the laser to turn off for a while, then turn back on. -When the laser's target has itself target set, its targets are triggered when someone enters or leaves the laser. -*/ - -/*QUAKED misc_model (1 .5 .25) (-16 -16 -16) (16 16 16) - SOLID - EXTRUDE_NORMALS EXTRUDE_TERRAIN COLOR_TO_ALPHA -Generic placeholder for inserting MD3 models in game. Requires compilation of map geometry to be added to level. If the map is compiled with Q3Map2, then ASE, 3DS, OBJ and other model formats are supported. --------- Q3MAP2 KEYS -------- -model: file name of model to include -_frame: frame of model to include -_remap: string of the form from;to specifying which texture name of the model to replace by which shader; * is allowed. Any key starting with this prefix will work, so if you need more remappings, create _remap2, etc. -angle: view direction of the model -angles: view direction of the model in PITCH YAW ROLL -modelscale: scaling factor -modelscale_vec: scaling vector for non-uniform scaling -_castshadows: Allows per-entity control over shadow casting. Defaults to 0 on entities, 1 on world. 0 = no shadow casting. 1 = cast shadows on world. > 1 = cast shadows on entities with _rs (or _receiveshadows) with the corresponding value, AND world. Negative values imply same, but DO NOT cast shadows on world. -_receiveshadows: Allows per-entity control over shadow reception. Defaults to 1 on everything (world shadows). 0 = receives NO shadows. > 1 = receive shadows only from corresponding keyed entities (see above) and world. < 1 = receive shadows ONLY from corresponding keyed entities. -_lightmapscale: light map resolution factor -_celshader: the cel shader for this --------- SPAWNFLAGS -------- -SOLID: make the model solid -EXTRUDE_NORMALS: for converting triangles to clip brushes, extrude along the model normals (by default, extrusion happens in a coordinate axis direction that is decided per triangle) -EXTRUDE_TERRAIN: always extrude downwards (for terrain) -COLOR_TO_ALPHA: use the color value as alpha (for terrain blending) -*/ - -/*QUAKED misc_gamemodel (0 .5 .8) (-8 -8 -8) (8 8 8) ALIGN_ORIGIN ALIGN_BOTTOM -A way to load models from a map by the engine (e.g. self-animated zym models). -Is non-solid by default. -The keys below actually apply to most engine-loaded model entities as they are engine features; however, they are described here as they aren't overridden by game code in misc_gamemodel. Its q3map2 keys below will work on any brush entity! --------- KEYS -------- -model: when used as a point entity, file name of model to load; when used as a brush entity, do not specify that -frame: animation frame to play (for self-animated zym models) -skin: number of skin to load (when model is used) -movetype: way in which it moves: one of 0 = NONE, 1 = ANGLENOCLIP, 2 = ANGLECLIP, 3 = WALK, 4 = STEP, 5 = FLY, 6 = TOSS, 7 = PUSH, 8 = NOCLIP, 9 = FLYMISSILE, 10 = BOUNCE, 11 = BOUNCEMISSILE -solid: solidity: one of 0 = NOT, 1 = TRIGGER, 2 = BBOX, 3 = SLIDEBOX, 4 = BSP, 5 = CORPSE -avelocity: vector giving its angular velocity (useful for spinning models) -scale: scale factor of the model (range: 0.0625 to 15.9375) -colormap: 1024 + 16 * pantscolor + shirtcolor -velocity: when movetype isn't 0, initial velocity vector -angles: initial looking direction -modelscale: scaling factor -effects: sum of 1 = BRIGHTFIELD, 4 = BRIGHTLIGHT, 8 = DIMLIGHT, 32 = ADDITIVE, 64 = BLUE, 128 = RED, 512 = FULLBRIGHT, 1024 = FLAME, 2048 = STARDUST, 4096 = NOSHADOW, 8192 = NODEPTHTEST, 32768 = DOUBLESIDED, 8388608 = NOMODELFLAGS (ignores the following coming from a model file), 16777216 = ROCKET, 33554432 = GRENADE, 67108864 = GIB, 134217728 = ROTATE, 268435456 = TRACER, 536870912 = ZOMGIB, 1073741824 = TRACER2, -2147483648 = TRACER3 -loddistance1: distance after which to show the first LOD model replacement (default: 1000) -loddistance2: distance after which to show the second LOD model replacement (default: 2000) -lodmodel1: file name of the first LOD model replacement -lodmodel2: file name of the second LOD model replacement -targetname: when invoking it by a button etc., it changes the color to the initiator of the action (e.g. the one pressing a button). In Onslaught, this can be used to color control points for team who owns them. In other game types, this can be used as a fun feature. -originjitter: a vector describing a random offset this entity will be moved on initial spawn. This corresponds to the "origin" field. Works on any non-q3map2-only entity. -anglesjitter: a vector in the order "pitch yaw roll" describing a random angles change on this entity on initial spawn. The value 180 180 180 makes the angles entirely random and uniformly distributed (among euler angles). This corresponds to the "angles" field. Works on any non-q3map2-only entity. -anglejitter: a float describing a random yaw angle change on this entity on initial spawn. The value 180 makes the yaw angle entirely random (maybe good for items). This corresponds to the "angle" field. Works on any non-q3map2-only entity. -gametypefilter: either a + sign and a comma separated list of game types or the aliases "teams" and "noteams" to ONLY show the entity in the listed game types, or a - sign and a comma separated list of game types or the aliases "teams" and "noteams" to NOT show the entity in the listed game types. The syntax is the same as in sbar_columns_set strings. Works on any non-q3map2-only entity. -cvarfilter: either a + sign and a space separated list of conditions, or a - sign and the same for an inverted filter. The conditions are ALWAYS combined with AND! Possible conditions are: "cvar==value", "cvar!=value", "cvarvalue", "cvar<=value", "cvar>=value", "cvar===string", "cvar!==string", "cvar", "!cvar". Ridiculous example filter: "-g_balance_health_start<150 g_balance_armor_start==0" spawns an item only if start health is at least 150 or start armor is not 0. Other ideas: "+g_campaign" and "-g_campaign" for enabling/disabling items when the map is played as part of the campaign. --------- SPAWNFLAGS -------- -ALIGN_ORIGN: align the origin to the surface below the model -ALIGN_BOTTOM: align the bottom of the model to the surface below it -*/ - -/*QUAKED func_illusionary (0 .5 .8) ? -NOTE: THIS ENTITY IS BROKEN REGARDING CLIENT AND PROJECTILE PREDICTION. DO NOT USE IT. USE NONSOLID SHADERS OR FUNC_CLIENTILLUSIONARY INSTEAD. -A non-solid brush entity. Use func_wall if you want it solid. -The keys below actually apply to most brush entities as they are engine features; however, they are described here as they aren't overridden by game code in misc_models. Its q3map2 keys below will work on any brush entity! --------- KEYS -------- -movetype: way in which it moves: one of 0 = NONE, 1 = ANGLENOCLIP, 2 = ANGLECLIP, 3 = WALK, 4 = STEP, 5 = FLY, 6 = TOSS, 7 = PUSH, 8 = NOCLIP, 9 = FLYMISSILE, 10 = BOUNCE, 11 = BOUNCEMISSILE -avelocity: vector giving its angular velocity (useful for spinning models) -scale: scale factor of the model (range: 0.0625 to 15.9375) -colormap: 1024 + 16 * pantscolor + shirtcolor -velocity: when movetype isn't 0, initial velocity vector -angles: initial looking direction -effects: sum of 1 = BRIGHTFIELD, 4 = BRIGHTLIGHT, 8 = DIMLIGHT, 32 = ADDITIVE, 64 = BLUE, 128 = RED, 512 = FULLBRIGHT, 1024 = FLAME, 2048 = STARDUST, 4096 = NOSHADOW, 8192 = NODEPTHTEST, 32768 = DOUBLESIDED, 8388608 = NOMODELFLAGS (ignores the following coming from a model file), 16777216 = ROCKET, 33554432 = GRENADE, 67108864 = GIB, 134217728 = ROTATE, 268435456 = TRACER, 536870912 = ZOMGIB, 1073741824 = TRACER2, -2147483648 = TRACER3 -loddistance1: distance after which to show the first LOD model replacement (default: 1000) -loddistance2: distance after which to show the second LOD model replacement (default: 2000) -lodtarget1: targetname of the first LOD model entity (can be used instead of lodmodel1 to use a brush model instead) -lodtarget2: targetname of the second LOD model entity (can be used instead of lodmodel2 to use a brush model instead) -targetname: when invoking it by a button etc., it changes the color to the initiator of the action (e.g. the one pressing a button). In Onslaught, this can be used to color control points for team who owns them. In other game types, this can be used as a fun feature. Works only with _shirt and _pants textures. -originjitter: a vector describing a random offset this entity will be moved on initial spawn. This corresponds to the "origin" field. Works on any non-q3map2-only entity. -anglesjitter: a vector in the order "pitch yaw roll" describing a random angles change on this entity on initial spawn. The value 180 180 180 makes the angles entirely random and uniformly distributed (among euler angles). This corresponds to the "angles" field. Works on any non-q3map2-only entity. -anglejitter: a float describing a random yaw angle change on this entity on initial spawn. The value 180 makes the yaw angle entirely random (maybe good for items). This corresponds to the "angle" field. Works on any non-q3map2-only entity. -gametypefilter: either a + sign and a comma separated list of game types or the aliases "teams" and "noteams" to ONLY show the entity in the listed game types, or a - sign and a comma separated list of game types or the aliases "teams" and "noteams" to NOT show the entity in the listed game types. The syntax is the same as in sbar_columns_set strings. Works on any non-q3map2-only entity. --------- Q3MAP2 KEYS -------- -_castshadows: Allows per-entity control over shadow casting. Defaults to 0 on entities, 1 on world. 0 = no shadow casting. 1 = cast shadows on world. > 1 = cast shadows on entities with _rs (or _receiveshadows) with the corresponding value, AND world. Negative values imply same, but DO NOT cast shadows on world. -_receiveshadows: Allows per-entity control over shadow reception. Defaults to 1 on everything (world shadows). 0 = receives NO shadows. > 1 = receive shadows only from corresponding keyed entities (see above) and world. < 1 = receive shadows ONLY from corresponding keyed entities. -_clone: copies brushes from entity with identical _clonename. Still needs a single brush that will get replaced. -_clonename: template name so one can clone from it -min: override automatically found minimum coordinate bounds -max: override automatically found maximum coordinate bounds -targetname: if targeted by a misc_model, its brushes get inserted into this -_celshader: Sets the cel shader used for this geometry. Note: omit the "textures/" prefix. -*/ - -/*QUAKED func_wall (0 .5 .8) ? -A solid brush entity. Use func_clientillusionary if you want it non-solid. -The keys below actually apply to most brush entities as they are engine features; however, they are described here as they aren't overridden by game code in misc_models. Its q3map2 keys below will work on any brush entity! --------- KEYS -------- -movetype: way in which it moves: one of 0 = NONE, 1 = ANGLENOCLIP, 2 = ANGLECLIP, 3 = WALK, 4 = STEP, 5 = FLY, 6 = TOSS, 7 = PUSH, 8 = NOCLIP, 9 = FLYMISSILE, 10 = BOUNCE, 11 = BOUNCEMISSILE -solid: solidity: one of 1 = TRIGGER, 2 = BBOX, 3 = SLIDEBOX, 4 = BSP, 5 = CORPSE (default: 4, any other value causes prediction problems and should not be used until further notice) -avelocity: vector giving its angular velocity (useful for spinning models) -scale: scale factor of the model (range: 0.0625 to 15.9375) -colormap: 1024 + 16 * pantscolor + shirtcolor -velocity: when movetype isn't 0, initial velocity vector -angles: initial looking direction -effects: sum of 1 = BRIGHTFIELD, 4 = BRIGHTLIGHT, 8 = DIMLIGHT, 32 = ADDITIVE, 64 = BLUE, 128 = RED, 512 = FULLBRIGHT, 1024 = FLAME, 2048 = STARDUST, 4096 = NOSHADOW, 8192 = NODEPTHTEST, 32768 = DOUBLESIDED, 8388608 = NOMODELFLAGS (ignores the following coming from a model file), 16777216 = ROCKET, 33554432 = GRENADE, 67108864 = GIB, 134217728 = ROTATE, 268435456 = TRACER, 536870912 = ZOMGIB, 1073741824 = TRACER2, -2147483648 = TRACER3 -loddistance1: distance after which to show the first LOD model replacement (default: 1000) -loddistance2: distance after which to show the second LOD model replacement (default: 2000) -lodtarget1: targetname of the first LOD model entity (can be used instead of lodmodel1 to use a brush model instead) -lodtarget2: targetname of the second LOD model entity (can be used instead of lodmodel2 to use a brush model instead) -targetname: when invoking it by a button etc., it changes the color to the initiator of the action (e.g. the one pressing a button). In Onslaught, this can be used to color control points for team who owns them. In other game types, this can be used as a fun feature. Works only with _shirt and _pants textures. -originjitter: a vector describing a random offset this entity will be moved on initial spawn. This corresponds to the "origin" field. Works on any non-q3map2-only entity. -anglesjitter: a vector in the order "pitch yaw roll" describing a random angles change on this entity on initial spawn. The value 180 180 180 makes the angles entirely random and uniformly distributed (among euler angles). This corresponds to the "angles" field. Works on any non-q3map2-only entity. -anglejitter: a float describing a random yaw angle change on this entity on initial spawn. The value 180 makes the yaw angle entirely random (maybe good for items). This corresponds to the "angle" field. Works on any non-q3map2-only entity. -gametypefilter: either a + sign and a comma separated list of game types or the aliases "teams" and "noteams" to ONLY show the entity in the listed game types, or a - sign and a comma separated list of game types or the aliases "teams" and "noteams" to NOT show the entity in the listed game types. The syntax is the same as in sbar_columns_set strings. Works on any non-q3map2-only entity. --------- Q3MAP2 KEYS -------- -_castshadows: Allows per-entity control over shadow casting. Defaults to 0 on entities, 1 on world. 0 = no shadow casting. 1 = cast shadows on world. > 1 = cast shadows on entities with _rs (or _receiveshadows) with the corresponding value, AND world. Negative values imply same, but DO NOT cast shadows on world. -_receiveshadows: Allows per-entity control over shadow reception. Defaults to 1 on everything (world shadows). 0 = receives NO shadows. > 1 = receive shadows only from corresponding keyed entities (see above) and world. < 1 = receive shadows ONLY from corresponding keyed entities. -_clone: copies brushes from entity with identical _clonename. Still needs a single brush that will get replaced. -_clonename: template name so one can clone from it -min: override automatically found minimum coordinate bounds -max: override automatically found maximum coordinate bounds -targetname: if targeted by a misc_model, its brushes get inserted into this -_celshader: Sets the cel shader used for this geometry. Note: omit the "textures/" prefix. -*/ - -/*QUAKED misc_clientmodel (0 .5 .8) (-8 -8 -8) (8 8 8) ALIGN_ORIGIN ALIGN_BOTTOM -A way to load models from a map by the engine (e.g. self-animated zym models) on client side. -Is non-solid by default. --------- KEYS -------- -scale: scale factor of the model (range: 0.0625 to 15.9375) -colormap: 1024 + 16 * pantscolor + shirtcolor -angles: initial looking direction -targetname: when invoking it by a button etc., it changes the color to the initiator of the action (e.g. the one pressing a button). In Onslaught, this can be used to color control points for team who owns them. In other game types, this can be used as a fun feature. Works only with _shirt and _pants textures. -bgmscript: emitter class from the BGM script (if prefixed with <, movedir is treated as an angle value) -bgmscriptattack: attack time of the effect strength (0 to 3.9) -bgmscriptdecay: decay time of the effect strength (0 to 3.9) -bgmscriptsustain: sustain level of the effect strength (0.1 to 1, set to -1 to disable sustain) -bgmscriptrelease: release time of the effect strength (0 to 3.9) -movedir: vector by which the entity moves when "pressed" by the bgmscript -lip: alpha change when "pressed" by the bgmscript (if > 0, it fades in when pressed, if < 0, it fades out when pressed) -originjitter: a vector describing a random offset this entity will be moved on initial spawn. This corresponds to the "origin" field. Works on any non-q3map2-only entity. -anglesjitter: a vector in the order "pitch yaw roll" describing a random angles change on this entity on initial spawn. The value 180 180 180 makes the angles entirely random and uniformly distributed (among euler angles). This corresponds to the "angles" field. Works on any non-q3map2-only entity. -anglejitter: a float describing a random yaw angle change on this entity on initial spawn. The value 180 makes the yaw angle entirely random (maybe good for items). This corresponds to the "angle" field. Works on any non-q3map2-only entity. -gametypefilter: either a + sign and a comma separated list of game types or the aliases "teams" and "noteams" to ONLY show the entity in the listed game types, or a - sign and a comma separated list of game types or the aliases "teams" and "noteams" to NOT show the entity in the listed game types. The syntax is the same as in sbar_columns_set strings. Works on any non-q3map2-only entity. --------- SPAWNFLAGS -------- -ALIGN_ORIGN: align the origin to the surface below the model -ALIGN_BOTTOM: align the bottom of the model to the surface below it -*/ - -/*QUAKED func_clientillusionary (0 .5 .8) ? -A client-side non-solid brush entity. Use func_wall if you want it solid. --------- KEYS -------- -scale: scale factor of the model (range: 0.0625 to 15.9375) -colormap: 1024 + 16 * pantscolor + shirtcolor -angles: initial looking direction -targetname: when invoking it by a button etc., it changes the color to the initiator of the action (e.g. the one pressing a button). In Onslaught, this can be used to color control points for team who owns them. In other game types, this can be used as a fun feature. Works only with _shirt and _pants textures. -bgmscript: emitter class from the BGM script -bgmscriptattack: attack time of the effect strength (0 to 3.9) -bgmscriptdecay: decay time of the effect strength (0 to 3.9) -bgmscriptsustain: sustain level of the effect strength (0.1 to 1, set to -1 to disable sustain) -bgmscriptrelease: release time of the effect strength (0 to 3.9) -movedir: vector by which the entity moves when "pressed" by the bgmscript -lip: alpha change when "pressed" by the bgmscript (if > 0, it fades in when pressed, if < 0, it fades out when pressed) -originjitter: a vector describing a random offset this entity will be moved on initial spawn. This corresponds to the "origin" field. Works on any non-q3map2-only entity. -anglesjitter: a vector in the order "pitch yaw roll" describing a random angles change on this entity on initial spawn. The value 180 180 180 makes the angles entirely random and uniformly distributed (among euler angles). This corresponds to the "angles" field. Works on any non-q3map2-only entity. -anglejitter: a float describing a random yaw angle change on this entity on initial spawn. The value 180 makes the yaw angle entirely random (maybe good for items). This corresponds to the "angle" field. Works on any non-q3map2-only entity. -gametypefilter: either a + sign and a comma separated list of game types or the aliases "teams" and "noteams" to ONLY show the entity in the listed game types, or a - sign and a comma separated list of game types or the aliases "teams" and "noteams" to NOT show the entity in the listed game types. The syntax is the same as in sbar_columns_set strings. Works on any non-q3map2-only entity. --------- Q3MAP2 KEYS -------- -_castshadows: Allows per-entity control over shadow casting. Defaults to 0 on entities, 1 on world. 0 = no shadow casting. 1 = cast shadows on world. > 1 = cast shadows on entities with _rs (or _receiveshadows) with the corresponding value, AND world. Negative values imply same, but DO NOT cast shadows on world. -_receiveshadows: Allows per-entity control over shadow reception. Defaults to 1 on everything (world shadows). 0 = receives NO shadows. > 1 = receive shadows only from corresponding keyed entities (see above) and world. < 1 = receive shadows ONLY from corresponding keyed entities. -_clone: copies brushes from entity with identical _clonename. Still needs a single brush that will get replaced. -_clonename: template name so one can clone from it -min: override automatically found minimum coordinate bounds -max: override automatically found maximum coordinate bounds -targetname: if targeted by a misc_model, its brushes get inserted into this -_celshader: Sets the cel shader used for this geometry. Note: omit the "textures/" prefix. -*/ - -/*QUAKED func_clientwall (0 .5 .8) ? -NOTE: THIS ENTITY IS IN MOST USE CASES BROKEN REGARDING CLIENT AND PROJECTILE PREDICTION. DO NOT USE IT. USE FUNC_WALL INSTEAD. -A client-side solid brush entity. Use func_clientillusionary if you want it non-solid. --------- KEYS -------- -solid: solidity: one of 1 = TRIGGER, 2 = BBOX, 3 = SLIDEBOX, 4 = BSP, 5 = CORPSE (default: 4, any other value causes prediction problems and should not be used until further notice) -scale: scale factor of the model (range: 0.0625 to 15.9375) -colormap: 1024 + 16 * pantscolor + shirtcolor -angles: initial looking direction -targetname: when invoking it by a button etc., it changes the color to the initiator of the action (e.g. the one pressing a button). In Onslaught, this can be used to color control points for team who owns them. In other game types, this can be used as a fun feature. Works only with _shirt and _pants textures. -bgmscript: emitter class from the BGM script -bgmscriptattack: attack time of the effect strength (0 to 3.9) -bgmscriptdecay: decay time of the effect strength (0 to 3.9) -bgmscriptsustain: sustain level of the effect strength (0.1 to 1, set to -1 to disable sustain) -bgmscriptrelease: release time of the effect strength (0 to 3.9) -movedir: vector by which the entity moves when "pressed" by the bgmscript -lip: alpha change when "pressed" by the bgmscript (if > 0, it fades in when pressed, if < 0, it fades out when pressed) -originjitter: a vector describing a random offset this entity will be moved on initial spawn. This corresponds to the "origin" field. Works on any non-q3map2-only entity. -anglesjitter: a vector in the order "pitch yaw roll" describing a random angles change on this entity on initial spawn. The value 180 180 180 makes the angles entirely random and uniformly distributed (among euler angles). This corresponds to the "angles" field. Works on any non-q3map2-only entity. -anglejitter: a float describing a random yaw angle change on this entity on initial spawn. The value 180 makes the yaw angle entirely random (maybe good for items). This corresponds to the "angle" field. Works on any non-q3map2-only entity. -gametypefilter: either a + sign and a comma separated list of game types or the aliases "teams" and "noteams" to ONLY show the entity in the listed game types, or a - sign and a comma separated list of game types or the aliases "teams" and "noteams" to NOT show the entity in the listed game types. The syntax is the same as in sbar_columns_set strings. Works on any non-q3map2-only entity. --------- Q3MAP2 KEYS -------- -_castshadows: Allows per-entity control over shadow casting. Defaults to 0 on entities, 1 on world. 0 = no shadow casting. 1 = cast shadows on world. > 1 = cast shadows on entities with _rs (or _receiveshadows) with the corresponding value, AND world. Negative values imply same, but DO NOT cast shadows on world. -_receiveshadows: Allows per-entity control over shadow reception. Defaults to 1 on everything (world shadows). 0 = receives NO shadows. > 1 = receive shadows only from corresponding keyed entities (see above) and world. < 1 = receive shadows ONLY from corresponding keyed entities. -_clone: copies brushes from entity with identical _clonename. Still needs a single brush that will get replaced. -_clonename: template name so one can clone from it -min: override automatically found minimum coordinate bounds -max: override automatically found maximum coordinate bounds -targetname: if targeted by a misc_model, its brushes get inserted into this -_celshader: Sets the cel shader used for this geometry. Note: omit the "textures/" prefix. -*/ - -/*QUAKED misc_teleporter_dest (1 .5 .25) (-16 -16 -24) (16 16 45) -Teleport destination location point for trigger_teleport entities. Do not let it touch the floor, but place it slightly higher (like, 16 units above) for better flow when jumping through it. --------- KEYS -------- -targetname: make the trigger_teleporter point to this. -target: target to activate when a teleporter targeting this is used -angle: direction in which player will look when teleported, OR use -angles: pitch and yaw when coming out of the teleporter (also specifies the direction the player will aim when coming out) -cnt: weight for random selection, in case a teleporter points at multiple misc_teleporter_dest -speed: maximum speed cap for the teleported player (if -1, teleported players will have no speed) -*/ - -/*QUAKED onslaught_controlpoint (0 .5 .8) (-32 -32 0) (32 32 128) -Control point. Be sure to give this enough clearance so that the shootable part has room to exist -This should link to an onslaught_controlpoint entity or onslaught_generator entity. --------- KEYS -------- -targetname: name that onslaught_link entities will use to target this. -target: target any entities that are tied to this control point, such as vehicles and buildable structure entities. -message: name of this control point (should reflect the location in the map, such as "center bridge", "north tower", etc) -*/ - -/*QUAKED onslaught_generator (0 .5 .8) (-32 -32 -24) (32 32 64) -Base generator. - -onslaught_link entities can target this. --------- KEYS -------- -team: team that owns this generator (5 = red, 14 = blue, etc), MUST BE SET. -targetname: name that onslaught_link entities will use to target this. -*/ - -/*QUAKED onslaught_link (0 .5 .8) (-16 -16 -16) (16 16 16) -Link between control points. - -This entity targets two different onslaught_controlpoint or onslaught_generator entities, and suppresses shielding on both if they are owned by different teams. --------- KEYS -------- -target: first control point. -target2: second control point. -*/ - -/*QUAKED path_corner (.5 .3 0) (-8 -8 -8) (8 8 8) -Path corner entity that func_train will follow. -All path_corner entities of a train have to connect in a circular manner, while the func_train shall point to one of the path_corners (ideally the one at the train's starting point) --------- KEYS -------- -target: point to next path_corner in the path. -targetname: the train following the path or the previous path_corner in the path points to this. -speed: speed of func_train while moving to this path corner. If unset, the value from the func_train will be used. -wait: number of seconds func_train will pause on this path corner before moving to next path corner (default: 0.1; to not wait, set this to -1 -*/ - -/*QUAKED runematch_spawn_point (.3 .3 1) (-16 -16 -16) (16 16 16) -Spawn point for runes in a runematch. -Runematch can work without runes also, it then spawn runes at random safe locations. -*/ - -/*QUAKED target_assault_roundend (1 0 0) (-8 -8 -8) (8 8 8) -This entity ends the current assault round if triggered or if the timelimit is reached. -Ending a round means swapping attacker/defender teams, resetting objectives and rewarding the winning team. -Every assault map needs this entity. There should only be one per map. --------- KEYS -------- -targetname: Name to target this entity -*/ - -/*QUAKED target_assault_roundstart (.5 0 .5) (-8 -8 -8) (8 8 8) -This entity triggers its targets whenever a new assault round is started. This can be used to e.g. activate the first objective. --------- KEYS -------- -target: targetname of entities to be enabled/triggered on round start (e.g. the first target_objective) -target2: targetname of entities to be enabled/triggered on round start (e.g. the func_assault_destructibles targeting the target_objective) -target3: targetname of entities to be enabled/triggered on round start -target4: targetname of entities to be enabled/triggered on round start -*/ - -/*QUAKED target_objective (.5 0 .5) (-8 -8 -8) (8 8 8) -target_objective controls an objective. Once triggered the objective is active and has 100 "health" points. If this "health" falls below zero it is assumed this objective has been fulfilled and entities targeted will be triggered (e.g. to activate the next objective or to end this round). Use target_objective_decrease to decrease the objective health. --------- KEYS -------- -target: targetname of entities to be enabled/triggered on objective fulfilling (e.g. the next target_objective, or target_assault_roundend) -target2: targetname of entities to be enabled/triggered on objective fulfilling (e.g. the func_assault_destructibles targeting the target_objective) -target3: targetname of entities to be enabled/triggered on objective fulfilling -target4: targetname of entities to be enabled/triggered on objective fulfilling -targetname: targetname for this entity so it can be triggered by other entities. -*/ - -/*QUAKED target_objective_decrease (0 1 0) (-8 -8 -8) (8 8 8) -When triggered decreases health of the targeted target_objective by the amount specified in dmg. Remember, target_objective has 100 health points and is considered conquered if health falls below zero. -If you want e.g. two events to happen to conquer an objective you'd need two target_objective_decrease, each with a value for cnt of e.g. 51. To show attackers and defenders where to go, target_objective_decrease will show a fitting sprite ("Defend" to defenders, "Destroy"/"Push" to attackers) which can be seen through walls. --------- KEYS -------- -target: The targetname of the target_objective you want to manipulate. -targetname: Name for other entities to target this entity. -dmg: The amount of "health"-points you want to subtract from the objective health. Defaults to 101. Also used as score for triggering this objective. -*/ - -/*QUAKED target_position (0 .5 0) (-8 -8 -8) (8 8 8) -Aiming target for entities like light and trigger_push. --------- KEYS -------- -targetname: the entity that requires an aiming direction points to this. -target: target to activate when a jumppad targeting this is used -*/ - -/*QUAKED target_speaker (0 .7 .7) (-8 -8 -8) (8 8 8) -Sound generating entity that plays sound files. -If targeted, it plays the sound file every time when triggered. -If not targeted, it loops the sound file as an ambient noise. --------- KEYS -------- -noise: path/name of .wav/.ogg file to play -targetname: the activating button or trigger points to this. -atten: distance attenuation of the sound (a value from 0.1 to 3.9), default is 0.5 if targeted, 3 otherwise; set to -1 for no attenuation (global sound) -volume: volume of the sound -*/ - -/*QUAKED trigger_counter (.5 .5 .5) ? NOMESSAGE -Acts as an intermediary for an action that takes multiple inputs. -After the counter has been triggered "count" times, it will fire all of its targets and remove itself. --------- KEYS -------- -count: how many times this needs to be triggered to activate its targets -target: trigger all entities with this targetname when triggered -targetname: name that identifies this entity so it can be triggered -delay: delay the triggering by the given time -message: print this message to the player who activated the trigger -killtarget: remove all entities with this targetname when triggered --------- SPAWNFLAGS -------- -NOMESSAGE: don't print a "2 more to go..."-like message when triggered -*/ - -/*QUAKED trigger_delay (.5 .5 .5) (-8 -8 -8) (8 8 8) -Trigger that delays triggering by a given amount of time. Only one action can be waited for; if triggered again before the "wait" time expires, the timer will restart (as opposed to trigger_relay). --------- KEYS -------- -wait: delay the triggering by the given time -target: trigger all entities with this targetname when triggered -targetname: name that identifies this entity so it can be triggered -message: print this message to the player who activated the trigger -killtarget: remove all entities with this targetname when triggered -*/ - -/*QUAKED trigger_hurt (.5 .5 .5) ? -Any object touching this will be hurt. -Has the useful effect of automatically returning flags, keys and runes when they touch it. --------- KEYS -------- -dmg: amount of damage to deal (default: 1000) -message: kill message when someone gets killed by this (default: "was in the wrong place") -message2: kill message when someone gets pushed into this (default: "was thrown into a world of hurt by"). The # character is replaced by the attacker name if present (and it instead does not get appended to the end) -*/ - -/*QUAKED trigger_impulse (.5 .5 .5) ? -An accelerator/dampener/wind field. -Can be used in two ways: -"dampener field": just set strength to a value from 0 to 1. Entering the field will slow down to this factor. -"accelerator field": just set strength to a value from 1 to infinity. Entering the field will accelerate by this factor. -"wind field": set strength to the amount of velocity to add per second, and target a target_position. The field will apply force in the direction from its own origin to the target (use an origin brush to specify its own origin, or this will fail) when touched. -"gravity field": set strength to the amount of velocity to add per second at the center, and set radius to the radius of the field. Set falloff to the desired falloff characteristics. --------- KEYS -------- -target: "wind field": points to the target_position to which the player will get pushed. -strength: "wind field", "gravity field": amount of force per second to apply. "dampener/accelerator field": slowdown/speedup factor. -falloff: "gravity field": 0 means no falloff, 1 means linear falloff (zero at the outside), 2 means inverted linear falloff (zero at the inside) -*/ - -/*QUAKED trigger_multiple (.5 .5 .5) ? NOTOUCH ALLENTS - - - - - - NOSPLASH -Variable sized repeatable trigger. Must be targeted at one or more entities. If "health" is set, the trigger must be killed to activate each time. --------- KEYS -------- -health: amount of damage that has to be dealt to the trigger to activate (it then won't respond to merely touching it) -wait: prevent triggering again for this amount of time (default: 0.2, set to -1 to wait indefinitely, or -2 to not wait at all) -sounds: 1 to play misc/secret.wav, 2 to play misc/talk.wav, 3 to play misc/trigger1.wav -noise: path to sound file, if you want to play something else -target: trigger all entities with this targetname when triggered -target2: trigger all entities with this targetname when triggered -target3: trigger all entities with this targetname when triggered -target4: trigger all entities with this targetname when triggered -targetname: name that identifies this entity so it can be triggered -delay: delay the triggering by the given time -message: print this message to the player who activated the trigger -killtarget: remove all entities with this targetname when triggered --------- SPAWNFLAGS -------- -NOTOUCH: the trigger can only be triggered by other entities, not by touching or firing (you should probably use trigger_relay or trigger_delay instead) -ALLENTS: the trigger responds to all entities, not just players (useful for targetting trigger_items) -NOSPLASH: if set, splash damage cannot activate the door, only direct damage can (requires health to be set) -*/ - -/*QUAKED trigger_once (.5 .5 .5) ? NOTOUCH - - - - - - - NOSPLASH -Variable sized repeatable trigger. Must be targeted at one or more entities. If "health" is set, the trigger must be killed to activate each time. -Basically, it's a use-once trigger_multiple. --------- KEYS -------- -health: amount of damage that has to be dealt to the trigger to activate (it then won't respond to merely touching it) -sounds: 1 to play misc/secret.wav, 2 to play misc/talk.wav, 3 to play misc/trigger1.wav -noise: path to sound file, if you want to play something else -target: trigger all entities with this targetname when triggered -targetname: name that identifies this entity so it can be triggered -delay: delay the triggering by the given time -message: print this message to the player who activated the trigger -killtarget: remove all entities with this targetname when triggered --------- SPAWNFLAGS -------- -NOTOUCH: the trigger can only be triggered by other entities, not by touching or firing (you should probably use trigger_relay or trigger_delay instead) -NOSPLASH: if set, splash damage cannot activate the door, only direct damage can (requires health to be set) -*/ - -/*QUAKED trigger_push (1 .5 0) ? - - INVERT_TEAM -Jump pad. What else? -Can be used in three ways: -Xonotic "target/height" way: put the target_position where the player should land, and tune height to get a nice jump path. A good starting value for height is 100. -Q3A "target" way: put the target_position at the apex of the jump, and hope the player will land at the right spot. Good luck. -Quake "movedir/speed" way: player will get velocity movedir * speed * 10 when using the jump pad --------- KEYS -------- -target: point the player will fly to when using the jump pad (use a target_position here) -height: if height is 0, the (player's origin at the) apex of the jump will be at the target; otherwise, the apex will be abs(height) above the higher point of player's origin and the target; if positive, the apex will be reached in the jump from initial origin to target -movedir: when target is not set, direction vector to push to -speed: speed of jump pad (default: 1000) -noise: sound to play when jump pad is used; default is misc/jumppad.wav; you can set it to "" to make the pad silent -team: team that owns this jump pad (5 = red, 14 = blue, etc) (when set, only this team can teleport) -targetname: when targeted by a func_button, pressing the button will reassign the teleporter to the team of the activator. --------- SPAWNFLAGS -------- -INVERT_TEAM: the team that owns the teleporter will NOT jump when touching this -*/ - -/*QUAKED trigger_relay (.5 .5 .5) (-8 -8 -8) (8 8 8) -This fixed size trigger cannot be touched, it can only be fired by other events. It can, like any other trigger, contain killtargets, targets, delays, and messages. -One possible use is to trigger entities with more than one targetname on an action, e.g. a button. For this, set target of your button to foobar. Create two trigger_relay with targetname=foobar. Give one of the trigger_relay entities target=ent1, and give the other target=ent2. -More than one "trigger event" can be delayed at once, as opposed to trigger_delay. --------- KEYS -------- -target: trigger all entities with this targetname when triggered -target2: trigger all entities with this targetname when triggered -target3: trigger all entities with this targetname when triggered -target4: trigger all entities with this targetname when triggered -targetname: name that identifies this entity so it can be triggered -delay: delay the triggering by the given time -message: print this message to the player who activated the trigger -killtarget: remove all entities with this targetname when triggered -*/ - -/*QUAKED trigger_swamp (.5 .5 .5) ? -Players getting into the swamp will get slowed down and damaged --------- KEYS -------- -dmg: damage per interval to deal (default is 5) -swamp_interval: interval of damage when in swamp (default is 1) -swamp_slowdown: amount of slowdown caused by the swamp (default is 0.5) -*/ - -/*QUAKED trigger_teleport (.5 .5 .5) ? - - INVERT_TEAM -Touching this will teleport players to the location of the targeted misc_teleporter_dest entity. -Note that in Xonotic, teleporters preserve momentum of the player using them. --------- KEYS -------- -target: this must point to a misc_teleporter_dest entity. If it points to more than one, a destination is randomly selected on teleport. -team: team that owns this teleporter (5 = red, 14 = blue, etc) (when set, only this team can teleport) -targetname: when targeted by a func_button, pressing the button will reassign the teleporter to the team of the activator. --------- SPAWNFLAGS -------- -INVERT_TEAM: the team that owns the teleporter will NOT teleport when touching this -*/ - -/*QUAKED weapon_crylink (1 0 .5) (-30 -30 0) (30 30 32) FLOATING -the Crylink --------- KEYS -------- -ammo_cells: initial cells of the weapon (if unset, g_pickup_cells is used) -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/weapons/g_crylink.md3" -*/ - -/*QUAKED weapon_electro (1 0 .5) (-30 -30 0) (30 30 32) FLOATING -the Electro --------- KEYS -------- -ammo_cells: initial cells of the weapon (if unset, g_pickup_cells is used) -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/weapons/g_electro.md3" -*/ - -/*QUAKED weapon_grenadelauncher (1 0 .5) (-30 -30 0) (30 30 32) FLOATING -the Mortar --------- KEYS -------- -ammo_rockets: initial rockets of the weapon (if unset, g_pickup_rockets is used) -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/weapons/g_gl.md3" -*/ - -/*QUAKED weapon_hagar (1 0 .5) (-30 -30 0) (30 30 32) FLOATING -the Hagar --------- KEYS -------- -ammo_rockets: initial rockets of the weapon (if unset, g_pickup_rockets is used) -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/weapons/g_hagar.md3" -*/ - -/*QUAKED weapon_laser (1 0 .5) (-30 -30 0) (30 30 32) FLOATING -the Laser. Note that unless you use - settemp_for_type all g_start_weapon_laser 0 -in your mapinfo file, everyone will already spawn with one, making this pickup useless. --------- KEYS -------- -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/weapons/g_laser.md3" -*/ - -/*QUAKED weapon_nex (1 0 .5) (-30 -30 0) (30 30 32) FLOATING -the Nex -In Minstagib, this turns into an item_minst_cells if no explicit item_minst_cells have been placed. --------- KEYS -------- -ammo_cells: initial cells of the weapon (if unset, g_pickup_cells is used) -respawntime: time till it respawns (default: 15 * g_balance_nex_respawntime_modifier) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/weapons/g_nex.md3" -*/ - -/*QUAKED weapon_rocketlauncher (1 0 .5) (-30 -30 0) (30 30 32) FLOATING -the Rocket Launcher -In Minstagib, this turns into an item_minst_cells if no explicit item_minst_cells have been placed. --------- KEYS -------- -ammo_rockets: initial rockets of the weapon (if unset, g_pickup_rockets is used) -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/weapons/g_rl.md3" -*/ - -/*QUAKED weapon_shotgun (1 0 .5) (-30 -30 0) (30 30 32) FLOATING -the Shotgun. Note that unless you use - settemp_for_type all g_start_weapon_shotgun 0 -in your mapinfo file, everyone will already spawn with one, making this pickup useless. --------- KEYS -------- -ammo_shells: initial shells of the weapon (if unset, g_pickup_shells is used) -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/weapons/g_shotgun.md3" -*/ - -/*QUAKED weapon_uzi (1 0 .5) (-30 -30 0) (30 30 32) FLOATING -the Machine Gun --------- KEYS -------- -ammo_nails: initial bullets of the weapon (if unset, g_pickup_nails is used) -respawntime: time till it respawns (default: 15) -team: out of items with the same value here, only one (random one) will spawn. Useful to put multiple items on one spot. -cnt: weight of this item for random selection using "team". Set to a lower value for items you want to see less likely. --------- SPAWNFLAGS -------- -FLOATING: the item will float in air, instead of aligning to the floor by falling --------- MODEL FOR RADIANT ONLY - DO NOT SET THIS AS A KEY -------- -model="models/weapons/g_uzi.md3" -*/ - -/*QUAKED worldspawn (0 0 0) ? -The world. -If you see this, the currently selected brush is not of an entity. --------- KEYS -------- -fog: fog parameters of the map (density red green blue alpha mindist maxdist); works just like the "fog" console command -author: name of the author of the map, if not specified in "message". Will get copied to the "author" entry of the mapinfo file when none is present. -message: text to print at user logon. Used for name of level. Ideally: "NAMEOFLEVEL by AUTHOR". Will get copied to the "title" and "author" entries of the mapinfo file when none is present. -_description: one-line description of the map. Will get copied to the "description" entry of the mapinfo file when none is present. --------- Q3MAP2 KEYS -------- -_blocksize: vector specifying the automatic vis subdivision block size (default: 1024 1024 1024) -gridsize: lightgrid granularity vector (default: 64 64 128) -_color: color of the global light parameters -_ambient: light added to all surfaces -_mingridlight: minimum grid light -_minlight: minimum light value on both surfaces and lightgrid -_keepLights: do not remove light entities from the map (useful e.g. for realtime lighting) -_floodlight: flood light parameters (red green blue distance intensity), start with 240 240 255 1024 128 -_farplanedist: range after which everything is completely invisible by fog (when fog is being used) -_noshadersun: turn off sun defined by shaders (useful if you defined your own light entity to be a sun) -_ignoreleaks: ignore leaks when compiling -_lightmapscale: light map resolution factor -_castshadows: Allows per-entity control over shadow casting. Defaults to 0 on entities, 1 on world. 0 = no shadow casting.1 = cast shadows on world. > 1 = cast shadows on entities with _rs (or _receiveshadows) with the corresponding value, AND world. Negative values imply same, but DO NOT cast shadows on world. -_receiveshadows: Allows per-entity control over shadow reception. Defaults to 1 on everything (world shadows). 0 = receives NO shadows. > 1 = receive shadows only from corresponding keyed entities (see above) and world. < 1 = receive shadows ONLY from corresponding keyed entities. -_celshader: Sets the cel shader used for this geometry. Note: omit the "textures/" prefix. -*/ - -/*QUAKED trigger_race_checkpoint (0 1 0) ? NOTOUCH STRICTTRIGGER CRUSH FINISH -A checkpoint, for the race game mode. Be sure to make them quite long, so they actually catch a player reliably! --------- KEYS -------- -cnt: Number of the checkpoint. 0 for start/finish line, and at least two other checkpoints have to exist. They MUST be touched in sequential order! -message: Death message, when touching checkpoints in the wrong order. -message2: Death message when someone gets pushed into this (default: "was thrown into a world of hurt by"). The # character is replaced by the attacker name if present (and it instead does not get appended to the end) -targetname: Name of the checkpoint. info_player_race can target this to assign a spawn to a checkpoint. Also used for triggering a checkpoint by an event. -target: when the checkpoint is passed, these entities are triggered. Useful for forcing items in certain areas using trigger_items -race_penalty: when set, this penalty time is given if passing this checkpoint, and the checkpoint does not show up with a sprite. Useful for invisible checkpoints to detect driving around the intended checkpoint -race_penalty_reason: reason to display when the penalty time is imposed. Default: "missing a checkpoint" --------- SPAWNFLAGS -------- -NOTOUCH: the checkpoint will not become active when touched, it HAS to be targeted -STRICTTRIGGER: only trigger the targets when the checkpoint actually was reached in a valid way (that is, not when going back) -CRUSH: the checkpoint kills when used at the wrong time -FINISH: when set on the last checkpoint (i.e. the one with highest cnt), it is marked as finish line and the CP with cnt=0 is the start line -*/ - -/*QUAKED trigger_race_penalty (0 1 0) ? NOTOUCH -A penalty trigger. --------- KEYS -------- -race_penalty: this penalty time is given if passing this trigger -race_penalty_reason: reason to display when the penalty time is imposed. Default: "leaving the track" --------- SPAWNFLAGS -------- -NOTOUCH: the trigger will not become active when touched, it HAS to be targeted -*/ - -/*QUAKED info_player_race (1 0.5 0) (-16 -16 -24) (16 16 45) -Race spawn point. -NOTE for race_place: when the race starts after the qualifying, the player with the fastest lap ends up at the info_player_race with race_place 1, and so on. If there are too many players, or if someone comes in later, he will spawn at an info_player_race with highest race_place. If someone dies after reaching the the starting checkpoint, he will spawn at race_place 0. So for each trigger_race_checkpoint, there must be at least one corresponding info_player_race with race_place NOT set. --------- KEYS -------- -target: this should point to a trigger_race_checkpoint to decide when this spawning point is active. The checkpoint has to be AFTER this spawn. -target2: trigger all entities with this targetname when someone spawns -cnt: weight of spawn point for random selection. Set to a lower value if you have many spawn points close together. Default value is 1. -race_place: if target points to the trigger_race_checkpoint with cnt 0 (finish line), this sets which place the spawn corresponds to; the special value 0 stands for spawns for players who died in game, and -1 marks the spawnpoint for qualifying mode only; any race map must have spawnpoints with race_place being 1, 2, 3 or it gets marked as a frustrating map -restriction: when 1, only bots can spawn here; when 2, only humans can spawn here (be careful with these, or the game will crash because someone cannot spawn) -*/ - -/*QUAKED func_pointparticles (.5 .5 .5) ? START_ON IMPULSE -A brush that emits particles. --------- KEYS -------- -mdl: particle effect name from effectinfo.txt -impulse: when positive, number of particles to emit per second; when negative; number of particles to emit per second and 64^3 block -velocity: particle direction and speed -waterlevel: extra velocity jitter amount -count: particle count multiplier (per spawned particle) -movedir: when set, trace direction (particles will then be emitted from the surface the trace hits); the length of the vector is used as strength of taking the normal of the trace into account -noise: sound to play when the particle is emitted -atten: distance attenuation of the sound (a value from 0.1 to 3.9), default is 0.5; set to -1 for no attenuation (global sound) -volume: volume of the sound -targetname: name to target this (then its state is toggled) -bgmscript: emitter class from the BGM script -bgmscriptattack: attack time of the effect strength (0 to 3.9) -bgmscriptdecay: decay time of the effect strength (0 to 3.9) -bgmscriptsustain: sustain level of the effect strength (0.1 to 1, set to -1 to disable sustain) -bgmscriptrelease: release time of the effect strength (0 to 3.9) --------- SPAWNFLAGS -------- -START_ON: when targeted, the particle emitter will start switched on -IMPULSE: only send the full amount of impulse particles when the entity is triggered --------- NOTES -------- -Use trigger_monoflop if you want the particles to turn off for a while, then turn back on. -A BGM script is a .bgs file named like the map, in the maps directory. Its format is lines of the form -