1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
|
# Tremulous Particle System
Files matching the pattern `scripts/*.particle` are loaded as particle system description files.
Each `.particle` file can contain an arbitrary number of discrete particle systems, much like a `.shader` file can house many shaders.
A particle system is declared by a name followed by curly braces within which the functionality of the particle system is defined.
For example:
```
aShinyNewParticleSystem { }
```
Inside the particle system declaration are placed UP TO *four* particle ejectors.
Ejectors are identified by the keyword ejector and curly braces:
```
aShinyNewParticleSystem
{
ejector { }
ejector { }
thirdPersonOnly
}
```
The `thirdPersonOnly` keyword may be used to specify that the particle system is not visible from the first person if it relates to that client.
The role of the particle ejector is to create some number of new particles at a defined rate.
These attributes are controlled by the following parameters:
- count `<number>|infinite` - the number of particles this ejector will spawn.
- delay `<msec>` - the delay in msec before the ejector starts spawning.
- period `<initial> <final> <variance>` - the period between particle ejections.
It is perfectly acceptable to have an initial period of zero.
In this case the number of particles specified by the count keyword will be ejected at once.
It is not permissible to have count infinite and a period of zero for obvious reasons.
At ejection time each ejector creates up to four new particles based on templates.
These are specified in the ejector section using the particle keyword:
```
aShinyNewParticleSystem
{
ejector
{
particle { }
particle { }
count 50
delay 0
period 0 - 0
}
}
```
Each particle template has a number of attributes:
- `shader <fps>|sync <shader1 <shader2> ... <shaderN>` - this specifies the shaders to use for the particle. The frame rate can be set to a static rate or the sync parameter can be used in which case the frame rate will be synchronised to the lifetime of the particle such that the first frame is displayed on birth and the last frame is displayed immediately before death.
- `model <model1> <model2> ... <modelN>` - use one of the specified models as the particle. This cannot be used in conjunction with the shader keyword.
- `modelAnmation <firstFrame> <numFrames> <loopFrames> <fps>|sync` - animation parameters to use when model particles are employed.
- `displacement <x> <y> <z> <variance>` - a static displacement about the attachment point. The variance parameter specifies a random displacement in all axes.
- `normalDisplacement <displacement>` - for particle systems that have their normal set (impact particle systems for example) this specifies the magnitude of a displacement along the normal.
- `velocityType static|static_transform|tag|cent|normal` - this specifies how the particle will compute its initial velocity. `static` means it is specified statically in the `.particle` file, `static_transform` means the same, except that it is transformed by the orientation matrix of what it is attached to, `tag` means the velocity is in the direction of the tag it is attached to, `cent` means the velocity is in the direction of the cent it is attached to and `normal` means the velocity is in the direction of the particle system normal.
- `velocityDir linear|point` - this specifies whether the initial velocity is computed as a simple direction or as the direction towards a secondary point (defined by `velocityPoint` or dynamically through `velocityType cent`).
- `velocity <x> <y> <z> <variance>` - for when `velocityType static` is present this specifies the direction. The variance here is specified in degrees e.g. `~5` - up to 5 degrees deviation.
- `velocityMagnitude <magnitude>` - the magnitude of the velocity.
- `velocityPoint <x> <y> <z> <variance>` - for when `velocityType static` and `velocityDir point` are present this specifies the point to move towards.
- `parentVelocityFraction <fraction>` - for when the particle system is attached to a cent this specifies the fraction of the cent’s velocity that is added to the particle’s velocity.
- `accelerationType static|static_transform|tag|cent|normal` - this specifies how the particle will compute its acceleration. `static` means it is specified statically in the `.particle` file, `static_transform` means the same, except that it is transformed by the orientation matrix of what it is attached to, `tag` means the acceleration is in the direction of the tag it is attached to, `cent` means the acceleration is in the direction of the cent it is attached to and `normal` means the acceleration is in the direction of the particle system normal.
- `accelerationDir linear|point` - this specifies whether the acceleration is computed as a simple direction or as the direction towards a secondary point (defined by `accelerationPoint` or dynamically through `accelerationType cent`).
- `acceleration <x> <y> <z> <variance>` - for when accelerationType static is present this specifies the direction. The variance here is specified in degrees e.g. `~5` - up to 5 degrees deviation.
- `accelerationMagnitude <magnitude>` - the magnitude of the acceleration.
- `accelerationPoint <x> <y> <z> <variance>` - for when accelerationType static and accelerationDir point are present this specifies the point to move towards.
- `bounce <fraction>|cull` - the fraction of velocity that is refiected when a particle collides. If this is set to `0.0` the particle won't collide. When cull is used particles are culled as soon as they collide with objects.
- `bounceMark <count> <radius> <shader>` - make a mark at each bounce point for up to `<count>` bounces.
- `bounceSound <count> <sound>` - make a sound at each bounce point for up to `<count>` bounces.
- `dynamicLight <delayRadius> <initialRadius> <finalRadius> { <r> <g> <b> }` - attach a dynamic light to this particle.
- `color <delay> { <ir> <ig> <ib> } { <fr> <fg> <fb> }` - color the particle where `<i.>` refers to the initial color component and `<f.>` refers to the final color component.
- `overdrawProtection` - cull particles that occupy a large amount of screen space.
- `realLight` - light particles using the lightgrid instead of fullbright.
- `cullOnStartSolid` - cull particles that are spawned inside brushes.
- `radius <delay> <initial> <final>` - the radius of the particle throughout its lifetime. The delay parameter specifies the time in msec before radius scaling begins. The initial and final parameters specify the radii of the particle in quake units.
- `alpha <delay> <initial> <final>` - the alpha of the particle throughout its lifetime. The delay parameter specifies the time in msec before alpha scaling begins. The initial and final parameters specify the alpha of the particle where `1.0` is totally opaque and `0.0` is totally transparent.
- `rotation <delay> <initial> <final>` - the rotation of the particle throughout its lifetime. The delay parameter specifies the time in msec before the rotation begins. The initial and final parameters specify the rotation of the particle in degrees.
- `lifeTime <time>` - the lifetime of the particle.
- `childSystem <particle system>` - specifies a particle system to attach to this particle.
- `childTrailSystem <trail system>` - specifies a trail system to attach to this particle.
- `onDeathSystem <particle system>` - specifies a particle system to spawn at the point where this particle died.
- `physicsRadius` - ???
- `scaleWithCharge` - ???
Except for vector components, shader fps ... and `period <initial><final> <variance>`, every value can be specified with a random variance.
The syntax for this is as follows:
```
[value][variance[%]]
```
So the following forms are possible, where random is a random number between `0.0` and `1.0` inclusive:
```
5.0 // 5.0
5.0~8.0 // 5.0 + ( random * 8.0 )
5.0~200% // 5.0 + ( random * 5.0 * 200% )
~7.0 // random * 7.0
```
This allows for relatively fiexible randomisation of most of the particle’s parameters. For parameters taking an initial and final value, specifying the final value as '`-`' will result in a final value the same as the initial value.
For the purposes of map based particle systems using `misc_particle_system` it is safe to ignore `velocityType` and `accelerationType tag|cent|normal`, `normalDisplacement` and `parentVelocityFraction` altogether.
Of course, it is not necessary to specify every parameter documented here for every particle system.
If a parameter is not included it will usually default to zero.
C/C++ style comments can be used throughout.
There are an enormous number of possible combinations of particle systems parameters and as such it is impractical to test them all.
For this reason it is possible that certain permutations do not behave as expected or wrongly.
In this case you may have discovered a bug - let us know.
Having said this when you’re having problems with a particle system make sure you scroll up the console and check that it compiled OK, I’ve written the parser to be very intolerant of error.
Here is an example particle system:
```
aShinyNewParticleSystem
{
ejector
{
particle
{
shader sync shader1 shader2
velocityType static
velocityDir linear
velocityMagnitude 200
velocity 0 0 1 ~30
accelerationType static
accelerationDir linear
accelerationMagnitude 50
acceleration 0 0 1 ~0
radius 0 10.0 50.0
alpha 0 1.0 1.0
rotation 0 ~360 -
bounce 0.4
lifeTime 1500
}
count 50
delay 0
period 0 - 0
}
}
```
|