The xpDynamics Tag
This tag adds object dynamics capabilities to X-Particles. Note that this is not a polygon-based system such as Bullet (which is used in the Cinema 4D dynamics engine) but a particle-based system. This means you can use other X-Particles objects such as particle modifiers and collision tag to move an object and implement collisions.
Please see 'How to use the xpDynamics Tag' before using the tag for the first time.
Interface
The interface contains the following sections:
Tag tab
For the buttons at the bottom of the interface, please see the 'Common interface elements' page.
Parameters
Parameter maps
Several of the parameters have a little arrow next to them. Clicking this arrow will reveal a link field labelled 'Map', like so:
You can drag a selection tag or a vertex map into this field. This will then be used to alter the corresponding setting for particles on vertices depending on whether the vertex is included in the selection (or on the vertex weight, if a vertex map is used).
Distribution
This menu controls how the particles are distributed on the object. The options are:
Vertices
A particle is added to each object vertex.
Vert - Mid
A particle is added to each object vertex plus one in the centre of each polygon.
Surface
Particles are distributed over the object surface.
Volume
Particles fill the object's volume.
Include Children
If this switch is checked, child objects of the object with the xpDynamics tag are also included.
Trigger
This menu determines when the dynamics become active - that is, when the particles required for the dynamics system are generated. The options are:
Immediately
The particles are generated as soon as the animation plays.
At Time
The particles are generated at the time specified in the 'Time' setting.
Time
Only available if 'Trigger' is set to 'At Time', It is the scene time when the particles required for the animation will be generated.
Group
If you drag a particle Group object into this field, the generated particles will belong to this group.
Note that the particles will NOT take on the parameters in the group (editor display type, radius, speed, etc.) other than the colour. The particles will always be drawn in the 'Squares' display type but will use the group's colour.
The purpose of this parameter is again to give more control from modifiers, actions and other objects over the particles used in the dynamics simulation.
Spacing
Only available if 'Distribution' is set to 'Surface' or 'Volume'. It controls the spacing between particles covering or filling the object. Changing it will affect the rigidity of the object. This value will affect the number of particles which are generated.
The value in the 'Radius' setting is multiplied by this value to determine the spacing. If 'Radius' is 5 scene units, and 'Spacing' is 100%, the space between particles is 5 units. If 'Spacing' is 200%, the space will be 10 units, and so on. This setting enables you to maintain the radius at the required value while independently altering the space between particles.
Offset
This parameter moves the particle along the surface normal, either away from the object (positive values) or into the object (negative values).
The value in the 'Radius' setting is multiplied by this value to determine the actual offset. If 'Radius' is 5 scene units, and 'Spacing' is 100%, the offset will be 5 units. If 'Spacing' is 200%, the offset will be 10 units, and so on.
Damping
This is normally set at a very low level. Increasing it will reduce the strength of the dynamic constraints, including rigidity strength. Sometimes a constraint can oscillate, so increasing this setting will reduce the constraint strength and help to reduce oscillation.
Update PSR
If this switch is checked, the position, scale and rotation (PSR) of the object will be altered as the particles are updated. If it is unchecked the object will move with the particles but its PSR values will not change from their initial state.
Update Points
If this switch is checked, the vertices of the object are updated as the particles are updated. If you uncheck it, the particles and the object move but the object does not deform, giving a more rigid look.
Radius
This is the radius of the generated particles. It overrides the radius value in any emitter you may supply in the 'Emitter' field.
Rigidity
A value of 100% means that the particles are forced to retain the shape of the object. If the value is less than 100%, they are freer to move from their position and the result appears softer.
Note that rigidity is based upon constraints between the particles and object. The more constraints you have (i.e. the more particles you have) the more iterations are required. You can alter the number of iterations in the X-Particles project settings.
Pressure
This is the pressure applied to the vertices of an object in the direction of the surface of the object, so it can be used to inflate or deflate an object (if it has a volume).
Volume Pressure
Increasing this value applies pressure to try to maintain the volume of the object. For example, if an object is squashed between two other objects it will inflate vertically to maintain the volume.
Push
If checked, additional constraints are added to push the particles apart. This can impart a jelly-like movement to the object on collision, for example.
Strength
Only available if 'Push' is checked, this is the strength of the effect.
Emitter
You can drag an emitter into this link field. This is optional, since the tag will create the required particles if an emitter is not given. Adding an emitter to this field gives you greater control over the particles (for example, it would allow you to specify which modifiers in the scene work with this emitter, which you cannot do with the emitter built in to the tag).
Add Emitter
Click this button to create a new emitter and add it to the 'Emitter' field.
Mass, Density, Friction, Bounce
These are the corresponding particle properties found in the emitter. They are set by the values in these settings instead of by the emitter itself.
Adaptive Radius
If checked, the particle radius is adjusted according to the size of surrounding polygons, so small polygons give small particle size.
Weighted Mass
If checked, the particle mass is adjusted according to the size of surrounding polygons, so small polygons give small particle mass.
Linear Velocity
You can use this parameter to give some initial velocity to the object along any of the desired axes. This doesn't require a particle modifier. The particles are given the required speed and direction; the speed is given in terms of scene units per second. For example, if the X component had a value of 100 scene units and Y and Z were both zero, the particle speed would be 100 units per second with a direction vector of (1, 0, 0) - that is, along the positive X axis.
Angular Velocity
As with 'Linear Velocity' you can use this parameter to give some initial spin to the object around any of the desired axes. This doesn't require a particle modifier. The values are shown as degrees of rotation per second.
Set Initial
Click this button to set the initial state of the object. To move the object either do so on the starting frame of the scene (before the tag has generated any particles) or disable the tag first, then move the object.
Reset to Initial
Resets the object to its initial state.
Constraints tab
This tab enables you to apply certain constraints to the particles which affect the object's rigidity. In each case the 'Strength' parameter is only available if the corresponding switch is checked to enable the constraint, and the 'Strength' value controls the strength of the corresponding constraints.
These constraints can be applied to create a range of softbody and rubber effects and will do very little if 'Rigidity' is set to a high value.
Structure Constraints, Strength
These are constraints between polygon edges or spline vertices.
Shape Constraints, Strength
These constraints are set across polygons or across every other spline point.
Vertex-Volume Constraints, Strength
Only available when 'Distribution' is set to 'Volume'. Constraints are then added between each vertex and the closest particles in the object volume.
Volume Constraints, Strength
Only available when 'Distribution' is set to 'Volume'. These constraints link the entire object together, giving a more rigid volume..
Modifiers tab
This tab contains a list of particle modifiers acting on the emitter used by the xpDynamics tag. You can use it to prevent certain modifiers from acting on the emitter or specifying that only certain modifiers do so.
Drag any modifiers you want to affect into this list. If the modifier has a yellow tick icon, it will act on the emitter; if it has a blue dash icon, it will not do so.
Same System
If this switch is checked, only modifiers which are child objects of the same System object as the emitter used by the tag will be excluded or included.
Modifiers
The list of modifiers to be excluded or included.
Display tab
This tab enables you to alter the visibility and colour of the particles and/or constraints.
Show Particles
If checked, the dynamics particles are shown in the viewport.
Show Constraints
If checked, any constraints are shown in the viewport.
Set Particle Color
Checking this switch will allow you to change the colours used for the particles.
Vertices/Surface/Volume
These are three colour settings which control the colours used for particles located at the object's vertices, on the surface, and inside the object volume.
How to use the xpDynamics Tag
Unlike a polygon-based dynamics engine, X-Particles uses a particle-based system. The xpDynamics tag will generate particles - we can call them 'dynamic' particles - which are created on the vertices of an object, on a polygon surface, or in an object's volume. These different modes have different uses, depending on the nature of the simulation.
The particles are just ordinary particles except that they remain stuck to the object they are controlling. Once they are generated they can be affected by modifiers in the usual way. For example, they will fall if a gravity modifier is added to the scene.
Important: if you supply an emitter, note that the dynamic particles will all start with a speed of zero, not the speed apparently given to them in the emitter interface.
This is important if you subsequently test the speed of these particles in some way; you might assume their speed is that shown in the emitter, but that is not the case. Their speed depends on whatever is done to start them moving, such as a gravity or turbulence modifier.
Using the tag
Using the tag is very simple.
1. Add the tag to the object to be moved by the dynamics system. When you play the animation, particles are emitted and attached to the object but nothing else will happen, because there is nothing to move the particles, and you need to move the particles to move the object.
2. Now add a Gravity modifier. When you play the animation, the particles fall downwards, taking the object with it.
3. Optionally, add a collider object to act as a floor and attach a Collider tag. Now when the particles attached to the falling object hit the floor object, they will bounce, and so will the object.
That's all there is to it. There is a lot more you can do with the xpDynamics tag, and tutorials on our website will cover some of these actions.
Note that it is not required that you add an emitter to the scene. The tag will create the required particles if an emitter is not provided. But if you want more control over the particles, you can create an emitter and add it to the 'Emitter' link field.
xpDynamics vs. Keyframes
You should note that you cannot move an object using keyframes and X-Particles dynamics at the same time. Results are unpredictable if you try. You can use keyframes up until the point that the xpDynamics becomes active, but while the dynamics are active.