Package com.jme3.bullet.control
Class AbstractPhysicsControl
java.lang.Object
com.jme3.bullet.control.AbstractPhysicsControl
- All Implemented Interfaces:
- PhysicsControl,- Savable,- Control,- JmeCloneable,- Cloneable
- Direct Known Subclasses:
- BetterCharacterControl,- DacConfiguration,- KinematicRagdollControl
Manage the life cycle of a physics object linked to a spatial in a scene
 graph.
 
This class is shared between JBullet and Native Bullet.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected booleantrue→body is added to the physics space, false→not addedprotected booleantrue → physics coordinates match local transform, false → physics coordinates match world transformprotected booleantrue→control is enabled, false→control is disabledprotected PhysicsSpacespace to which the physics object is (or would be) addedprotected Spatialspatial to which this control is added, or null if none
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected abstract voidaddPhysics(PhysicsSpace space) Add all managed physics objects to the specified space.protected voidapplyPhysicsTransform(Vector3f worldLocation, Quaternion worldRotation) Apply a physics transform to the spatial.voidcloneFields(Cloner cloner, Object original) Callback fromClonerto convert this shallow-cloned control into a deep-cloned one, using the specified cloner and original to resolve copied fields.cloneForSpatial(Spatial spatial) Deprecated.protected abstract voidcreateSpatialData(Spatial spat) Create spatial-dependent data.Access the physics space to which the object is (or would be) added.protected QuaternionAccess whichever spatial rotation corresponds to the physics rotation.protected Vector3fAccess whichever spatial translation corresponds to the physics location.booleanTest whether physics-space coordinates should match the spatial's local coordinates.booleanTest whether this control is enabled.voidread(JmeImporter im) De-serialize this control from the specified importer, for example when loading from a J3O file.protected abstract voidremovePhysics(PhysicsSpace space) Remove all managed physics objects from the specified space.protected abstract voidremoveSpatialData(Spatial spat) Destroy spatial-dependent data.voidrender(RenderManager rm, ViewPort vp) Should be called prior to queuing the spatial by the RenderManager.voidsetApplyPhysicsLocal(boolean applyPhysicsLocal) Alter whether physics-space coordinates should match the spatial's local coordinates.voidsetEnabled(boolean enabled) Enable or disable this control.protected abstract voidTranslate the physics object to the specified location.protected abstract voidsetPhysicsRotation(Quaternion quat) Rotate the physics object to the specified orientation.voidsetPhysicsSpace(PhysicsSpace newSpace) If enabled, add this control's physics object to the specified physics space.voidsetSpatial(Spatial spatial) Alter which spatial is controlled.voidupdate(float tpf) Updates the control.voidwrite(JmeExporter ex) Serialize this object, for example when saving to a J3O file.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.jme3.util.clone.JmeCloneablejmeClone
- 
Field Details- 
spatialspatial to which this control is added, or null if none
- 
enabledprotected boolean enabledtrue→control is enabled, false→control is disabled
- 
addedprotected boolean addedtrue→body is added to the physics space, false→not added
- 
spacespace to which the physics object is (or would be) added
- 
applyLocalprotected boolean applyLocaltrue → physics coordinates match local transform, false → physics coordinates match world transform
 
- 
- 
Constructor Details- 
AbstractPhysicsControlpublic AbstractPhysicsControl()
 
- 
- 
Method Details- 
createSpatialDataCreate spatial-dependent data. Invoked when this control is added to a spatial.- Parameters:
- spat- the controlled spatial (not null)
 
- 
removeSpatialDataDestroy spatial-dependent data. Invoked when this control is removed from a spatial.- Parameters:
- spat- the previously controlled spatial (not null)
 
- 
setPhysicsLocationTranslate the physics object to the specified location.- Parameters:
- vec- desired location (not null, unaffected)
 
- 
setPhysicsRotationRotate the physics object to the specified orientation.- Parameters:
- quat- desired orientation (not null, unaffected)
 
- 
addPhysicsAdd all managed physics objects to the specified space.- Parameters:
- space- which physics space to add to (not null)
 
