A particle system is a rendering technique used to display complex and often fluid effects. Many games use particle systems for effects such as fire, water, spells, etc. There are several Roblox instances that use particles to create their effects, such as
Sparkles. While the default particle systems that Roblox provides can be used in a variety of games and settings, there is a limit to how much they can be customized. More customizable systems can be created with the
Particle systems are made up of sprite textures, often overlaid and blended. In Roblox, a particle is always billboarded so it will always face the screen. A ParticleEmitter can use any custom texture you like by changing the
Texture field, just as you would for a
The Part a ParticleEmitter is parented to determines the direction and origin of the particles created in the system. For a ParticleEmitter system to work, its parent must be either a subtype of a
BasePart, or an
Attachment. The starting position of each particle created by the emitter is a randomly chosen point from within the volume of the ParticleEmitter’s Parent.
If the ParticleEmitter has a non-zero
ParticleEmitter/Speed property then the created particles will travel along the part’s local Y axis. Rotating the Parent will change the direction new particles travel.
Particles exist for a limited time which is determined by the ParticleEmitter’s
ParticleEmitter/Lifetime property. Lifetime defines a minimum and maximium amount of time in seconds a particle will last. When a new particle is created it’s lifetime will be randomly chosen between the Lifetime minimum and maximum values. Setting minimum and maximum to the same value will ensure the particles will last for an exact amount of time. The maximum value of Lifetime is capped at 20 seconds.
ParticleEmitter/Rate determines how many particles per second a ParticleEmitter will create. An individual emitter can emit up to 500 particles per second.
ParticleEmitter/Rotation property determines how much each particle is rotated when it is created. Rotation defines a minimum and maximum rotation value in degrees. When a new particle is created a value is picked at random between the minimum and maximum. The particle is then rotated by this value. Note that minimum can be negative (for counter-clockwise rotation).
ParticleEmitter/RotSpeed determines how fast particles rotate while they are active. This property defines a minimum and maximum value in degrees per second. When a new particle is created a value is picked at random between the minimum and maximum. The particle will then constantly rotate at this value. Note that minimum can be negative (for counter-clockwise rotation).
By default particles will travel along the local Y axis of its Parent.
ParticleEmitter/VelocitySpread defines an offset range that particles can travel in. This offset is measured in degrees from the Y axis. This can be effectively set between 0 and 180 degrees.
Particles are not affected by regular gravity or Roblox forces.
ParticleEmitter/Acceleration defines an acceleration in studs per second (per second). This acceleration affects all particles created by the ParticleEmitter. Changing this value will instantly apply the acceleration to all particles made by the emitter (both existing and new particles).
Particles can have color through the
ParticleEmitter/Texture, but a tint can also be applied with the
ParticleEmitter/Color property. The color of each particle will be linearly interpolated between the colors over its lifetime, based on the colors assigned with the Color property. If you don’t need the colors to transition you can set the Start and End colors to the same value and remove any key-points inbetween them.
Particles can be blended together using additive blending. In additive blending, when two colors overlap their color values are added together to determine the displayed color. This often brings the color closer to white, which creates a glowing type effect. The value of
ParticleEmitter/LightEmission determines how much the particles in the emitter’s system will additively blend (0 means no blending, 1 meaning fully additive).
Particles can vary in size even throughout their lifetime. The simplest way to do this is to set the
ParticleEmitter/Size property to a number between 0 and 10. This will force all particles created by the ParticleEmitter to be that size. Size is measured in studs.
Alternatively this value can be set via a
DataType/NumberSequence. The easiest way to do this is through the Studio spline editor. Next to the
ParticleEmitter/Size field in the emitter’s properties is a button to open the editor. This editor represents a particle’s size over it’s lifetime (the x axis is time, the y axis is size). Clicking anywhere on the line will create a new node. Each node, including the starting and ending nodes can be dragged. In addition, the handles above and below each node can be dragged. This creates a red envelope on the graph. This envelope represents a random range of sizes a particle can be at that point.
Particles can be up to 10 studs large in the editor, but can reach up to 200 studs in size.
Particles can vary in transparency throughout their lifetime. The
ParticleEmitter/Transparency property is set in the same way as
ParticleEmitter/Size, with the only exception being that Transparency values can only be between 0 and 1.
A part can contain multiple particle emitters. When this happens, particles will sometimes fight to determine which is drawn on top. In cases where you want to ensure some particles draw on top of others use the
ParticleEmitter/ZOffset property. This shifts the particles in the Z axis of the camera (either closer or further). This value is measured in studs. This is useful when you need certain particles to always draw on top, no matter which orientation you view them from.