cam.utilities.shapely_utils#

Fabex ‘shapely_utils.py’ © 2012 Vilem Novak

Functions to handle shapely operations and conversions - curve, coords, polygon

Functions#

shapely_remove_doubles(p, optimize_threshold)

Remove duplicate points from the boundary of a shape.

shapely_to_multipolygon(anydata)

Convert a Shapely geometry to a MultiPolygon.

shapely_to_coordinates(anydata)

Convert a Shapely geometry object to a list of coordinates.

shapely_to_curve(name, p, z[, cyclic])

Create a 3D curve object in Blender from a Shapely geometry.

Module Contents#

shapely_remove_doubles(p, optimize_threshold)[source]#

Remove duplicate points from the boundary of a shape.

This function simplifies the boundary of a given shape by removing duplicate points using the Ramer-Douglas-Peucker algorithm. It iterates through each contour of the shape, applies the simplification, and adds the resulting contours to a new shape. The optimization threshold can be adjusted to control the level of simplification.

Parameters:
  • p (Shape) – The shape object containing boundaries to be simplified.

  • optimize_threshold (float) – A threshold value that influences the simplification process.

Returns:

A new shape object with simplified boundaries.

Return type:

Shape

shapely_to_multipolygon(anydata)[source]#

Convert a Shapely geometry to a MultiPolygon.

This function takes a Shapely geometry object and converts it to a MultiPolygon. If the input geometry is already a MultiPolygon, it returns it as is. If the input is a Polygon and not empty, it wraps the Polygon in a MultiPolygon. If the input is an empty Polygon, it returns an empty MultiPolygon. For any other geometry type, it prints a message indicating that the conversion was aborted and returns an empty MultiPolygon.

Parameters:

anydata (shapely.geometry.base.BaseGeometry) – A Shapely geometry object

Returns:

A MultiPolygon representation of the input geometry.

Return type:

shapely.geometry.MultiPolygon

shapely_to_coordinates(anydata)[source]#

Convert a Shapely geometry object to a list of coordinates.

This function takes a Shapely geometry object and extracts its coordinates based on the geometry type. It handles various types of geometries including Polygon, MultiPolygon, LineString, MultiLineString, and GeometryCollection. If the geometry is empty or of type MultiPoint, it returns an empty list. The coordinates are returned in a nested list format, where each sublist corresponds to the exterior or interior coordinates of the geometries.

Parameters:

anydata (shapely.geometry.base.BaseGeometry) – A Shapely geometry object

Returns:

A list of coordinates extracted from the input geometry. The structure of the list depends on the geometry type.

Return type:

list

shapely_to_curve(name, p, z, cyclic=True)[source]#

Create a 3D curve object in Blender from a Shapely geometry.

This function takes a Shapely geometry and converts it into a 3D curve object in Blender. It extracts the coordinates from the Shapely geometry and creates a new curve object with the specified name. The curve is created in the 3D space at the given z-coordinate, with a default weight for the points.

Parameters:
  • name (str) – The name of the curve object to be created.

  • p (shapely.geometry) – A Shapely geometry object from which to extract coordinates.

  • z (float) – The z-coordinate for all points of the curve.

Returns:

The newly created curve object in Blender.

Return type:

bpy.types.Object