ClipPrimitive Class
- ClipPrimitive is a base class for clipping implementations that use
- A UnionOfConvexClipPlaneSets designated "clipPlanes"
- an "invisible" flag
- When constructed directly, objects of type ClipPrimitive (directly, not through a derived class) will have just planes
- Derived classes (e.g. ClipShape) carry additional data such as a swept shape.
- ClipPrimitive can be constructed with no planes.
- Derived class is responsible for filling the plane sets.
- At discretion of derived classes, plane construction can be done at construction time or "on demand when" queries call
ensurePlaneSets ()
- ClipPrimitive can be constructed directly with planes (and no derived class).
- That the prevailing use is via a ClipShape derived class.
- The ClipShape has an "isMask" property
- isMask === false means the plane sets should cover the inside of its polygon
- isMask === true means the plane sets should cover the outside of its polygon.
- Note that the ClipShape's
isMask property and the ClipPrimitive's isInvisible property are distinct controls.
- In normal usage, callers get "outside" clip behavior using ONLY the ClipShape isMask property.
- The ClipShape happens to pass the _invisible bit down to ClipPlanes that it creates.
- At that level, the flag controls whether the cut edges are produced on the plane
- This seems like an confused overloading of the meaning.
Extended by
Implements
Methods
| Name |
Description |
|
| constructor(planeSet?: UnionOfConvexClipPlaneSets, isInvisible: boolean = false): ClipPrimitive Protected |
|
|
| announceClippedArcIntervals(arc: Arc3d, announce?: AnnounceNumberNumberCurvePrimitive): boolean |
Method from Clipper interface. |
|
| announceClippedSegmentIntervals(f0: number, f1: number, pointA: Point3d, pointB: Point3d, announce?: AnnounceNumberNumber): boolean |
Method from Clipper interface. |
|
| arePlanesDefined(): boolean |
Returns true if the planes are present. |
|
| classifyPointContainment(points: Point3d[], ignoreInvisibleSetting: boolean): ClipPlaneContainment |
Quick test of whether the given points fall completely inside or outside. |
|
| clone(): ClipPrimitive |
Return a deep clone |
|
| containsZClip(): boolean |
Return true if any plane of the primary clipPlanes has (a) non-zero z component in its normal vector and (b) finite distance from origin. |
|
| ensurePlaneSets(): void |
* trigger (if needed) computation of plane sets (if applicable) in the derived class. |
|
| fetchClipPlanesRef(): undefined | UnionOfConvexClipPlaneSets |
Get a reference to the UnionOfConvexClipPlaneSets. |
|
| isPointOnOrInside(point: Point3d, onTolerance: number = Geometry.smallMetricDistanceSquared): boolean |
Method from Clipper interface. |
|
| multiplyPlanesByMatrix4d(matrix: Matrix4d, invert: boolean = true, transpose: boolean = true): boolean |
Multiply all ClipPlanes DPoint4d by matrix. |
|
| pointInside(point: Point3d, onTolerance: number = Geometry.smallMetricDistanceSquared): boolean |
Return true if the point lies inside/on this polygon (or not inside/on if this polygon is a mask). |
|
| setInvisible(invisible: boolean): void |
Sets both the clip plane set and the mask set visibility |
|
| toJSON(): ClipPrimitiveProps |
Emit json form of the clip planes |
|
| transformInPlace(transform: Transform): boolean |
Apply a transform to the clipper (e.g. |
|
| createCapture(planes: undefined | ConvexClipPlaneSet | UnionOfConvexClipPlaneSets, isInvisible: boolean = false): ClipPrimitive Static |
Create a ClipPrimitive, capturing the supplied plane set as the clip planes. |
|
| fromJSON(json: undefined | ClipPrimitiveProps): undefined | ClipPrimitive Static |
Promote json object form to class instance |
|
| fromJSONClipPrimitive(json: undefined | ClipPrimitivePlanesProps): undefined | ClipPrimitive Static |
Specific converter producing the base class ClipPrimitive. |
|
Properties
| Name |
Type |
Description |
|
| _clipPlanes Protected |
undefined | UnionOfConvexClipPlaneSets |
The (union of) convex regions. |
|
| _invisible Protected |
boolean |
If true, pointInside inverts the sense of the pointInside for the _clipPlanes |
|
| invisible Accessor ReadOnly |
boolean |
Ask if this primitive is a hole. |
|
Defined in
Last Updated:
30 November, 2023