phoenix_title wx.lib.floatcanvas.FCObjects.PointSet

Draws a set of points

If Points is a sequence of tuples: Points[N][0] is the x-coordinate of point N and Points[N][1] is the y-coordinate.

If Points is a NumPy array: Points[N,0] is the x-coordinate of point N and Points[N,1] is the y-coordinate for arrays.

Each point will be drawn the same color and Diameter. The Diameter is in screen pixels, not world coordinates.

The hit-test code does not distingish between the points, you will only know that one of the points got hit, not which one. You can use PointSet.FindClosestPoint(WorldPoint) to find out which one

In the case of points, the HitLineWidth is used as diameter.


class_hierarchy Class Hierarchy

Inheritance diagram for class PointSet:

method_summary Methods Summary

__init__

Default class constructor.

DrawD2

FindClosestPoint

Returns the index of the closest point to the point, XY, given

SetDiameter

Sets the diameter


api Class API

class PointSet(PointsObjectMixin, ColorOnlyMixin, DrawObject)

Draws a set of points

If Points is a sequence of tuples: Points[N][0] is the x-coordinate of point N and Points[N][1] is the y-coordinate.

If Points is a NumPy array: Points[N,0] is the x-coordinate of point N and Points[N,1] is the y-coordinate for arrays.

Each point will be drawn the same color and Diameter. The Diameter is in screen pixels, not world coordinates.

The hit-test code does not distingish between the points, you will only know that one of the points got hit, not which one. You can use PointSet.FindClosestPoint(WorldPoint) to find out which one

In the case of points, the HitLineWidth is used as diameter.


Methods

__init__(self, Points, Color="Black", Diameter=1, InForeground=False)

Default class constructor.

Parameters
  • Points – takes a 2-tuple, or a (2,) NumPy array of point coordinates

  • Color – see SetColor

  • Diameter (integer) – the points diameter

  • InForeground (boolean) – should object be in foreground



DrawD2(self, dc, Points)


FindClosestPoint(self, XY)

Returns the index of the closest point to the point, XY, given in World coordinates. It’s essentially random which you get if there are more than one that are the same.

This can be used to figure out which point got hit in a mouse binding callback, for instance. It’s a lot faster that using a lot of separate points.

Parameters

XY – the (x,y) coordinates of the point to look for, it takes a 2-tuple or (2,) numpy array in World coordinates



SetDiameter(self, Diameter)

Sets the diameter

Parameters

Diameter (integer) – the points diameter