Package com.jme3.bullet.control
Class GhostControl
java.lang.Object
com.jme3.bullet.NativePhysicsObject
com.jme3.bullet.collision.PhysicsCollisionObject
com.jme3.bullet.objects.PhysicsGhostObject
com.jme3.bullet.control.GhostControl
- All Implemented Interfaces:
PhysicsControl
,com.jme3.export.Savable
,com.jme3.scene.control.Control
,com.jme3.util.clone.JmeCloneable
,Cloneable
,Comparable<NativePhysicsObject>
A PhysicsControl to link a PhysicsGhostObject to a Spatial.
The ghost object follows the Spatial it is attached to and can be used to detect overlaps with other physics objects (e.g. aggro radius).
-
Field Summary
Fields inherited from class com.jme3.bullet.objects.PhysicsGhostObject
logger2
Fields inherited from class com.jme3.bullet.collision.PhysicsCollisionObject
COLLISION_GROUP_01, COLLISION_GROUP_02, COLLISION_GROUP_03, COLLISION_GROUP_04, COLLISION_GROUP_05, COLLISION_GROUP_06, COLLISION_GROUP_07, COLLISION_GROUP_08, COLLISION_GROUP_09, COLLISION_GROUP_10, COLLISION_GROUP_11, COLLISION_GROUP_12, COLLISION_GROUP_13, COLLISION_GROUP_14, COLLISION_GROUP_15, COLLISION_GROUP_16, COLLISION_GROUP_NONE, logger
Fields inherited from class com.jme3.bullet.NativePhysicsObject
loggerN
-
Constructor Summary
ModifierConstructorDescriptionprotected
No-argument constructor needed by SavableClassUtil.GhostControl
(CollisionShape shape) Instantiate an enabled Control with the specified CollisionShape. -
Method Summary
Modifier and TypeMethodDescriptionvoid
cloneFields
(com.jme3.util.clone.Cloner cloner, Object original) Callback fromCloner
to convert this shallow-cloned Control into a deep-cloned one, using the specified Cloner and original to resolve copied fields.com.jme3.scene.control.Control
cloneForSpatial
(com.jme3.scene.Spatial spatial) Clone this Control for a different Spatial.Access the PhysicsSpace to which the ghost object is (or would be) added.com.jme3.scene.Spatial
Access the controlled Spatial.boolean
Test whether physics-space coordinates should match the spatial's local coordinates.boolean
Test whether the collision-shape scale should match the spatial's scale.boolean
Test whether this Control is enabled.void
read
(com.jme3.export.JmeImporter importer) De-serialize this Control from the specified importer, for example when loading from a J3O file.void
render
(com.jme3.renderer.RenderManager rm, com.jme3.renderer.ViewPort vp) Render this Control.void
setApplyPhysicsLocal
(boolean applyPhysicsLocal) Alter whether physics-space coordinates should match the spatial's local coordinates.void
setApplyScale
(boolean setting) Alter whether the collision-shape scale should match the spatial's scale.void
setEnabled
(boolean enabled) Enable or disable this Control.void
setPhysicsSpace
(PhysicsSpace newSpace) If enabled, add this control's physics object to the specified PhysicsSpace.void
setSpatial
(com.jme3.scene.Spatial controlledSpatial) Alter which Spatial is controlled.void
update
(float tpf) Update this Control.void
write
(com.jme3.export.JmeExporter exporter) Serialize this Control to the specified exporter, for example when saving to a J3O file.Methods inherited from class com.jme3.bullet.objects.PhysicsGhostObject
getOverlapping, getOverlappingCount, getOverlappingObjects, setCollisionShape, setPhysicsLocation, setPhysicsLocationDp, setPhysicsRotation, setPhysicsRotation, setPhysicsRotationDp, setPhysicsRotationDp
Methods inherited from class com.jme3.bullet.collision.PhysicsCollisionObject
activate, addCollideWithGroup, addToIgnoreList, attachCollisionShape, boundingBox, clearIgnoreList, cloneIgnoreList, collisionFlags, copyPcoProperties, countIgnored, debugMeshInitListener, debugMeshNormals, debugMeshResolution, debugNumSides, finalizeNative, findInstance, getActivationState, getAnisotropicFriction, getApplicationData, getCcdMotionThreshold, getCcdSquareMotionThreshold, getCcdSweptSphereRadius, getCollideWithGroups, getCollisionGroup, getCollisionShape, getCollisionSpace, getContactDamping, getContactProcessingThreshold, getContactStiffness, getDeactivationTime, getDebugMaterial, getFriction, getInternalType, getPhysicsLocation, getPhysicsLocation, getPhysicsLocationDp, getPhysicsRotation, getPhysicsRotationDp, getPhysicsRotationMatrix, getPhysicsRotationMatrixDp, getRestitution, getRollingFriction, getScale, getSpinningFriction, getTransform, getUserObject, hasAnisotropicFriction, ignores, initUserPointer, isActive, isContactResponse, isInWorld, isStatic, jmeClone, listIgnoredPcos, proxyGroup, proxyMask, readPcoProperties, removeCollideWithGroup, removeFromIgnoreList, setActivationState, setAnisotropicFriction, setApplicationData, setCcdMotionThreshold, setCcdSweptSphereRadius, setCollideWithGroups, setCollisionFlags, setCollisionGroup, setContactDamping, setContactProcessingThreshold, setContactStiffness, setDeactivationTime, setDebugMaterial, setDebugMeshInitListener, setDebugMeshNormals, setDebugMeshResolution, setDebugNumSides, setFriction, setIgnoreList, setLocationAndBasis, setRestitution, setRollingFriction, setSpinningFriction, setUserIndex, setUserIndex2, setUserIndex3, setUserObject, spaceId, toString, userIndex, userIndex2, userIndex3
Methods inherited from class com.jme3.bullet.NativePhysicsObject
compareTo, countTrackers, dumpTrackers, equals, freeUnusedObjects, hasAssignedNativeObject, hashCode, nativeId, reassignNativeId, setNativeId, setNativeIdNotTracked, unassignNativeObject
-
Field Details
-
logger3
message logger for this class
-
-
Constructor Details
-
GhostControl
protected GhostControl()No-argument constructor needed by SavableClassUtil. -
GhostControl
Instantiate an enabled Control with the specified CollisionShape.- Parameters:
shape
- the desired shape (not null, alias created)
-
-
Method Details
-
getSpatial
public com.jme3.scene.Spatial getSpatial()Access the controlled Spatial.- Returns:
- the Spatial, or null if none
-
isApplyPhysicsLocal
public 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
-
isApplyScale
public boolean isApplyScale()Test whether the collision-shape scale should match the spatial's scale.- Returns:
- true if matching scales, otherwise false
-
setApplyPhysicsLocal
public 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)
-
setApplyScale
public void setApplyScale(boolean setting) Alter whether the collision-shape scale should match the spatial's scale. CAUTION: Not all shapes can be scaled arbitrarily.Note that if the shape is shared (between collision objects and/or compound shapes) scaling can have unintended consequences.
- Parameters:
setting
- true → enable shape scaling (to the extent the CollisionShape supports it), false → disable shape scaling (default=false)
-
cloneForSpatial
public com.jme3.scene.control.Control cloneForSpatial(com.jme3.scene.Spatial spatial) Clone this Control for a different Spatial. No longer used as of JME 3.1.- Specified by:
cloneForSpatial
in interfacecom.jme3.scene.control.Control
- Parameters:
spatial
- (unused)- Returns:
- never
- Throws:
UnsupportedOperationException
- always
-
getPhysicsSpace
Access the PhysicsSpace to which the ghost object is (or would be) added.- Specified by:
getPhysicsSpace
in interfacePhysicsControl
- Returns:
- the pre-existing space, or null for none
-
isEnabled
public boolean isEnabled()Test whether this Control is enabled.- Specified by:
isEnabled
in interfacePhysicsControl
- Returns:
- true if enabled, otherwise false
-
render
public void render(com.jme3.renderer.RenderManager rm, com.jme3.renderer.ViewPort vp) Render this Control. Invoked once per ViewPort per frame, provided the Control is added to a scene. Should be invoked only by a subclass or by the RenderManager.- Specified by:
render
in interfacecom.jme3.scene.control.Control
- Parameters:
rm
- the RenderManager (unused)vp
- the ViewPort to render (unused)
-
setEnabled
public void setEnabled(boolean enabled) Enable or disable this Control.When the Control is disabled, the ghost object is removed from physics space. When the Control is enabled again, the object is moved to the current location of the Spatial and then added to the PhysicsSpace.
- Specified by:
setEnabled
in interfacePhysicsControl
- Parameters:
enabled
- true→enable the Control, false→disable it
-
setPhysicsSpace
If enabled, add this control's physics object to the specified PhysicsSpace. If not enabled, alter where the object would be added. The object is removed from any other space it's currently in.- Specified by:
setPhysicsSpace
in interfacePhysicsControl
- Parameters:
newSpace
- where to add, or null to simply remove
-
setSpatial
public void setSpatial(com.jme3.scene.Spatial controlledSpatial) Alter 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:
setSpatial
in interfacecom.jme3.scene.control.Control
- Parameters:
controlledSpatial
- the Spatial to control (or null)
-
update
public void update(float tpf) Update this Control. Invoked once per frame, during the logical-state update, provided the Control is added to a scene. Do not invoke directly from user code.- Specified by:
update
in interfacecom.jme3.scene.control.Control
- Parameters:
tpf
- the time interval between frames (in seconds, ≥0)
-
cloneFields
Callback fromCloner
to convert this shallow-cloned Control into a deep-cloned one, using the specified Cloner and original to resolve copied fields.- Specified by:
cloneFields
in interfacecom.jme3.util.clone.JmeCloneable
- Overrides:
cloneFields
in classPhysicsGhostObject
- Parameters:
cloner
- the Cloner that's cloning this Control (not null)original
- the instance from which this Control was shallow-cloned (not null, unaffected)
-
read
De-serialize this Control from the specified importer, for example when loading from a J3O file.- Specified by:
read
in interfacecom.jme3.export.Savable
- Overrides:
read
in classPhysicsGhostObject
- Parameters:
importer
- (not null)- Throws:
IOException
- from the importer
-
write
Serialize this Control to the specified exporter, for example when saving to a J3O file.- Specified by:
write
in interfacecom.jme3.export.Savable
- Overrides:
write
in classPhysicsGhostObject
- Parameters:
exporter
- (not null)- Throws:
IOException
- from the exporter
-