GeoAPI 1.0
Build 2004-05-18

org.opengis.spatialschema.geometry.primitive
Interface OrientablePrimitive

All Superinterfaces:
Geometry, Primitive, TransfiniteSet
All Known Subinterfaces:
CompositeCurve, CompositeSurface, Curve, OrientableCurve, OrientableSurface, Ring, Shell, Surface

public interface OrientablePrimitive
extends Primitive

Primitives that can be mirrored into new geometric objects in terms of their internal local coordinate systems (manifold charts). For curves, the orientation reflects the direction in which the curve is traversed, that is, the sense of its parameterization. When used as boundary curves, the surface being bounded is to the "left" of the oriented curve. For surfaces, the orientation reflects from which direction the local coordinate system can be viewed as right handed, the "top" or the surface being the direction of a completing z-axis that would form a right-handed system. When used as a boundary surface, the bounded solid is "below" the surface. The orientation of points and solids has no immediate geometric interpretation in 3-dimensional space.

OrientablePrimitive objects are essentially references to geometric primitives that carry an "orientation" reversal flag (either "+" or "-") that determines whether this primitive agrees or disagrees with the orientation of the referenced object.

NOTE: There are several reasons for subclassing the “positive” primitives under the orientable primitives. First is a matter of the semantics of subclassing. Subclassing is assumed to be a “is type of” hierarchy. In the view used, the “positive” primitive is simply the orientable one with the positive orientation. If the opposite view were taken, and orientable primitives were subclassed under the “positive” primitive, then by subclassing logic, the “negative” primitive would have to hold the same sort of geometric description that the “positive” primitive does. The only viable solution would be to separate “negative” primitives under the geometric root as being some sort of reference to their opposite. This adds a great deal of complexity to the subclassing tree. To minimize the number of objects and to bypass this logical complexity, positively oriented primitives are self-referential (are instances of the corresponding primitive subtype) while negatively oriented primitives are not.

Version:
2.0
Author:
ISO/DIS 19107, OpenGIS® consortium
UML identifier (abstract type): GM_OrientablePrimitive

Method Summary
 int getOrientation()
          Determines which of the two possible orientations this object represents.
 Primitive getPrimitive()
          Returns the primitive associated with this OrientablePrimitive.
 
Methods inherited from interface Primitive
getBoundary, getComplexes, getContainedPrimitives, getContainingPrimitives, getProxy
 
Methods inherited from interface Geometry
getBuffer, getCentroid, getClosure, getConvexHull, getCoordinateDimension, getCoordinateReferenceSystem, getDimension, getDistance, getEnvelope, getMaximalComplex, getMbRegion, getRepresentativePoint, isCycle, isSimple, transform, transform
 
Methods inherited from interface TransfiniteSet
contains, contains, difference, equals, intersection, intersects, symmetricDifference, union
 

Method Detail

getOrientation

int getOrientation()
Determines which of the two possible orientations this object represents.

Returns:
+1 for a positive orientation, or -1 for a negative orientation.
UML identifier (operation): orientation

getPrimitive

Primitive getPrimitive()
Returns the primitive associated with this OrientablePrimitive. Each primitive of dimension 1 or 2 is associated to two OrientablePrimitives, one for each possible orientation. For curves and surfaces, there are exactly two orientable primitives for each geometric object.

Returns:
The primitive, never null.
See Also:
Primitive.getProxy()
UML identifier (association): primitive

GeoAPI 1.0
Build 2004-05-18

Symbols, terms and definitions
Copyright OpenGIS® Consortium