Difference between revisions of "Temp Entity Events (Half-Life 1)"

From AlliedModders Wiki
Jump to: navigation, search
(Started to add list of HL const.h TempEnts)
 
(Add proper 107, TE_EXPLODEMODEL.)
 
(3 intermediate revisions by 2 users not shown)
Line 1: Line 1:
 +
{{LanguageSwitch}}
 +
 
Add Main Description Here.
 
Add Main Description Here.
  
Line 6: Line 8:
 
Sets the type of message the temp entity is transmitted in.
 
Sets the type of message the temp entity is transmitted in.
  
MSG_ types that can be used for ''dest'' in [http://www.amxmodx.org/funcwiki.php?go=func&id=262 message_begin] are listed below:
+
MSG_ types that can be used for ''dest'' field in [http://www.amxmodx.org/funcwiki.php?go=func&id=262 message_begin] are as follows:
 
<pre>#define MSG_BROADCAST 0 // unreliable to all
 
<pre>#define MSG_BROADCAST 0 // unreliable to all
 
#define MSG_ONE 1 // reliable to one (msg_entity)
 
#define MSG_ONE 1 // reliable to one (msg_entity)
 
#define MSG_ALL 2 // reliable to all
 
#define MSG_ALL 2 // reliable to all
#define MSG_INIT 3 // write to the init string
+
#define MSG_INIT 3 // write to the init string
 
#define MSG_PVS 4 // Ents in PVS of org
 
#define MSG_PVS 4 // Ents in PVS of org
 
#define MSG_PAS 5 // Ents in PAS of org
 
#define MSG_PAS 5 // Ents in PAS of org
#define MSG_PVS_R 6 // Reliable to PVS
+
#define MSG_PVS_R 6 // Reliable to PVS
#define MSG_PAS_R 7 // Reliable to PAS
+
#define MSG_PAS_R 7 // Reliable to PAS
 
#define MSG_ONE_UNRELIABLE 8 // Send to one client, but don't put in reliable stream, put in unreliable datagram (could be dropped)
 
#define MSG_ONE_UNRELIABLE 8 // Send to one client, but don't put in reliable stream, put in unreliable datagram (could be dropped)
#define MSG_SPEC 9 // Sends to all spectator proxies</pre>
+
#define MSG_SPEC 9 // Sends to all spectator proxies</pre>
  
  
Line 26: Line 28:
  
 
== 0: TE_BEAMPOINTS ==
 
== 0: TE_BEAMPOINTS ==
Creates a beam between two points.
+
<font size=3>Creates a beam between two points.</font>
  
  
=== Options ===
+
<font size=4>Options</font>
 
{| border="1" cellpadding="5"
 
{| border="1" cellpadding="5"
 
|- style="background:#efefef;"
 
|- style="background:#efefef;"
Line 91: Line 93:
  
  
=== Format ===
+
<font size=4>Format</font>
<pre>#define TE_BEAMPOINTS 0 // beam effect between two points
+
<pre>#define TE_BEAMPOINTS 0 // beam effect between two points
 +
 
 +
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 +
write_byte(TE_BEAMPOINTS)
 +
write_coord() // start position
 +
write_coord()
 +
write_coord()
 +
write_coord() // end position
 +
write_coord()
 +
write_coord()
 +
write_short() // sprite index
 +
write_byte() // starting frame
 +
write_byte() // frame rate in 0.1's
 +
write_byte() // life in 0.1's
 +
write_byte() // line width in 0.1's
 +
write_byte() // noise amplitude in 0.01's
 +
write_byte() // Red
 +
write_byte() // Green
 +
write_byte() // Blue
 +
write_byte() // brightness
 +
write_byte() // scroll speed in 0.1's
 +
message_end()</pre>
 +
 
 +
 
 +
 
 +
== 1: TE_BEAMENTPOINT ==
 +
<font size=3>Creates a beam between the primary entity and a point.</font>
 +
 
 +
 
 +
<font size=4>Options</font>
 +
{| border="1" cellpadding="5"
 +
|- style="background:#efefef;"
 +
! Option || Range || Default || Description
 +
|-
 +
|nowrap="1"| Start Entity
 +
|nowrap="1"| ID of Entity
 +
|nowrap="1"| Primary entity id
 +
|Starting point of the beam from the id's origin
 +
|-
 +
|nowrap="1"| End
 +
|nowrap="1"| X Y Z (coords)
 +
|nowrap="1"| Origin of secondary entity, or 0 0 0
 +
|Ending point of the beam
 +
|-
 +
|nowrap="1"| Sprite
 +
|nowrap="1"| sprite path
 +
|nowrap="1"| "sprites/laserbeam.spr"
 +
|The sprite to use in the beam
 +
|-
 +
|nowrap="1"| FrameStart
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 0
 +
|The frame to start with in the sprite
 +
|-
 +
|nowrap="1"| FrameRate
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 0
 +
|The frame rate to show the sprite at, in 0.1s (10 = 1 fps)
 +
|-
 +
|nowrap="1"| Life
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 50
 +
|The length of time the beam shall remain, in 0.1s (50 = 5 seconds)
 +
|-
 +
|nowrap="1"| Width
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 10
 +
|The width of the beam in 0.1s
 +
|-
 +
|nowrap="1"| Noise
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 10
 +
|The noise amplitude of the beam, this controls how much the beam distorts, again in 0.1s
 +
|-
 +
|nowrap="1"| Color
 +
|nowrap="1"| R G B
 +
|nowrap="1"| 255 255 255
 +
|The color of the beam in the RBG triplet value
 +
|-
 +
|nowrap="1"| Brightness
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 127
 +
|The brightness of the beam
 +
|-
 +
|nowrap="1"| Scroll
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 0
 +
|The scroll speed of the beam, in 0.1s (??)
 +
|}
 +
 
 +
 
 +
<font size=4>Format</font>
 +
<pre>#define TE_BEAMENTPOINT 1 // beam effect between point and entity
 +
 
 +
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 +
write_byte(TE_BEAMENTPOINT)
 +
write_short() // start entity
 +
write_coord() // end position
 +
write_coord()
 +
write_coord()
 +
write_short() // sprite index
 +
write_byte() // starting frame
 +
write_byte() // frame rate in 0.1's
 +
write_byte() // life in 0.1's
 +
write_byte() // line width in 0.1's
 +
write_byte() // noise amplitude in 0.01's
 +
write_byte() // Red
 +
write_byte() // Green
 +
write_byte() // Blue
 +
write_byte() // brightness
 +
write_byte() // scroll speed in 0.1's
 +
message_end()</pre>
 +
 
 +
 
 +
 
 +
== 2: TE_GUNSHOT ==
 +
<font size=3>Creates a particle effect plus a ricochet sound.</font>
 +
 
 +
 
 +
<font size=4>Options</font>
 +
{| border="1" cellpadding="5"
 +
|- style="background:#efefef;"
 +
! Option || Range || Default || Description
 +
|-
 +
|nowrap="1"| Pos
 +
|nowrap="1"| X Y Z (coords)
 +
|nowrap="1"| Origin of primary entity, or 0 0 0
 +
|Position of the gunshot effect
 +
|}
 +
 
 +
 
 +
<font size=4>Format</font>
 +
<pre>#define TE_GUNSHOT 2 // particle effect plus ricochet sound
 +
 
 +
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 +
write_byte(TE_GUNSHOT)
 +
write_coord() // start position
 +
write_coord()
 +
write_coord()
 +
message_end()</pre>
 +
 
 +
 
 +
 
 +
== 3: TE_EXPLOSION ==
 +
<font size=3>Creates an additive sprite, 2 dynamic lights, flickering particles, explosion sound, and moves the sprite vertically.</font>
 +
 
 +
 
 +
<font size=4>Options</font>
 +
{| border="1" cellpadding="5"
 +
|- style="background:#efefef;"
 +
! Option || Range || Default || Description
 +
|-
 +
|nowrap="1"| Pos
 +
|nowrap="1"| X Y Z (coords)
 +
|nowrap="1"| Origin of primary entity, or 0 0 0
 +
|Position of the explosion effect
 +
|-
 +
|nowrap="1"| Sprite
 +
|nowrap="1"| sprite path
 +
|nowrap="1"| "sprites/zerogxplode.spr"
 +
|The additive sprite to use in the explosion
 +
|-
 +
|nowrap="1"| Scale
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 1
 +
|The scale of the sprite in the explosion, in 0.1s
 +
|-
 +
|nowrap="1"| FrameRate
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 0
 +
|The frame rate to show the sprite at, in 0.1s (10 = 1 fps)
 +
|-
 +
|nowrap="1"| Flags
 +
|nowrap="1"| 0-15
 +
|nowrap="1"| 0
 +
|Sets flags for the explosion, you may also add these together:
 +
*0: Default Half-Life explosion
 +
*1: Sprite will be drawn opaque
 +
*2: Do not render the dynamic lights
 +
*4: Do not play the explosion sound
 +
*8: Do not draw the particles
 +
|}
 +
 
 +
 
 +
<font size=4>Format</font>
 +
<pre>#define TE_EXPLOSION 3 // additive sprite, 2 dynamic lights, flickering particles, explosion sound, move vertically 8 pps
 +
 
 +
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 +
write_byte(TE_EXPLOSION)
 +
write_coord() // start position
 +
write_coord()
 +
write_coord()
 +
write_short() // sprite index
 +
write_byte() // scale in 0.1's
 +
write_byte() // framerate
 +
write_byte() // flags
 +
message_end()</pre>
 +
 
 +
 
 +
 
 +
== 4: TE_TAREXPLOSION ==
 +
<font size=3>Creates the Quake 'tar' explosion.</font>
 +
 
 +
 
 +
<font size=4>Options</font>
 +
{| border="1" cellpadding="5"
 +
|- style="background:#efefef;"
 +
! Option || Range || Default || Description
 +
|-
 +
|nowrap="1"| Pos
 +
|nowrap="1"| X Y Z (coords)
 +
|nowrap="1"| Origin of primary entity, or 0 0 0
 +
|Position of the effect
 +
|}
 +
 
 +
 
 +
<font size=4>Format</font>
 +
<pre>#define TE_TAREXPLOSION 4 // Quake1 "tarbaby" explosion with sound
 +
 
 +
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 +
write_byte(TE_TAREXPLOSION)
 +
write_coord() // start position
 +
write_coord()
 +
write_coord()
 +
message_end()</pre>
 +
 
 +
 
 +
 
 +
== 5: TE_SMOKE ==
 +
<font size=3>Creates a rising alphablend sprite at 30 pps.</font>
 +
 
 +
 
 +
<font size=4>Options</font>
 +
{| border="1" cellpadding="5"
 +
|- style="background:#efefef;"
 +
! Option || Range || Default || Description
 +
|-
 +
|nowrap="1"| Pos
 +
|nowrap="1"| X Y Z (coords)
 +
|nowrap="1"| Origin of primary entity, or 0 0 0
 +
|Position of the smoke effect
 +
|-
 +
|nowrap="1"| Sprite
 +
|nowrap="1"| sprite path
 +
|nowrap="1"| "sprites/steam1.spr"
 +
|The alphablend sprite to use for smoke
 +
|-
 +
|nowrap="1"| Scale
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 1
 +
|The scale of the smoke, in 0.1s
 +
|-
 +
|nowrap="1"| FrameRate
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 0
 +
|The frame rate to show the sprite at
 +
|}
 +
 
 +
 
 +
<font size=4>Format</font>
 +
<pre>#define TE_SMOKE 5 // alphablend sprite, move vertically 30 pps
 +
 
 +
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 +
write_byte(TE_SMOKE)
 +
write_coord() // start position
 +
write_coord()
 +
write_coord()
 +
write_short() // sprite index
 +
write_byte() // scale in 0.1's
 +
write_byte() // framerate
 +
message_end()</pre>
 +
 
 +
 
 +
 
 +
== 6: TE_TRACER ==
 +
<font size=3>Creates a tracer effect from one point to another.</font>
 +
 
 +
 
 +
<font size=4>Options</font>
 +
{| border="1" cellpadding="5"
 +
|- style="background:#efefef;"
 +
! Option || Range || Default || Description
 +
|-
 +
|nowrap="1"| Pos
 +
|nowrap="1"| X Y Z (coords)
 +
|nowrap="1"| Origin of primary entity, or 0 0 0
 +
|Starting point of the tracer
 +
|-
 +
|nowrap="1"| End
 +
|nowrap="1"| X Y Z (coords)
 +
|nowrap="1"| Origin of secondary entity, or 0 0 0
 +
|Ending point of the tracer
 +
|}
 +
 
 +
 
 +
<font size=4>Format</font>
 +
<pre>#define TE_TRACER 6 // tracer effect from point to point
 +
 
 +
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 +
write_byte(TE_TRACER)
 +
write_coord() // start position
 +
write_coord()
 +
write_coord()
 +
write_coord() // end position
 +
write_coord()
 +
write_coord()
 +
message_end()</pre>
 +
 
 +
 
 +
 
 +
== 7: TE_LIGHTNING ==
 +
<font size=3>Simplified options for TE_BEAMPOINTS - Lightning effect.</font>
 +
 
 +
 
 +
<font size=4>Options</font>
 +
{| border="1" cellpadding="5"
 +
|- style="background:#efefef;"
 +
! Option || Range || Default || Description
 +
|-
 +
|nowrap="1"| Pos
 +
|nowrap="1"| X Y Z (coords)
 +
|nowrap="1"| Origin of primary entity, or 0 0 0
 +
|Starting point of the lightning
 +
|-
 +
|nowrap="1"| End
 +
|nowrap="1"| X Y Z (coords)
 +
|nowrap="1"| Origin of secondary entity, or 0 0 0
 +
|Ending point of the lightning
 +
|-
 +
|nowrap="1"| Life
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 50
 +
|The length of time the lightning shall remain, in 0.1s (50 = 5 seconds)
 +
|-
 +
|nowrap="1"| Width
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 10
 +
|The width of the lightning in 0.1s
 +
|-
 +
|nowrap="1"| Noise
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 10
 +
|The noise amplitude of the lightning, this controls how much it distorts, again in 0.1s
 +
|-
 +
|nowrap="1"| Sprite
 +
|nowrap="1"| sprite path
 +
|nowrap="1"| "sprites/laserbeam.spr"
 +
|The sprite to use in the lightning
 +
|}
 +
 
 +
 
 +
<font size=4>Format</font>
 +
<pre>#define TE_LIGHTNING 7 // TE_BEAMPOINTS with simplified parameters
 +
 
  
message_begin(MSG_ ,SVC_TEMPENTITY) // message begin
+
message_begin(MSG_ ,SVC_TEMPENTITY)
write_byte(TE_BEAMPOINTS)  
+
write_byte(TE_LIGHTNING)
write_coord() // start position  
+
write_coord() // start position
write_coord()  
+
write_coord()
write_coord()  
+
write_coord()
 
write_coord() // end position  
 
write_coord() // end position  
write_coord()  
+
write_coord()
write_coord()  
+
write_coord()
write_short() // sprite index
 
write_byte() // starting frame
 
write_byte() // frame rate in 0.1's
 
 
write_byte() // life in 0.1's  
 
write_byte() // life in 0.1's  
write_byte() // line width in 0.1's  
+
write_byte() // width in 0.1's  
write_byte() // noise amplitude in 0.01's  
+
write_byte() // amplitude in 0.01's  
write_byte() // Red
+
write_short() // sprite model index
write_byte() // Green
 
write_byte() // Blue
 
write_byte() // brightness
 
write_byte() // scroll speed in 0.1's
 
 
message_end()</pre>
 
message_end()</pre>
  
  
  
== 1: TE_BEAMENTPOINT ==
+
== 8: TE_BEAMENTS ==
Creates a beam between the primary entity and a point.
+
<font size=3>Creates a beam between the primary entity and another entity.</font>
  
  
=== Options ===
+
<font size=4>Options</font>
 
{| border="1" cellpadding="5"
 
{| border="1" cellpadding="5"
 
|- style="background:#efefef;"
 
|- style="background:#efefef;"
 
! Option || Range || Default || Description
 
! Option || Range || Default || Description
 +
|-
 +
|nowrap="1"| Start Entity
 +
|nowrap="1"| ID of Entity
 +
|nowrap="1"| Primary entity id
 +
|Starting point of the beam from the id's origin
 +
|-
 +
|nowrap="1"| End Entity
 +
|nowrap="1"| ID of Entity
 +
|nowrap="1"| Secondary entity id
 +
|Ending point of the beam to the id's origin
 +
|-
 +
|nowrap="1"| Sprite
 +
|nowrap="1"| sprite path
 +
|nowrap="1"| "sprites/laserbeam.spr"
 +
|The sprite to use in the beam
 +
|-
 +
|nowrap="1"| FrameStart
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 0
 +
|The frame to start with in the sprite
 +
|-
 +
|nowrap="1"| FrameRate
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 0
 +
|The frame rate to show the sprite at, in 0.1s (10 = 1 fps)
 +
|-
 +
|nowrap="1"| Life
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 50
 +
|The length of time the beam shall remain, in 0.1s (50 = 5 seconds)
 +
|-
 +
|nowrap="1"| Width
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 10
 +
|The width of the beam in 0.1s
 +
|-
 +
|nowrap="1"| Noise
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 10
 +
|The noise amplitude of the beam, this controls how much the beam distorts, again in 0.1s
 +
|-
 +
|nowrap="1"| Color
 +
|nowrap="1"| R G B
 +
|nowrap="1"| 255 255 255
 +
|The color of the beam in the RBG triplet value
 +
|-
 +
|nowrap="1"| Brightness
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 127
 +
|The brightness of the beam
 +
|-
 +
|nowrap="1"| Scroll
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 0
 +
|The scroll speed of the beam, in 0.1s (??)
 
|}
 
|}
  
  
=== Format ===
+
<font size=4>Format</font>
 +
<pre>#define TE_BEAMENTS 8 // Create a beam between two entities
 +
 
 +
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 +
write_byte(TE_BEAMENTS)
 +
write_short() // start entity
 +
write_short()  // end entity
 +
write_short() // sprite index
 +
write_byte() // starting frame
 +
write_byte() // frame rate in 0.1's
 +
write_byte() // life in 0.1's
 +
write_byte() // line width in 0.1's
 +
write_byte() // noise amplitude in 0.01's
 +
write_byte() // red
 +
write_byte() // green
 +
write_byte() // blue
 +
write_byte() // brightness
 +
write_byte() // scroll speed in 0.1's
 +
message_end()</pre>
 +
 
 +
== 107: TE_EXPLODEMODEL ==
 +
<font size=3>Spherical shower of models, picks from set.</font>
 +
 
 +
 
 +
<font size=4>Options</font>
 +
{| border="1" cellpadding="5"
 +
|- style="background:#efefef;"
 +
! Option || Range || Default || Description
 +
|-
 +
|nowrap="1"| Pos
 +
|nowrap="1"| X Y Z (coords)
 +
|nowrap="1"| Origin of primary entity, or 0 0 0
 +
|Position of the explode model effect
 +
|-
 +
|nowrap="1"| Velocity
 +
|nowrap="1"| 1-255
 +
|nowrap="1"| 10
 +
|The velocity of explode model.
 +
|-
 +
|nowrap="1"| Model Index
 +
|nowrap="1"| model path
 +
|nowrap="1"| "models/gib_skull.mdl"
 +
|The file path of model to explode.
 +
|-
 +
|nowrap="1"| Count
 +
|nowrap="1"| 1-1000
 +
|nowrap="1"| 1
 +
|The number of models used.
 +
|-
 +
|nowrap="1"| Life
 +
|nowrap="1"| 0-255
 +
|nowrap="1"| 50
 +
|The length of time the models with remain and blink, in 0.1s (50 = 5 seconds)
 +
|}
 +
<font size=4>Format</font>
 
<pre>
 
<pre>
 +
#define TE_EXPLODEMODEL            107
 +
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 +
write_byte(TE_EXPLODEMODEL)
 +
write_coord(origin.x)
 +
write_coord(origin.y)
 +
write_coord(origin.z)
 +
write_coord(velocity)
 +
write_short(model index)
 +
write_short(count)
 +
write_byte(life in 0.1's)
 +
message_end()
 
</pre>
 
</pre>
  
 
+
TODO: add rest, I'll get this done eventually.
 
 
 
[[Category:Half-Life 1]]
 
[[Category:Half-Life 1]]
 
[[Category:Scripting (AMX Mod X)]]
 
[[Category:Scripting (AMX Mod X)]]

Latest revision as of 20:32, 2 October 2021

Warning: This template (and by extension, language format) should not be used, any pages using it should be switched to Template:Languages

View this page in:  English  Russian  简体中文(Simplified Chinese)

Add Main Description Here.


Message Types

Sets the type of message the temp entity is transmitted in.

MSG_ types that can be used for dest field in message_begin are as follows:

#define MSG_BROADCAST		0	// unreliable to all
#define MSG_ONE			1	// reliable to one (msg_entity)
#define MSG_ALL			2	// reliable to all
#define MSG_INIT		3	// write to the init string
#define MSG_PVS			4	// Ents in PVS of org
#define MSG_PAS			5	// Ents in PAS of org
#define MSG_PVS_R		6	// Reliable to PVS
#define MSG_PAS_R		7	// Reliable to PAS
#define MSG_ONE_UNRELIABLE	8	// Send to one client, but don't put in reliable stream, put in unreliable datagram (could be dropped)
#define MSG_SPEC		9	// Sends to all spectator proxies


TempEnt Events

Add Description Here.


0: TE_BEAMPOINTS

Creates a beam between two points.


Options

Option Range Default Description
Start X Y Z (coords) Origin of primary entity, or 0 0 0 Starting point of the beam
End X Y Z (coords) Origin of secondary entity, or 0 0 0 Ending point of the beam
Sprite sprite path "sprites/laserbeam.spr" The sprite to use in the beam
FrameStart 0-255 0 The frame to start with in the sprite
FrameRate 0-255 0 The frame rate to show the sprite at, in 0.1s (10 = 1 fps)
Life 0-255 50 The length of time the beam shall remain, in 0.1s (50 = 5 seconds)
Width 0-255 10 The width of the beam in 0.1s
Noise 0-255 10 The noise amplitude of the beam, this controls how much the beam distorts, again in 0.1s
Color R G B 255 255 255 The color of the beam in the RBG triplet value
Brightness 0-255 127 The brightness of the beam
Scroll 0-255 0 The scroll speed of the beam, in 0.1s (??)


Format

#define TE_BEAMPOINTS 0		// beam effect between two points


message_begin(MSG_ ,SVC_TEMPENTITY)
write_byte(TE_BEAMPOINTS)
write_coord()	// start position
write_coord()
write_coord()
write_coord()	// end position
write_coord()
write_coord()
write_short()	// sprite index
write_byte()	// starting frame
write_byte()	// frame rate in 0.1's
write_byte()	// life in 0.1's
write_byte()	// line width in 0.1's
write_byte()	// noise amplitude in 0.01's
write_byte()	// Red
write_byte()	// Green
write_byte()	// Blue
write_byte()	// brightness
write_byte()	// scroll speed in 0.1's
message_end()


1: TE_BEAMENTPOINT

Creates a beam between the primary entity and a point.


Options

Option Range Default Description
Start Entity ID of Entity Primary entity id Starting point of the beam from the id's origin
End X Y Z (coords) Origin of secondary entity, or 0 0 0 Ending point of the beam
Sprite sprite path "sprites/laserbeam.spr" The sprite to use in the beam
FrameStart 0-255 0 The frame to start with in the sprite
FrameRate 0-255 0 The frame rate to show the sprite at, in 0.1s (10 = 1 fps)
Life 0-255 50 The length of time the beam shall remain, in 0.1s (50 = 5 seconds)
Width 0-255 10 The width of the beam in 0.1s
Noise 0-255 10 The noise amplitude of the beam, this controls how much the beam distorts, again in 0.1s
Color R G B 255 255 255 The color of the beam in the RBG triplet value
Brightness 0-255 127 The brightness of the beam
Scroll 0-255 0 The scroll speed of the beam, in 0.1s (??)


Format

#define TE_BEAMENTPOINT 1	// beam effect between point and entity


message_begin(MSG_ ,SVC_TEMPENTITY)
write_byte(TE_BEAMENTPOINT)
write_short()	// start entity
write_coord()	// end position
write_coord()
write_coord()
write_short()	// sprite index
write_byte()	// starting frame
write_byte()	// frame rate in 0.1's
write_byte()	// life in 0.1's
write_byte()	// line width in 0.1's
write_byte()	// noise amplitude in 0.01's
write_byte()	// Red
write_byte()	// Green
write_byte()	// Blue
write_byte()	// brightness
write_byte()	// scroll speed in 0.1's
message_end()


2: TE_GUNSHOT

Creates a particle effect plus a ricochet sound.


Options

Option Range Default Description
Pos X Y Z (coords) Origin of primary entity, or 0 0 0 Position of the gunshot effect


Format

#define TE_GUNSHOT 2		// particle effect plus ricochet sound


message_begin(MSG_ ,SVC_TEMPENTITY)
write_byte(TE_GUNSHOT)
write_coord()	// start position
write_coord()
write_coord()
message_end()


3: TE_EXPLOSION

Creates an additive sprite, 2 dynamic lights, flickering particles, explosion sound, and moves the sprite vertically.


Options

Option Range Default Description
Pos X Y Z (coords) Origin of primary entity, or 0 0 0 Position of the explosion effect
Sprite sprite path "sprites/zerogxplode.spr" The additive sprite to use in the explosion
Scale 0-255 1 The scale of the sprite in the explosion, in 0.1s
FrameRate 0-255 0 The frame rate to show the sprite at, in 0.1s (10 = 1 fps)
Flags 0-15 0 Sets flags for the explosion, you may also add these together:
  • 0: Default Half-Life explosion
  • 1: Sprite will be drawn opaque
  • 2: Do not render the dynamic lights
  • 4: Do not play the explosion sound
  • 8: Do not draw the particles


Format

#define TE_EXPLOSION 3		// additive sprite, 2 dynamic lights, flickering particles, explosion sound, move vertically 8 pps


message_begin(MSG_ ,SVC_TEMPENTITY)
write_byte(TE_EXPLOSION)
write_coord()	// start position
write_coord()
write_coord()
write_short()	// sprite index
write_byte()	// scale in 0.1's
write_byte()	// framerate
write_byte()	// flags
message_end()


4: TE_TAREXPLOSION

Creates the Quake 'tar' explosion.


Options

Option Range Default Description
Pos X Y Z (coords) Origin of primary entity, or 0 0 0 Position of the effect


Format

#define TE_TAREXPLOSION 4	// Quake1 "tarbaby" explosion with sound


message_begin(MSG_ ,SVC_TEMPENTITY)
write_byte(TE_TAREXPLOSION)
write_coord()	// start position
write_coord()
write_coord()
message_end()


5: TE_SMOKE

Creates a rising alphablend sprite at 30 pps.


Options

Option Range Default Description
Pos X Y Z (coords) Origin of primary entity, or 0 0 0 Position of the smoke effect
Sprite sprite path "sprites/steam1.spr" The alphablend sprite to use for smoke
Scale 0-255 1 The scale of the smoke, in 0.1s
FrameRate 0-255 0 The frame rate to show the sprite at


Format

#define TE_SMOKE 5			// alphablend sprite, move vertically 30 pps


message_begin(MSG_ ,SVC_TEMPENTITY)
write_byte(TE_SMOKE)
write_coord()	// start position
write_coord()
write_coord()
write_short()	// sprite index 
write_byte()	// scale in 0.1's 
write_byte()	// framerate 
message_end()


6: TE_TRACER

Creates a tracer effect from one point to another.


Options

Option Range Default Description
Pos X Y Z (coords) Origin of primary entity, or 0 0 0 Starting point of the tracer
End X Y Z (coords) Origin of secondary entity, or 0 0 0 Ending point of the tracer


Format

#define TE_TRACER 6			// tracer effect from point to point


message_begin(MSG_ ,SVC_TEMPENTITY)
write_byte(TE_TRACER)
write_coord()	// start position
write_coord()
write_coord()
write_coord()	// end position 
write_coord()
write_coord()
message_end()


7: TE_LIGHTNING

Simplified options for TE_BEAMPOINTS - Lightning effect.


Options

Option Range Default Description
Pos X Y Z (coords) Origin of primary entity, or 0 0 0 Starting point of the lightning
End X Y Z (coords) Origin of secondary entity, or 0 0 0 Ending point of the lightning
Life 0-255 50 The length of time the lightning shall remain, in 0.1s (50 = 5 seconds)
Width 0-255 10 The width of the lightning in 0.1s
Noise 0-255 10 The noise amplitude of the lightning, this controls how much it distorts, again in 0.1s
Sprite sprite path "sprites/laserbeam.spr" The sprite to use in the lightning


Format

#define TE_LIGHTNING 7		// TE_BEAMPOINTS with simplified parameters


message_begin(MSG_ ,SVC_TEMPENTITY)
write_byte(TE_LIGHTNING)
write_coord()	// start position
write_coord()
write_coord()
write_coord()	// end position 
write_coord()
write_coord()
write_byte()	// life in 0.1's 
write_byte()	// width in 0.1's 
write_byte()	// amplitude in 0.01's 
write_short()	// sprite model index
message_end()


8: TE_BEAMENTS

Creates a beam between the primary entity and another entity.


Options

Option Range Default Description
Start Entity ID of Entity Primary entity id Starting point of the beam from the id's origin
End Entity ID of Entity Secondary entity id Ending point of the beam to the id's origin
Sprite sprite path "sprites/laserbeam.spr" The sprite to use in the beam
FrameStart 0-255 0 The frame to start with in the sprite
FrameRate 0-255 0 The frame rate to show the sprite at, in 0.1s (10 = 1 fps)
Life 0-255 50 The length of time the beam shall remain, in 0.1s (50 = 5 seconds)
Width 0-255 10 The width of the beam in 0.1s
Noise 0-255 10 The noise amplitude of the beam, this controls how much the beam distorts, again in 0.1s
Color R G B 255 255 255 The color of the beam in the RBG triplet value
Brightness 0-255 127 The brightness of the beam
Scroll 0-255 0 The scroll speed of the beam, in 0.1s (??)


Format

#define TE_BEAMENTS 8		// Create a beam between two entities


message_begin(MSG_ ,SVC_TEMPENTITY)
write_byte(TE_BEAMENTS)
write_short()	// start entity
write_short()  // end entity
write_short()	// sprite index
write_byte()	// starting frame
write_byte()	// frame rate in 0.1's
write_byte()	// life in 0.1's
write_byte()	// line width in 0.1's
write_byte()	// noise amplitude in 0.01's
write_byte()	// red
write_byte()	// green
write_byte()	// blue
write_byte()	// brightness
write_byte()	// scroll speed in 0.1's
message_end()

107: TE_EXPLODEMODEL

Spherical shower of models, picks from set.


Options

Option Range Default Description
Pos X Y Z (coords) Origin of primary entity, or 0 0 0 Position of the explode model effect
Velocity 1-255 10 The velocity of explode model.
Model Index model path "models/gib_skull.mdl" The file path of model to explode.
Count 1-1000 1 The number of models used.
Life 0-255 50 The length of time the models with remain and blink, in 0.1s (50 = 5 seconds)

Format

#define TE_EXPLODEMODEL             107

message_begin(MSG_ ,SVC_TEMPENTITY)
write_byte(TE_EXPLODEMODEL)
write_coord(origin.x)
write_coord(origin.y)
write_coord(origin.z)
write_coord(velocity)
write_short(model index)
write_short(count)
write_byte(life in 0.1's)
message_end()

TODO: add rest, I'll get this done eventually.