Particle System Constraints: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
		
	
| SirYodaJedi (talk | contribs)  | |||
| (8 intermediate revisions by 7 users not shown) | |||
| Line 1: | Line 1: | ||
| {{LanguageBar}} | |||
| {{confirm-box}} | {{confirm-box}} | ||
| {{back|Category:Particle System}} | |||
| {{toc-right}} | |||
| '''Particle Constraints''' prevent particles from passing through certain areas, such as brushes. The can also be user-defined, such as a 2-Dimensional plane. | '''Particle Constraints''' prevent particles from passing through certain areas, such as brushes. The can also be user-defined, such as a 2-Dimensional plane. | ||
| Line 8: | Line 11: | ||
| ; collision mode | ; collision mode | ||
| :  | : 0 to 3 range. Defines how exactly traces will be used for particle collision. | ||
| : ' | :; '0' (Default) | ||
| : ' | :: Titled <code>COLLISION_MODE_PER_PARTICLE_TRACE</code> in the source code. Does a trace per frame, for each particle. This is the most accurate, but also the expensive mode, and it gets worse the more particles there are. | ||
| :; '1' | |||
| :: Titled <code>COLLISION_MODE_PER_FRAME_PLANESET</code> in the source code. Performs several traces when this particle system first starts, from the origin of Control Point #0. The information gained from this is then used to approximately test particle collision. This is one of the cheapest collision modes, but also very inaccurate. | |||
| :; '2' | |||
| :: Titled <code>COLLISION_MODE_INITIAL_TRACE_DOWN</code> in the source code. Similar in function to mode 1. However, it performs a single trace going in the -X direction in world-space. The plane derived from this trace is then used for particle collision, and only that plane. This doesn't seem to have any use at all. | |||
| :: {{note|Judging by its name in the code, mode 2 is probably ''intended'' to trace in the world's -Z direction (down) instead of the world's -X direction (West). If it worked properly, it would theoretically be useful for cheap, imprecise ground collisions.}} | |||
| :; '3' | |||
| :: Titled <code>COLLISION_MODE_USE_NEAREST_TRACE</code> in the source code. Similar in function to mode 0. However, it performs traces far more sparingly, and the traces extend further ahead of the particles. This mode is the best compromise between accuracy, and performance. Particles using this collision mode may sometimes clip and go through objects. | |||
| ; collision group | ; collision group | ||
| : Known arguments are: | : Known arguments are: | ||
| Line 25: | Line 36: | ||
| :; <code>PASSABLE</code> | :; <code>PASSABLE</code> | ||
| :: Doors that the player shouldn't collide with. | :: Doors that the player shouldn't collide with. | ||
| :; <code>ROCKETS</code> {{tf2|only}} | |||
| :: Weapon projectiles | |||
| ; amount of bounce | ; amount of bounce | ||
Latest revision as of 11:24, 24 October 2025
Particle Constraints prevent particles from passing through certain areas, such as brushes. The can also be user-defined, such as a 2-Dimensional plane.
Collision via traces
Uses traces for checking collisions.
- collision mode
- 0 to 3 range. Defines how exactly traces will be used for particle collision.
- '0' (Default)
- Titled COLLISION_MODE_PER_PARTICLE_TRACEin the source code. Does a trace per frame, for each particle. This is the most accurate, but also the expensive mode, and it gets worse the more particles there are.
- '1'
- Titled COLLISION_MODE_PER_FRAME_PLANESETin the source code. Performs several traces when this particle system first starts, from the origin of Control Point #0. The information gained from this is then used to approximately test particle collision. This is one of the cheapest collision modes, but also very inaccurate.
- '2'
- Titled COLLISION_MODE_INITIAL_TRACE_DOWNin the source code. Similar in function to mode 1. However, it performs a single trace going in the -X direction in world-space. The plane derived from this trace is then used for particle collision, and only that plane. This doesn't seem to have any use at all.
 Note:Judging by its name in the code, mode 2 is probably intended to trace in the world's -Z direction (down) instead of the world's -X direction (West). If it worked properly, it would theoretically be useful for cheap, imprecise ground collisions. Note:Judging by its name in the code, mode 2 is probably intended to trace in the world's -Z direction (down) instead of the world's -X direction (West). If it worked properly, it would theoretically be useful for cheap, imprecise ground collisions.
- '3'
- Titled COLLISION_MODE_USE_NEAREST_TRACEin the source code. Similar in function to mode 0. However, it performs traces far more sparingly, and the traces extend further ahead of the particles. This mode is the best compromise between accuracy, and performance. Particles using this collision mode may sometimes clip and go through objects.
 
- collision group
- Known arguments are:
- NONE
- Does not collide with anything.
- DEBRIS
- Collides with nothing but world and static stuff.
- INTERACTIVE
- Collides with everything except interactive debris or debris.
- NPC
- Generic NPC group.
- ACTOR
- Used so NPCs in scripts ignore the player.
- PASSABLE
- Doors that the player shouldn't collide with.
- ROCKETS(only in ) )
- Weapon projectiles
 
- amount of bounce
- Amount of bounce force to apply when a collision occurs.
- amount of slide
- Amount of sliding force applied to particles currently on a surface.
- kill particle on collision
- Destroys the particle when it collides with an object
- brush only
- If 1, the particle will collide only with brushes
- trace accuracy tolerance
- Amount of tolerance to use when calculating collisions. Higher values mean more tolerance, but less realistic collisions. Lower values mean more accurate collisions, most likely at the cost of additional calculations.
Constrain distance to path between two control points
Keeps particles on a path between two control points. Internally determined control point only?
- minimum distance
- Minimum distance between the two control points. It's recommended to keep this at zero.
- maximum distance
- Maximum distance between the two control points. It needs to be equal or greater than the distance between the two control points, in order to work.
- maximum distance middle
- Maximum distance between start and the middle, Controlled via a circular radius.
- maximum distance end
- Maximum distance between middle and end point. Default value is -1 which means off.
- travel time
- Maximum time a particle can spend traveling between the two points.
- random bulge
- Random clumping of particles. Works much like emitting a group of particles.
- start control point number
- The starting control point number. 0 is recommended since it is the particle system's origin.
- end control point number
- The end control point number. Using the start control point number is NOT recommended, as the particles will just around. See this in order to make a control point.
- bulge control 0=random 1=orientation of start pnt 2=orientation of end point
- Pretty self explanatory, determines where to place the bulge
- mid point position
- Determines the middle of the path, in a decimal percentage. 0.5 is the middle, 1 is the end, 0 is the beginning?
Prevent passing through a plane
Blocks particles from passing through an imaginary two-dimensional plane. Default settings make it at the bottom of the particle's origin.
- global origin
- Use global origin instead of particle origin? (Not recommended)
- plane point
- The 2nd Point to use to define a more complex plane, based on its coordinates.
- plane normal
- 3D vector that determines the angle of the plane (same concept as VPlane)
Prevent passing through static part of world
Prevents passing through any static part of the world. I.e. prop_statics, brushes, etc


