- 
removePhysicsRemove all managed physics objects from the specified space.- Parameters:
- space- which physics space to remove from (not null)
 
- 
isApplyPhysicsLocalpublic boolean isApplyPhysicsLocal()Test whether physics-space coordinates should match the spatial's local coordinates.- Returns:
- true if matching local coordinates, false if matching world coordinates
 
- 
setApplyPhysicsLocalpublic void setApplyPhysicsLocal(boolean applyPhysicsLocal) Alter whether physics-space coordinates should match the spatial's local coordinates.- Parameters:
- applyPhysicsLocal- true→match local coordinates, false→match world coordinates (default=false)
 
- 
getSpatialTranslationAccess whichever spatial translation corresponds to the physics location.- Returns:
- the pre-existing location vector (in physics-space coordinates, not null)
 
- 
getSpatialRotationAccess whichever spatial rotation corresponds to the physics rotation.- Returns:
- the pre-existing quaternion (in physics-space coordinates, not null)
 
- 
applyPhysicsTransformApply a physics transform to the spatial.- Parameters:
- worldLocation- location vector (in physics-space coordinates, not null, unaffected)
- worldRotation- orientation (in physics-space coordinates, not null, unaffected)
 
- 
cloneForSpatialDeprecated.Description copied from interface:ControlCreates a clone of the Control, the given Spatial is the cloned version of the spatial to which this control is attached to.- Specified by:
- cloneForSpatialin interface- Control
- Parameters:
- spatial- the Spatial to be controlled by the clone
- Returns:
- A clone of this control for the spatial
 
- 
cloneFieldsCallback fromClonerto convert this shallow-cloned control into a deep-cloned one, using the specified cloner and original to resolve copied fields.- Specified by:
- cloneFieldsin interface- JmeCloneable
- Parameters:
- cloner- the cloner that's cloning this control (not null)
- original- the control from which this control was shallow-cloned (unused)
 
- 
setSpatialAlter which spatial is controlled. Invoked when the control is added to or removed from a spatial. Should be invoked only by a subclass or from Spatial. Do not invoke directly from user code.- Specified by:
- setSpatialin interface- Control
- Parameters:
- spatial- the spatial to control (or null)
 
- 
getSpatial- Returns:
- returns the spatial the control is added to, or null if the control is not attached to a spatial yet.
 
- 
setEnabledpublic void setEnabled(boolean enabled) Enable or disable this control.When the control is disabled, the physics object is removed from physics space. When the control is enabled again, the physics object is moved to the spatial's location and then added to the physics space. - Specified by:
- setEnabledin interface- PhysicsControl
- Parameters:
- enabled- true→enable the control, false→disable it
 
- 
isEnabledpublic boolean isEnabled()Test whether this control is enabled.- Specified by:
- isEnabledin interface- PhysicsControl
- Returns:
- true if enabled, otherwise false
 
- 
updatepublic void update(float tpf) Description copied from interface:ControlUpdates the control. This should not be called from user code.
- 
renderDescription copied from interface:ControlShould be called prior to queuing the spatial by the RenderManager. This should not be called from user code.
- 
setPhysicsSpaceIf enabled, add this control's physics object to the specified physics space. If not enabled, alter where the object would be added. The object is removed from any other space it's in.- Specified by:
- setPhysicsSpacein interface- PhysicsControl
- Parameters:
- newSpace- where to add, or null to simply remove
 
- 
getPhysicsSpaceAccess the physics space to which the object is (or would be) added.- Specified by:
- getPhysicsSpacein interface- PhysicsControl
- Returns:
- the pre-existing space, or null for none
 
- 
writeSerialize this object, for example when saving to a J3O file.- Specified by:
- writein interface- Savable
- Parameters:
- ex- exporter (not null)
- Throws:
- IOException- from exporter
 
- 
readDe-serialize this control from the specified importer, for example when loading from a J3O file.- Specified by:
- readin interface- Savable
- Parameters:
- im- importer (not null)
- Throws:
- IOException- from importer
 
 
-