CPUParticles

    CPU-based 3D particle emitter.

    CPU-based 3D particle node used to create a variety of particle systems and effects.

    See also , which provides the same functionality with hardware acceleration, but may not run on older devices.

    Note: Unlike Particles, the visibility rect is generated on-the-fly and doesn’t need to be configured by the user.

    Properties

    void ( Node particles )
    get_param ( param ) const
    Curve ( Parameter param ) const
    get_param_randomness ( param ) const
    bool ( Flags flag ) const
    void ( )
    voidset_param ( param, float value )
    void ( Parameter param, curve )
    voidset_param_randomness ( param, float randomness )
    void ( Flags flag, enable )

    Enumerations

    enum DrawOrder:

    • DRAW_ORDER_INDEX = 0 —- Particles are drawn in the order emitted.
    • DRAW_ORDER_LIFETIME = 1 —- Particles are drawn in order of remaining lifetime.
    • DRAW_ORDER_VIEW_DEPTH = 2 —- Particles are drawn in order of depth.

    enum Parameter:


    enum Flags:

    • FLAG_ALIGN_Y_TO_VELOCITY = 0 —- Use with to set flag_align_y.
    • FLAG_ROTATE_Y = 1 —- Use with to set flag_rotate_y.
    • FLAG_DISABLE_Z = 2 —- Use with to set flag_disable_z.
    • FLAG_MAX = 3 —- Represents the size of the enum.

    enum EmissionShape:

    • EMISSION_SHAPE_POINT = 0 —- All particles will be emitted from a single point.
    • EMISSION_SHAPE_SPHERE = 1 —- Particles will be emitted in the volume of a sphere.
    • EMISSION_SHAPE_BOX = 2 —- Particles will be emitted in the volume of a box.
    • EMISSION_SHAPE_POINTS = 3 —- Particles will be emitted at a position chosen randomly among emission_points. Particle color will be modulated by .
    • EMISSION_SHAPE_DIRECTED_POINTS = 4 —- Particles will be emitted at a position chosen randomly among emission_points. Particle velocity and rotation will be set based on . Particle color will be modulated by emission_colors.
    • EMISSION_SHAPE_MAX = 5 —- Represents the size of the enum.
    Default8
    Setterset_amount(value)
    Getterget_amount()

    The number of particles emitted in one emission cycle (corresponding to the ).

    Note: Changing amount will reset the particle emission, therefore removing all particles that were already emitted before changing .


    Default0.0
    Setterset_param(value)
    Getterget_param()

    Initial rotation applied to each particle, in degrees.


    Setterset_param_curve(value)
    Getterget_param_curve()

    Each particle’s rotation will be animated along this .


    Default0.0
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Rotation randomness ratio.


    • angular_velocity
    Default0.0
    Setterset_param(value)
    Getterget_param()

    Initial angular velocity applied to each particle. Sets the speed of rotation of the particle.


    • Curve angular_velocity_curve
    Setterset_param_curve(value)
    Getterget_param_curve()

    Each particle’s angular velocity will vary along this .


    • float angular_velocity_random
    Default0.0
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Angular velocity randomness ratio.


    • anim_offset
    Default0.0
    Setterset_param(value)
    Getterget_param()

    Particle animation offset.


    Setterset_param_curve(value)
    Getterget_param_curve()

    Each particle’s animation offset will vary along this .


    • float anim_offset_random
    Default0.0
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Animation offset randomness ratio.


    • anim_speed
    Default0.0
    Setterset_param(value)
    Getterget_param()

    Particle animation speed.


    Setterset_param_curve(value)
    Getterget_param_curve()

    Each particle’s animation speed will vary along this .


    Default0.0
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Animation speed randomness ratio.


    • color
    DefaultColor( 1, 1, 1, 1 )
    Setterset_color(value)
    Getterget_color()

    Unused for 3D particles.


    Setterset_color_ramp(value)
    Getterget_color_ramp()

    Unused for 3D particles.


    • damping
    Default0.0
    Setterset_param(value)
    Getterget_param()

    The rate at which particles lose velocity.


    Setterset_param_curve(value)
    Getterget_param_curve()

    Damping will vary along this .


    Default0.0
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Damping randomness ratio.


    • direction
    DefaultVector3( 1, 0, 0 )
    Setterset_direction(value)
    Getterget_direction()

    Default0
    Setterset_draw_order(value)
    Getterget_draw_order()

    Particle draw order. Uses values.


    The rectangle’s extents if is set to EMISSION_SHAPE_BOX.


    • emission_colors
    DefaultPoolColorArray(  )
    Setterset_emission_colors(value)
    Getterget_emission_colors()

    Sets the Colors to modulate particles by when using or EMISSION_SHAPE_DIRECTED_POINTS.


    • emission_normals
    Setterset_emission_normals(value)
    Getterget_emission_normals()

    Sets the direction the particles will be emitted in when using EMISSION_SHAPE_DIRECTED_POINTS.


    • emission_points
    DefaultPoolVector3Array(  )
    Setterset_emission_points(value)
    Getterget_emission_points()

    Sets the initial positions to spawn particles when using EMISSION_SHAPE_POINTS or .


    Default0
    Setterset_emission_shape(value)
    Getterget_emission_shape()

    Particles will be emitted inside this region. See for possible values.


    • float emission_sphere_radius
    Setterset_emission_sphere_radius(value)
    Getterget_emission_sphere_radius()

    The sphere’s radius if is set to EMISSION_SHAPE_SPHERE.


    • emitting
    Defaulttrue
    Setterset_emitting(value)
    Getteris_emitting()

    If true, particles are being emitted.


    Default0.0
    Setterset_explosiveness_ratio(value)
    Getterget_explosiveness_ratio()

    How rapidly particles in an emission cycle are emitted. If greater than 0, there will be a gap in emissions before the next cycle begins.


    • fixed_fps
    Default0
    Setterset_fixed_fps(value)
    Getterget_fixed_fps()

    The particle system’s frame rate is fixed to a value. For instance, changing the value to 2 will make the particles render at 2 frames per second. Note this does not slow down the particle system itself.


    Defaultfalse
    Setterset_particle_flag(value)
    Getterget_particle_flag()

    Align Y axis of particle with the direction of its velocity.


    • flag_disable_z
    Defaultfalse
    Setterset_particle_flag(value)
    Getterget_particle_flag()

    If , particles will not move on the z axis.


    Defaultfalse
    Setterset_particle_flag(value)
    Getterget_particle_flag()

    If true, particles rotate around Y axis by .


    Default0.0
    Setterset_flatness(value)
    Getterget_flatness()

    Amount of in Y/Z plane. A value of 1 restricts particles to X/Z plane.


    Defaulttrue
    Setterset_fractional_delta(value)
    Getterget_fractional_delta()

    If true, results in fractional delta calculation which has a smoother particles display effect.


    • gravity
    DefaultVector3( 0, -9.8, 0 )
    Setterset_gravity(value)
    Getterget_gravity()

    Gravity applied to every particle.


    Default0.0
    Setterset_param(value)
    Getterget_param()

    Initial hue variation applied to each particle.


    • hue_variation_curve
    Setterset_param_curve(value)
    Getterget_param_curve()

    Each particle’s hue will vary along this Curve.


    Default0.0
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Hue variation randomness ratio.


    • initial_velocity
    Default0.0
    Setterset_param(value)
    Getterget_param()

    Initial velocity magnitude for each particle. Direction comes from spread and the node’s orientation.


    • initial_velocity_random
    Default0.0
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Initial velocity randomness ratio.


    Default1.0
    Setterset_lifetime(value)
    Getterget_lifetime()

    The amount of time each particle will exist (in seconds).


    • lifetime_randomness
    Default0.0
    Setterset_lifetime_randomness(value)
    Getterget_lifetime_randomness()

    Particle lifetime randomness ratio.


    Linear acceleration applied to each particle in the direction of motion.


    • linear_accel_curve
    Setterset_param_curve(value)
    Getterget_param_curve()

    Each particle’s linear acceleration will vary along this Curve.


    • linear_accel_random
    Default0.0
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Linear acceleration randomness ratio.


    Defaulttrue
    Setterset_use_local_coordinates(value)
    Getterget_use_local_coordinates()

    If true, particles use the parent node’s coordinate space. If false, they use global coordinates.


    • mesh
    Setterset_mesh(value)
    Getterget_mesh()

    Defaultfalse
    Setterset_one_shot(value)
    Getterget_one_shot()

    If true, only one emission cycle occurs. If set true during a cycle, emission will stop at the cycle’s end.


    • orbit_velocity
    Setterset_param(value)
    Getterget_param()

    Orbital velocity applied to each particle. Makes the particles circle around origin in the local XY plane. Specified in number of full rotations around origin per second.

    This property is only available when flag_disable_z is true.


    • orbit_velocity_curve
    Setterset_param_curve(value)
    Getterget_param_curve()

    Each particle’s orbital velocity will vary along this Curve.


    • orbit_velocity_random
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Orbital velocity randomness ratio.


    Default0.0
    Setterset_pre_process_time(value)
    Getterget_pre_process_time()

    Particle system starts as if it had already run for this many seconds.


    • radial_accel
    Default0.0
    Setterset_param(value)
    Getterget_param()

    Radial acceleration applied to each particle. Makes particle accelerate away from origin.


    • Curve radial_accel_curve
    Setterset_param_curve(value)
    Getterget_param_curve()

    Each particle’s radial acceleration will vary along this .


    • float radial_accel_random
    Default0.0
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Radial acceleration randomness ratio.


    • randomness
    Default0.0
    Setterset_randomness_ratio(value)
    Getterget_randomness_ratio()

    Emission lifetime randomness ratio.


    Default1.0
    Setterset_param(value)
    Getterget_param()

    Initial scale applied to each particle.


    • scale_amount_curve
    Setterset_param_curve(value)
    Getterget_param_curve()

    Each particle’s scale will vary along this Curve.


    • scale_amount_random
    Default0.0
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Scale randomness ratio.


    Default1.0
    Setterset_speed_scale(value)
    Getterget_speed_scale()

    Particle system’s running speed scaling ratio. A value of 0 can be used to pause the particles.


    • spread
    Default45.0
    Setterset_spread(value)
    Getterget_spread()

    Each particle’s initial direction range from +spread to -spread degrees. Applied to X/Z plane and Y/Z planes.


    Default
    Setterset_param(value)
    Getterget_param()

    Tangential acceleration applied to each particle. Tangential acceleration is perpendicular to the particle’s velocity giving the particles a swirling motion.


    • tangential_accel_curve
    Setterset_param_curve(value)
    Getterget_param_curve()

    Each particle’s tangential acceleration will vary along this Curve.


    • tangential_accel_random
    Default0.0
    Setterset_param_randomness(value)
    Getterget_param_randomness()

    Tangential acceleration randomness ratio.

    Method Descriptions

    • void convert_from_particles ( Node particles )

    Sets this node’s properties to match a given node with an assigned ParticlesMaterial.


    Returns the base value of the parameter specified by .


    • Curve get_param_curve ( param ) const

    Returns the Curve of the parameter specified by .


    • float get_param_randomness ( param ) const

    Returns the randomness factor of the parameter specified by Parameter.


    • get_particle_flag ( Flags flag ) const

    Returns the enabled state of the given flag (see for options).


    • void restart ( )

    Restarts the particle emitter.


    Sets the base value of the parameter specified by Parameter.


    • void set_param_curve ( param, Curve curve )

    Sets the of the parameter specified by Parameter.


    Sets the randomness factor of the parameter specified by .


    • void set_particle_flag ( Flags flag, enable )