Package com.jme3.bullet.collision.shapes
Class CustomConvexShape
java.lang.Object
com.jme3.bullet.NativePhysicsObject
com.jme3.bullet.collision.shapes.CollisionShape
com.jme3.bullet.collision.shapes.ConvexShape
com.jme3.bullet.collision.shapes.CustomConvexShape
- All Implemented Interfaces:
- Comparable<NativePhysicsObject>
An abstract base class for collision shapes defined in terms of their
 supporting vertices, based on Bullet's 
btConvexInternalShape.- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final Loggermessage logger for this classprotected static final ThreadLocal<Vector3f> temporary storage for one vector per threadFields inherited from class com.jme3.bullet.collision.shapes.ConvexShapeloggerXFields inherited from class com.jme3.bullet.collision.shapes.CollisionShapeenableContactFilter, logger, margin, scaleFields inherited from class com.jme3.bullet.NativePhysicsObjectloggerN
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedCustomConvexShape(float xHalfExtent, float yHalfExtent, float zHalfExtent) Instantiate a custom collision shape with the specified extents.protectedCustomConvexShape(Vector3f halfExtents) Instantiate a custom collision shape with the specified extents.
- 
Method SummaryModifier and TypeMethodDescriptionprotected abstract Vector3flocateSupport(float dirX, float dirY, float dirZ) Locate the shape's supporting vertex for the specified normal direction, excluding collision margin.protected voidsetScaledInertia(float ix, float iy, float iz) Alter the scaled rotational inertia.Methods inherited from class com.jme3.bullet.collision.shapes.ConvexShapeisConcave, isConvex, scaledVolume, toHullShape, toSplittableShapeMethods inherited from class com.jme3.bullet.collision.shapes.CollisionShapeaabbCenter, boundingBox, boundingBox, canScale, canSplit, getDefaultMargin, getMargin, getScale, getScaleDp, getShapeType, getShapeType, isContactFilterEnabled, isInfinite, isNonMoving, isPolyhedral, maxRadius, nativeMargin, recalculateAabb, setContactFilterEnabled, setDefaultMargin, setMargin, setNativeId, setScale, setScale, setUserIndex, setUserIndex2, toString, updateScale, userIndex, userIndex2Methods inherited from class com.jme3.bullet.NativePhysicsObjectcompareTo, countTrackers, dumpTrackers, equals, freeUnusedObjects, hasAssignedNativeObject, hashCode, nativeId, reassignNativeId, setNativeIdNotTracked, unassignNativeObject
- 
Field Details- 
loggerYmessage logger for this class
- 
threadTmpVectortemporary storage for one vector per thread
 
- 
- 
Constructor Details- 
CustomConvexShapeprotected CustomConvexShape(float xHalfExtent, float yHalfExtent, float zHalfExtent) Instantiate a custom collision shape with the specified extents. Subclass constructors should also invokesetScaledInertia().- Parameters:
- xHalfExtent- the desired half extent on the local X axis, for scale=(1,1,1) and margin=0 (>0)
- yHalfExtent- the desired half extent on the local Y axis, for scale=(1,1,1) and margin=0 (>0)
- zHalfExtent- the desired half extent on the local Z axis, for scale=(1,1,1) and margin=0 (>0)
 
- 
CustomConvexShapeInstantiate a custom collision shape with the specified extents. Subclass constructors should also invokesetScaledInertia().- Parameters:
- halfExtents- the desired half extents on each local axis, for scale=(1,1,1) and margin=0 (all components >0, unaffected), or- nullto calculate AABBs using the supporting vertices
 
 
- 
- 
Method Details- 
locateSupportLocate the shape's supporting vertex for the specified normal direction, excluding collision margin.This method is invoked by native code. - Parameters:
- dirX- the X-coordinate of the direction to test (in scaled shape coordinates)
- dirY- the Y-coordinate of the direction to test (in scaled shape coordinates)
- dirZ- the Z-coordinate of the direction to test (in scaled shape coordinates)
- Returns:
- the location on the shape's surface with the specified normal (in scaled shape coordinates, must lie on or within the shape's bounding box)
 
- 
setScaledInertiaprotected void setScaledInertia(float ix, float iy, float iz) Alter the scaled rotational inertia. Typically invoked during instantiation or after a change of scale.- Parameters:
- ix- the desired X-axis rotational inertia for mass=1 (>0)
- iy- the desired Y-axis rotational inertia for mass=1 (>0)
- iz- the desired Z-axis rotational inertia for mass=1 (>0)
 
 
-