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

From AlliedModders Wiki
Jump to: navigation, search
(Added more TE messages (will cont. later))
m (Added more effects, plus slight change to format)
Line 26: Line 26:
  
 
== 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 77: Line 77:
 
|nowrap="1"| R G B
 
|nowrap="1"| R G B
 
|nowrap="1"| 255 255 255
 
|nowrap="1"| 255 255 255
|The color of the beam in the RGB triplet value
+
|The color of the beam in the RBG triplet value
 
|-
 
|-
 
|nowrap="1"| Brightness
 
|nowrap="1"| Brightness
Line 91: Line 91:
  
  
=== 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) // message begin
+
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 
write_byte(TE_BEAMPOINTS)
 
write_byte(TE_BEAMPOINTS)
 
write_coord() // start position
 
write_coord() // start position
Line 118: Line 119:
  
 
== 1: TE_BEAMENTPOINT ==
 
== 1: TE_BEAMENTPOINT ==
Creates a beam between the primary entity and a point.
+
<font size=3>Creates a beam between the primary entity and a point.</font>
  
  
=== Options ===
+
<font size=4>Options</font>
 
{| border="1" cellpadding="5"
 
{| border="1" cellpadding="5"
 
|- style="background:#efefef;"
 
|- style="background:#efefef;"
Line 169: Line 170:
 
|nowrap="1"| R G B
 
|nowrap="1"| R G B
 
|nowrap="1"| 255 255 255
 
|nowrap="1"| 255 255 255
|The color of the beam in the RGB triplet value
+
|The color of the beam in the RBG triplet value
 
|-
 
|-
 
|nowrap="1"| Brightness
 
|nowrap="1"| Brightness
Line 183: Line 184:
  
  
=== Format ===
+
<font size=4>Format</font>
<pre>#define TE_BEAMENTPOINT 1 // beam effect between point and entity
+
<pre>#define TE_BEAMENTPOINT 1 // beam effect between point and entity
  
message_begin(MSG_ ,SVC_TEMPENTITY) // message begin
+
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 
write_byte(TE_BEAMENTPOINT)
 
write_byte(TE_BEAMENTPOINT)
 
write_short() // start entity
 
write_short() // start entity
Line 208: Line 210:
  
 
== 2: TE_GUNSHOT ==
 
== 2: TE_GUNSHOT ==
Creates a particle effect plus a ricochet sound.
+
<font size=3>Creates a particle effect plus a ricochet sound.</font>
  
  
=== Options ===
+
<font size=4>Options</font>
 
{| border="1" cellpadding="5"
 
{| border="1" cellpadding="5"
 
|- style="background:#efefef;"
 
|- style="background:#efefef;"
Line 223: Line 225:
  
  
=== Format ===
+
<font size=4>Format</font>
<pre>#define TE_GUNSHOT 2 // particle effect plus ricochet sound
+
<pre>#define TE_GUNSHOT 2 // particle effect plus ricochet sound
  
message_begin(MSG_ ,SVC_TEMPENTITY) // message begin
+
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 
write_byte(TE_GUNSHOT)
 
write_byte(TE_GUNSHOT)
 
write_coord() // start position
 
write_coord() // start position
Line 236: Line 239:
  
 
== 3: TE_EXPLOSION ==
 
== 3: TE_EXPLOSION ==
Creates an additive sprite, 2 dynamic lights, flickering particles, explosion sound, and moves the sprite vertically.
+
<font size=3>Creates an additive sprite, 2 dynamic lights, flickering particles, explosion sound, and moves the sprite vertically.</font>
  
  
=== Options ===
+
<font size=4>Options</font>
 
{| border="1" cellpadding="5"
 
{| border="1" cellpadding="5"
 
|- style="background:#efefef;"
 
|- style="background:#efefef;"
Line 276: Line 279:
  
  
=== Format ===
+
<font size=4>Format</font>
<pre>#define TE_EXPLOSION 3 // additive sprite, 2 dynamic lights, flickering particles, explosion sound, move vertically 8 pps
+
<pre>#define TE_EXPLOSION 3 // additive sprite, 2 dynamic lights, flickering particles, explosion sound, move vertically 8 pps
  
message_begin(MSG_ ,SVC_TEMPENTITY) // message begin
+
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 
write_byte(TE_EXPLOSION)
 
write_byte(TE_EXPLOSION)
 
write_coord() // start position
 
write_coord() // start position
Line 293: Line 297:
  
 
== 4: TE_TAREXPLOSION ==
 
== 4: TE_TAREXPLOSION ==
Creates the Quake 'tar' explosion.
+
<font size=3>Creates the Quake 'tar' explosion.</font>
  
  
=== Options ===
+
<font size=4>Options</font>
 
{| border="1" cellpadding="5"
 
{| border="1" cellpadding="5"
 
|- style="background:#efefef;"
 
|- style="background:#efefef;"
Line 308: Line 312:
  
  
=== Format ===
+
<font size=4>Format</font>
<pre>#define TE_TAREXPLOSION 4 // Quake1 "tarbaby" explosion with sound
+
<pre>#define TE_TAREXPLOSION 4 // Quake1 "tarbaby" explosion with sound
 +
 
  
message_begin(MSG_ ,SVC_TEMPENTITY) // message begin
+
message_begin(MSG_ ,SVC_TEMPENTITY)
 
write_byte(TE_TAREXPLOSION)
 
write_byte(TE_TAREXPLOSION)
 
write_coord() // start position
 
write_coord() // start position
Line 321: Line 326:
  
 
== 5: TE_SMOKE ==
 
== 5: TE_SMOKE ==
Creates a rising alphablend sprite at 30 pps.
+
<font size=3>Creates a rising alphablend sprite at 30 pps.</font>
  
  
=== Options ===
+
<font size=4>Options</font>
 
{| border="1" cellpadding="5"
 
{| border="1" cellpadding="5"
 
|- style="background:#efefef;"
 
|- style="background:#efefef;"
Line 351: Line 356:
  
  
=== Format ===
+
<font size=4>Format</font>
 
<pre>#define TE_SMOKE 5 // alphablend sprite, move vertically 30 pps
 
<pre>#define TE_SMOKE 5 // alphablend sprite, move vertically 30 pps
  
message_begin(MSG_ ,SVC_TEMPENTITY) // message begin
+
 
 +
message_begin(MSG_ ,SVC_TEMPENTITY)
 
write_byte(TE_SMOKE)
 
write_byte(TE_SMOKE)
 
write_coord() // start position
 
write_coord() // start position
Line 366: Line 372:
  
  
TO DO: Add rest of TempEnts
+
== 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)
 +
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()</pre>
 +
 
 +
 
 +
 
 +
== 8: TE_BEAMENTS ==
 +
<font size=3>Creates a beam between the primary entity and another entity.</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 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 (??)
 +
|}
 +
 
 +
 
 +
<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>
 +
 
  
 +
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)]]

Revision as of 18:45, 4 February 2006

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()


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