mapteksdk.data.primitives.point_properties module
Support for point primitives.
A point is a 3D location in space. In Python, they are represented as a numpy array containing three 64-bit floating point numbers, representing the location relative to the origin. For example, the point [X, Y, Z] is X metres away from the origin in the x direction (typically east), Y metres away from the origin in the y direction (typically north) and Z metres away from the origin in the z direction (typically up).
Points are typically used to define other primitives, such as edges, facets and cells.
- class PointProperties
Bases:
object
Mixin class which provides spatial objects support for point primitives.
A point is represented as a numpy array of length 3 of the form [x, y, z] where x, y and z are floating point numbers. For example, the point [1, 2, 3.5] is 1 metre away from the origin in the X direction (East in a standard view), 2 units away from the origin in the Y direction (North in a standard view) and 3.5 units away from the origin in the z direction. If one of the elements of a point is negative, this indicates its distance from the origin is in the opposite direction. For example, the point [-1, 0, 0] is 1 unit away from the origin in the direction opposite to the East arrow.
Functions and properties defined on this class are available on all classes which support points.
- property points
A 2D ndarray of points of the form: [[x1, y1, z1], [x2, y2, z2], …, [xN, yN, zN]] Where N is the number of points.
- Raises
AttributeError – If attempting to set the points on an object which does not support setting points.
Examples
Create a new point set and set the points:
>>> from mapteksdk.project import Project >>> from mapteksdk.data import PointSet >>> project = Project() ... with project.new("cad/test_points", PointSet) as new_points: ... new_points.points = [[0, 0, 0], [1, 0, 0], [1, 1, 0], ... [0, 1, 0], [0, 2, 2], [0, -1, 3]]
Print the second point from the point set defined above.
>>> from mapteksdk.project import Project >>> from mapteksdk.data import PointSet >>> project = Project() >>> with project.read("cad/test_points") as read_points: ... print(read_points.points[2]) [1., 1., 0.]
Then set the 2nd point to [1, 2, 3]:
>>> from mapteksdk.project import Project >>> from mapteksdk.data import PointSet >>> project = Project() >>> with project.edit("cad/test_points") as edit_points: ... edit_points.points[2] = [1, 2, 3]
Iterate over all of the points and print them.
>>> from mapteksdk.project import Project >>> from mapteksdk.data import PointSet >>> project = Project() >>> with project.read("cad/test_points") as read_points: >>> for point in read_points.points: >>> print(point) [0., 0., 0.] [1., 0., 0.] [1., 2., 3.] [0., 1., 0.] [0., 2., 2.] [0., -1., 3.]
Print all points with y > 0 using numpy. Note that index has one element for each point which will be true if that point has y > 0 and false otherwise. This is then used to retrieve the points with y > 0.
>>> from mapteksdk.project import Project >>> from mapteksdk.data import PointSet >>> project = Project() >>> with project.read("cad/test_points") as read_points: ... index = read_points.points[:, 1] > 0 ... print(read_points.points[index]) [[1. 2. 3.] [0. 1. 0.] [0. 2. 2.]]
- property point_z
The Z coordinates of the points.
- Raises
ValueError – If set using a string which cannot be converted to a float.
ValueError – If set to a value which cannot be broadcast to the right shape.
TypeError – If set using a value which cannot be converted to a float.
- property point_colours
The colours of the points, represented as a 2d ndarray of RGBA colours. When setting the colour you may use RGB or greyscale colours instead of RGBA colours. The array has one colour for each point. Object.point_colours[i] returns the colour of Object.points[i].
Notes
When the point colours are set, if there are more colours than points then the excess colours are silently ignored. If there are fewer colours than points then uncoloured points are coloured green. If only a single colour is specified, instead of padding with green all of the points are coloured with that colour. i.e.: object.point_colours = [[Red, Green, Blue]] will set all points to be the colour [Red, Green, Blue].
- property point_visibility
A 1D ndarray representing the visibility of points.
Object.point_visibility[i] is true if Object.point[i] is visible. It will be False if the point is invisible.
Object.point_visibility[i] = False will make Object.point[i] invisible.
- property point_selection
A 1D ndarray representing the point selection.
If Object.point_selection[i] = True then Object.point[i] is selected. Object.point_selection[i] = False then Object.point[i] is not selected.
- property point_count
The number of points in the object.
- remove_points(point_indices, update_immediately=True)
Remove one or more points. This is done directly in the project and thus changes made by this function will be saved even if save() is not called.
- Parameters
point_indices (array_like or int) – The index of the point to remove or a list of indices of points to remove.
update_immediately (bool) – If True, the deletion is done in the Project immediately. If False, the deletion is done when the object is closed.
- Returns
True if successful
- Return type
bool
Notes
Calling save() immediately after calling this function is recommended.
- property point_attributes
Access the custom point attributes. These are arrays of values of the same type with one value for each point.
Use Object.point_attributes[attribute_name] to access the point attribute called attribute_name. See PrimitiveAttributes for valid operations on point attributes.
- Returns
Access to the point attributes.
- Return type
- Raises
ValueError – If the type of the attribute is not supported.
- save_point_attribute(attribute_name, data)
Create and/or edit the values of the point attribute attribute_name.
This is equivalent to Object.point_attributes[attribute_name] = data.
- Parameters
attribute_name (str) – The name of attribute
data (array_like) – An array_like of length point_count containing the values for attribute_name.
- Raises
Exception – If the object is opened in read-only mode.
ValueError – If the type of the attribute is not supported.
- delete_point_attribute(attribute_name)
Delete a point attribute by name.
This is equivalent to: point_attributes.delete_attribute(attribute_name)
- Parameters
attribute_name (str) – The name of attribute
- Raises
Exception – If the object is opened in read-only mode.
ValueError – If the primitive type is not supported.