Package org.robwork.sdurw
Class DistanceStrategyPtr
- java.lang.Object
-
- org.robwork.sdurw.DistanceStrategyPtr
-
public class DistanceStrategyPtr extends java.lang.ObjectPtr stores a pointer and optionally takes ownership of the value.
-
-
Constructor Summary
Constructors Constructor Description DistanceStrategyPtr()Default constructor yielding a NULL-pointer.DistanceStrategyPtr(long cPtr, boolean cMemoryOwn)DistanceStrategyPtr(DistanceStrategy ptr)Do not take ownership of ptr.
ptr can be null.
The constructor is implicit on purpose.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description DistanceStrategy__ref__()Dereferencing operator.booleanaddGeometry(ProximityModel model, Geometry geom)adds geometry to a specific proximity model.booleanaddGeometry(ProximityModel model, GeometryPtr geom)adds geometry to a specific model.booleanaddGeometry(ProximityModel model, GeometryPtr geom, boolean forceCopy)adds geometry to a specific model.booleanaddModel(Frame frame, Geometry faces)Adds a Proximity model to a frame where the geometry is copied
in the underlying proximity strategy.
The Proximity model is constructed from the list of faces
booleanaddModel(Frame frame, GeometryPtr faces)Adds a Proximity model to a frame.
The Proximity model is constructed from the list of faces
booleanaddModel(Frame frame, GeometryPtr faces, boolean forceCopy)Adds a Proximity model to a frame.
The Proximity model is constructed from the list of faces
booleanaddModel(ObjectPtr object)Adds a Proximity model of a frame to this strategy.
The Proximity model is the one specified in the frames property
voidclear()Clears any stored model informationvoidclearFrame(Frame frame)Clear (remove all) model information for frame frame.voidclearFrames()Clear (remove all) model information for all frames.ProximityModelPtrcreateModel()creates an empty ProximityModelvoiddelete()DistanceStrategyderef()The pointer stored in the object.voiddestroyModel(ProximityModel model)deallocates the memory used for modelDistanceStrategyResultdistance(Frame a, Transform3Dd wTa, Frame b, Transform3Dd wTb)Calculates the distance between two given frames \mathcal{F}_a and
\mathcal{F}_b
Conditional comment:
End of conditional comment.DistanceStrategyResultdistance(Frame a, Transform3Dd wTa, Frame b, Transform3Dd wTb, double threshold)Calculates the distance between two given frames \mathcal{F}_a and
\mathcal{F}_b if the distance are within threshold.DistanceStrategyResultdistance(Frame a, Transform3Dd wTa, Frame b, Transform3Dd wTb, double threshold, ProximityStrategyData data)Calculates the distance between two given frames \mathcal{F}_a and
\mathcal{F}_b if the distance are within threshold.DistanceStrategyResultdistance(Frame a, Transform3Dd wTa, Frame b, Transform3Dd wTb, ProximityStrategyData data)Calculates the distance between two given frames \mathcal{F}_a and
\mathcal{F}_b
Conditional comment:
End of conditional comment.DistanceStrategyResultdistance(ProximityModelPtr a, Transform3Dd wTa, ProximityModelPtr b, Transform3Dd wTb, double threshold, ProximityStrategyData data)Calculates the distance between two given frames \mathcal{F}_a and
\mathcal{F}_b if the distance are within threshold.DistanceStrategyResultdistance(ProximityModelPtr a, Transform3Dd wTa, ProximityModelPtr b, Transform3Dd wTb, ProximityStrategyData data)Calculates the distance between two proximity models \mathcal{a} and
\mathcal{b}
Conditional comment:
End of conditional comment.booleanequals(DistanceStrategy p)static longgetCPtr(DistanceStrategyPtr obj)DistanceStrategygetDeref()Member access operator.VectorStringgetGeometryIDs(ProximityModel model)the list of all geometry ids that are associated to
the proximity model model is returnedProximityModelPtrgetModel(Frame frame)get the proximitymodel associated to frame.booleanhasModel(Frame frame)Tells whether the frame has a proximity model in the strategy
To have a proximity model does not means that it is loaded.booleanisNull()checks if the pointer is nullbooleanisShared()check if this Ptr has shared ownership or none
ownershipbooleanremoveGeometry(ProximityModel model, java.lang.String geomId)removes a geometry from a specific proximity model
-
-
-
Constructor Detail
-
DistanceStrategyPtr
public DistanceStrategyPtr(long cPtr, boolean cMemoryOwn)
-
DistanceStrategyPtr
public DistanceStrategyPtr()
Default constructor yielding a NULL-pointer.
-
DistanceStrategyPtr
public DistanceStrategyPtr(DistanceStrategy ptr)
Do not take ownership of ptr.
ptr can be null.
The constructor is implicit on purpose.
-
-
Method Detail
-
getCPtr
public static long getCPtr(DistanceStrategyPtr obj)
-
delete
public void delete()
-
deref
public DistanceStrategy deref()
The pointer stored in the object.
-
__ref__
public DistanceStrategy __ref__()
Dereferencing operator.
-
getDeref
public DistanceStrategy getDeref()
Member access operator.
-
equals
public boolean equals(DistanceStrategy p)
-
isShared
public boolean isShared()
check if this Ptr has shared ownership or none
ownership- Returns:
- true if Ptr has shared ownership, false if it has no ownership.
-
isNull
public boolean isNull()
checks if the pointer is null- Returns:
- Returns true if the pointer is null
-
distance
public DistanceStrategyResult distance(Frame a, Transform3Dd wTa, Frame b, Transform3Dd wTb)
Calculates the distance between two given frames \mathcal{F}_a and
\mathcal{F}_b
Conditional comment:
End of conditional comment.- Parameters:
a- [in] \mathcal{F}_awTa- [in] \robabx{w}{a}{\mathbf{T}}b- [in] \mathcal{F}_bwTb- [in] \robabx{w}{b}{\mathbf{T}}- Returns:
- shortest distance if \mathcal{F}_a and \mathcal{F}_b are
separated and not in collision.
-
distance
public DistanceStrategyResult distance(Frame a, Transform3Dd wTa, Frame b, Transform3Dd wTb, ProximityStrategyData data)
Calculates the distance between two given frames \mathcal{F}_a and
\mathcal{F}_b
Conditional comment:
End of conditional comment.- Parameters:
a- [in] \mathcal{F}_awTa- [in] \robabx{w}{a}{\mathbf{T}}b- [in] \mathcal{F}_bwTb- [in] \robabx{w}{b}{\mathbf{T}}data-- Returns:
- shortest distance if \mathcal{F}_a and \mathcal{F}_b are
separated and not in collision.
-
distance
public DistanceStrategyResult distance(ProximityModelPtr a, Transform3Dd wTa, ProximityModelPtr b, Transform3Dd wTb, ProximityStrategyData data)
Calculates the distance between two proximity models \mathcal{a} and
\mathcal{b}
Conditional comment:
End of conditional comment.- Parameters:
a- [in] \mathcal{F}_awTa- [in] \robabx{w}{a}{\mathbf{T}}b- [in] \mathcal{F}_bwTb- [in] \robabx{w}{b}{\mathbf{T}}data-- Returns:
- shortest distance if \mathcal{F}_a and \mathcal{F}_b are
separated and not in collision.
-
distance
public DistanceStrategyResult distance(Frame a, Transform3Dd wTa, Frame b, Transform3Dd wTb, double threshold)
Calculates the distance between two given frames \mathcal{F}_a and
\mathcal{F}_b if the distance are within threshold. If the distance
between the frames are larger than the threshold, the result will be inaccurate.
Conditional comment:
End of conditional comment.- Parameters:
a- [in] \mathcal{F}_awTa- [in] \robabx{w}{a}{\mathbf{T}}b- [in] \mathcal{F}_bwTb- [in] \robabx{w}{b}{\mathbf{T}}threshold- [in] threshold for distance calculations- Returns:
- shortest distance if \mathcal{F}_a and \mathcal{F}_b are
separated and not in collision.
-
distance
public DistanceStrategyResult distance(Frame a, Transform3Dd wTa, Frame b, Transform3Dd wTb, double threshold, ProximityStrategyData data)
Calculates the distance between two given frames \mathcal{F}_a and
\mathcal{F}_b if the distance are within threshold. If the distance
between the frames are larger than the threshold, the result will be inaccurate.- Parameters:
a- [in] \mathcal{F}_awTa- [in] \robabx{w}{a}{\mathbf{T}}b- [in] \mathcal{F}_bwTb- [in] \robabx{w}{b}{\mathbf{T}}threshold- [in] threshold for distance calculationsdata-- Returns:
- shortest distance if \mathcal{F}_a and \mathcal{F}_b are
separated and not in collision.
-
distance
public DistanceStrategyResult distance(ProximityModelPtr a, Transform3Dd wTa, ProximityModelPtr b, Transform3Dd wTb, double threshold, ProximityStrategyData data)
Calculates the distance between two given frames \mathcal{F}_a and
\mathcal{F}_b if the distance are within threshold. If the distance
between the frames are larger than the threshold, the result will be inaccurate.
Conditional comment:
End of conditional comment.- Parameters:
a- [in] \mathcal{F}_awTa- [in] \robabx{w}{a}{\mathbf{T}}b- [in] \mathcal{F}_bwTb- [in] \robabx{w}{b}{\mathbf{T}}threshold- [in] threshold for distance calculationsdata-- Returns:
- shortest distance if \mathcal{F}_a and \mathcal{F}_b are
separated and not in collision.
-
addModel
public boolean addModel(ObjectPtr object)
Adds a Proximity model of a frame to this strategy.
The Proximity model is the one specified in the frames property
- Parameters:
object- [in] the frame on which the Proximity model is to be
created.
- Returns:
- true if a Proximity model was succesfully created and linked
with the frame; false otherwise.
-
addModel
public boolean addModel(Frame frame, Geometry faces)
Adds a Proximity model to a frame where the geometry is copied
in the underlying proximity strategy.
The Proximity model is constructed from the list of faces
- Parameters:
frame- [in] the frame to which the Proximity model should associatefaces- [in] list of faces from which to construct the Proximity model- Returns:
- true if a Proximity model was succesfully created and linked
with the frame; false otherwise.
-
addModel
public boolean addModel(Frame frame, GeometryPtr faces, boolean forceCopy)
Adds a Proximity model to a frame.
The Proximity model is constructed from the list of faces
- Parameters:
frame- [in] the frame to which the Proximity model should associatefaces- [in] list of faces from which to construct the Proximity modelforceCopy- [in] force the strategy to copy the geometry data, if false the
strategy may choose to store the geometry reference or not.- Returns:
- true if a Proximity model was succesfully created and linked
with the frame; false otherwise.
-
addModel
public boolean addModel(Frame frame, GeometryPtr faces)
Adds a Proximity model to a frame.
The Proximity model is constructed from the list of faces
- Parameters:
frame- [in] the frame to which the Proximity model should associatefaces- [in] list of faces from which to construct the Proximity model
- Returns:
- true if a Proximity model was succesfully created and linked
with the frame; false otherwise.
-
hasModel
public boolean hasModel(Frame frame)
Tells whether the frame has a proximity model in the strategy
To have a proximity model does not means that it is loaded. If a GeoID string from
which a model can be loaded it returns true as well
- Parameters:
frame- [in] the frame to check for1.0/- Returns:
- true if a model exists or can be created
-
clearFrame
public void clearFrame(Frame frame)
Clear (remove all) model information for frame frame.
-
clearFrames
public void clearFrames()
Clear (remove all) model information for all frames.
-
getModel
public ProximityModelPtr getModel(Frame frame)
get the proximitymodel associated to frame. If no model
has been associated to frame then NULL is returned.- Parameters:
frame- [in] frame for which an proximitymodel is associated
-
createModel
public ProximityModelPtr createModel()
creates an empty ProximityModel
-
destroyModel
public void destroyModel(ProximityModel model)
deallocates the memory used for model- Parameters:
model-
-
addGeometry
public boolean addGeometry(ProximityModel model, Geometry geom)
adds geometry to a specific proximity model. The proximity strategy copies all
data of the geometry.- Parameters:
model- [in] the proximity model to add data togeom- [in] the geometry that is to be added
-
addGeometry
public boolean addGeometry(ProximityModel model, GeometryPtr geom, boolean forceCopy)
adds geometry to a specific model. Depending on the option forceCopy the proximity
strategy may choose to copy the geometry data or use it directly.- Parameters:
model-geom-forceCopy-- Returns:
-
addGeometry
public boolean addGeometry(ProximityModel model, GeometryPtr geom)
adds geometry to a specific model. Depending on the option forceCopy the proximity
strategy may choose to copy the geometry data or use it directly.- Parameters:
model-geom-
- Returns:
-
removeGeometry
public boolean removeGeometry(ProximityModel model, java.lang.String geomId)
removes a geometry from a specific proximity model- Returns:
- true if succesfull
-
getGeometryIDs
public VectorString getGeometryIDs(ProximityModel model)
the list of all geometry ids that are associated to
the proximity model model is returned- Parameters:
model- [in] the model containing the geometries- Returns:
- all geometry ids associated to the proximity model
-
clear
public void clear()
Clears any stored model information
-
-