Skip to content

difference_closed_polygons_xldDifferenceClosedPolygonsXldDifferenceClosedPolygonsXlddifference_closed_polygons_xlddifference_closed_polygons_xldπŸ”—

Short descriptionπŸ”—

difference_closed_polygons_xldDifferenceClosedPolygonsXldDifferenceClosedPolygonsXlddifference_closed_polygons_xlddifference_closed_polygons_xld β€” Compute the difference of closed polygons.

SignatureπŸ”—

difference_closed_polygons_xld( xld_poly Polygons, xld_poly Sub, out xld_poly PolygonsDifference )void DifferenceClosedPolygonsXld( const HObject& Polygons, const HObject& Sub, HObject* PolygonsDifference )static void HOperatorSet.DifferenceClosedPolygonsXld( HObject polygons, HObject sub, out HObject polygonsDifference )def difference_closed_polygons_xld( polygons: HObject, sub: HObject ) -> HObject

Herror difference_closed_polygons_xld( const Hobject Polygons, const Hobject Sub, Hobject* PolygonsDifference )

Herror T_difference_closed_polygons_xld( const Hobject Polygons, const Hobject Sub, Hobject* PolygonsDifference )

HXLDPoly HXLDPoly::DifferenceClosedPolygonsXld( const HXLDPoly& Sub ) const

HXLDPoly HXLDPoly.DifferenceClosedPolygonsXld( HXLDPoly sub )

DescriptionπŸ”—

The operator difference_closed_polygons_xldDifferenceClosedPolygonsXld calculates the difference of the regions enclosed by the polygons Polygonspolygonspolygons and Subsubsub. The boundaries of this difference are returned in PolygonsDifferencepolygonsDifferencepolygons_difference.

If the individual input polygons are not closed, they are closed automatically by connecting their start and end points.

Internally, first, the regions enclosed by each set of polygons (Polygonspolygonspolygons and Subsubsub, respectively) are determined as described below. Then, the difference of these two regions is calculated.

In the following, the two sets of input polygons are referred to as boundary sets. A boundary set consists of an arbitrary number of boundaries (the individual polygons of Polygonspolygonspolygons and Subsubsub, respectively). Each boundary may be convex or concave and self-intersecting. Internal holes may be formed by the nesting of boundaries.

The region enclosed by such a boundary set is defined by the so-called Even-Odd-Rule. Thus, it consists of all points with the following property: The line constructed by connecting the point with another reference point that lies outside of the region has an odd number of intersections with boundaries.

More descriptive, this means that a boundary defines a hole in the region enclosed by another boundary if it lies completely inside that region. Similarly, the overlapping area of two separate boundaries of one boundary set is taken as a β€œhole”, i.e., it does not belong to the region enclosed by the two boundaries. Note that the region enclosed by a boundary does not depend on the orientation of the boundary.

A self-intersecting boundary may be split at the intersection point or it is reordered such that it touches itself at the intersection point. The resulting boundaries are treated as separate boundaries.

AttentionπŸ”—

The resulting polygons PolygonsDifferencepolygonsDifferencepolygons_difference contain no references to the XLD contours that are possibly referenced by Polygonspolygonspolygons and Subsubsub. Hence, operators that access the contours associated with a polygon, e.g., split_contours_xldSplitContoursXld will not work correctly.

Execution informationπŸ”—

Execution information
  • Multithreading type: reentrant (runs in parallel with non-exclusive operators).

  • Multithreading scope: global (may be called from any thread).

  • Processed without parallelization.

ParametersπŸ”—

Polygonspolygonspolygons (input_object) xld_poly(-array) β†’ objectHObjectHXLDPolyHObjectHobject

Polygons enclosing the region from which the second region is subtracted.

Subsubsub (input_object) xld_poly(-array) β†’ objectHObjectHXLDPolyHObjectHobject

Polygons enclosing the region that is subtracted from the first region.

PolygonsDifferencepolygonsDifferencepolygons_difference (output_object) xld_poly(-array) β†’ objectHObjectHXLDPolyHObjectHobject *

Polygons enclosing the difference.

ResultπŸ”—

difference_closed_polygons_xldDifferenceClosedPolygonsXld returns 2 (H_MSG_TRUE) if all parameters are correct. If necessary, an exception is raised.

Combinations with other operatorsπŸ”—

Combinations

Possible predecessors

gen_polygons_xldGenPolygonsXld

Alternatives

differenceDifference

See also

intersection_closed_polygons_xldIntersectionClosedPolygonsXld, symm_difference_closed_polygons_xldSymmDifferenceClosedPolygonsXld, union2_closed_polygons_xldUnion2ClosedPolygonsXld, difference_closed_contours_xldDifferenceClosedContoursXld

ModuleπŸ”—

Foundation