matplotlib.widgets
¶
GUI neutral widgets¶
Widgets that are designed to work for any of the GUI backends.
All of these widgets require you to predefine a matplotlib.axes.Axes
instance and pass that as the first parameter. Matplotlib doesn't try to
be too smart with respect to layout -- you will have to figure out how
wide and tall you want your Axes to be to accommodate your widget.
-
class
matplotlib.widgets.
AxesWidget
(ax)[source]¶ Bases:
matplotlib.widgets.Widget
Widget that is connected to a single
Axes
.To guarantee that the widget remains responsive and not garbage-collected, a reference to the object should be maintained by the user.
This is necessary because the callback registry maintains only weak-refs to the functions, which are member functions of the widget. If there are no references to the widget object it may be garbage collected which will disconnect the callbacks.
Attributes: - ax
Axes
The parent axes for the widget.
- canvas
FigureCanvasBase
subclass The parent figure canvas for the widget.
active
boolIs the widget active?
- ax
-
class
matplotlib.widgets.
Button
(ax, label, image=None, color='0.85', hovercolor='0.95')[source]¶ Bases:
matplotlib.widgets.AxesWidget
A GUI neutral button.
For the button to remain responsive you must keep a reference to it. Call
on_clicked
to connect to the button.Attributes: - ax
The
matplotlib.axes.Axes
the button renders into.- label
A
matplotlib.text.Text
instance.- color
The color of the button when not hovering.
- hovercolor
The color of the button when hovering.
Parameters: - ax
Axes
The
Axes
instance the button will be placed into.- labelstr
The button text. Accepts string.
- imagearray-like or PIL image
The image to place in the button, if not None. Supported inputs are the same as for
Axes.imshow
.- colorcolor
The color of the button when not activated.
- hovercolorcolor
The color of the button when the mouse is over it.
-
class
matplotlib.widgets.
CheckButtons
(ax, labels, actives=None)[source]¶ Bases:
matplotlib.widgets.AxesWidget
A GUI neutral set of check buttons.
For the check buttons to remain responsive you must keep a reference to this object.
Connect to the CheckButtons with the
on_clicked()
methodAttributes: - ax
The
matplotlib.axes.Axes
the button are located in.- labels
A list of
matplotlib.text.Text
s.- lines
List of (line1, line2) tuples for the x's in the check boxes. These lines exist for each box, but have
set_visible(False)
when its box is not checked.- rectangles
A list of
matplotlib.patches.Rectangle
s.
Add check buttons to
matplotlib.axes.Axes
instance axParameters: - ax
Axes
The parent axes for the widget.
- labelslist of str
The labels of the check buttons.
- activeslist of bool, optional
The initial check states of the buttons. The list must have the same length as labels. If not given, all buttons are unchecked.
-
class
matplotlib.widgets.
Cursor
(ax, horizOn=True, vertOn=True, useblit=False, **lineprops)[source]¶ Bases:
matplotlib.widgets.AxesWidget
A crosshair cursor that spans the axes and moves with mouse cursor.
For the cursor to remain responsive you must keep a reference to it.
Parameters: - ax
matplotlib.axes.Axes
The
Axes
to attach the cursor to.- horizOnbool, optional, default: True
Whether to draw the horizontal line.
- vertOnbool, optional, default: True
Whether to draw the vertical line.
- useblitbool, optional, default: False
Use blitting for faster drawing if supported by the backend.
Other Parameters: Examples
See Cursor.
- ax
-
class
matplotlib.widgets.
EllipseSelector
(ax, onselect, drawtype='box', minspanx=None, minspany=None, useblit=False, lineprops=None, rectprops=None, spancoords='data', button=None, maxdist=10, marker_props=None, interactive=False, state_modifier_keys=None)[source]¶ Bases:
matplotlib.widgets.RectangleSelector
Select an elliptical region of an axes.
For the cursor to remain responsive you must keep a reference to it.
Example usage:
import numpy as np import matplotlib.pyplot as plt from matplotlib.widgets import EllipseSelector def onselect(eclick, erelease): "eclick and erelease are matplotlib events at press and release." print('startposition: (%f, %f)' % (eclick.xdata, eclick.ydata)) print('endposition : (%f, %f)' % (erelease.xdata, erelease.ydata)) print('used button : ', eclick.button) def toggle_selector(event): print(' Key pressed.') if event.key in ['Q', 'q'] and toggle_selector.ES.active: print('EllipseSelector deactivated.') toggle_selector.RS.set_active(False) if event.key in ['A', 'a'] and not toggle_selector.ES.active: print('EllipseSelector activated.') toggle_selector.ES.set_active(True) x = np.arange(100.) / 99 y = np.sin(x) fig, ax = plt.subplots() ax.plot(x, y) toggle_selector.ES = EllipseSelector(ax, onselect, drawtype='line') fig.canvas.mpl_connect('key_press_event', toggle_selector) plt.show()
Create a selector in ax. When a selection is made, clear the span and call onselect with:
onselect(pos_1, pos_2)
and clear the drawn box/line. The
pos_1
andpos_2
are arrays of length 2 containing the x- and y-coordinate.If minspanx is not None then events smaller than minspanx in x direction are ignored (it's the same for y).
The rectangle is drawn with rectprops; default:
rectprops = dict(facecolor='red', edgecolor = 'black', alpha=0.2, fill=True)
The line is drawn with lineprops; default:
lineprops = dict(color='black', linestyle='-', linewidth = 2, alpha=0.5)
Use drawtype if you want the mouse to draw a line, a box or nothing between click and actual position by setting
drawtype = 'line'
,drawtype='box'
ordrawtype = 'none'
. Drawing a line would result in a line from vertex A to vertex C in a rectangle ABCD.spancoords is one of 'data' or 'pixels'. If 'data', minspanx and minspanx will be interpreted in the same coordinates as the x and y axis. If 'pixels', they are in pixels.
button is a list of integers indicating which mouse buttons should be used for rectangle selection. You can also specify a single integer if only a single button is desired. Default is None, which does not limit which button can be used.
- Note, typically:
- 1 = left mouse button 2 = center mouse button (scroll wheel) 3 = right mouse button
interactive will draw a set of handles and allow you interact with the widget after it is drawn.
state_modifier_keys are keyboard modifiers that affect the behavior of the widget.
The defaults are: dict(move=' ', clear='escape', square='shift', center='ctrl')
Keyboard modifiers, which: 'move': Move the existing shape. 'clear': Clear the current shape. 'square': Makes the shape square. 'center': Make the initial point the center of the shape. 'square' and 'center' can be combined.
-
class
matplotlib.widgets.
Lasso
(ax, xy, callback=None, useblit=True)[source]¶ Bases:
matplotlib.widgets.AxesWidget
Selection curve of an arbitrary shape.
The selected path can be used in conjunction with
contains_point
to select data points from an image.Unlike
LassoSelector
, this must be initialized with a starting pointxy
, and theLasso
events are destroyed upon release.Parameters: - ax
Axes
The parent axes for the widget.
- xy(float, float)
Coordinates of the start of the lasso.
- callbackcallable
Whenever the lasso is released, the
callback
function is called and passed the vertices of the selected path.
- ax
-
class
matplotlib.widgets.
LassoSelector
(ax, onselect=None, useblit=True, lineprops=None, button=None)[source]¶ Bases:
matplotlib.widgets._SelectorWidget
Selection curve of an arbitrary shape.
For the selector to remain responsive you must keep a reference to it.
The selected path can be used in conjunction with
contains_point
to select data points from an image.In contrast to
Lasso
,LassoSelector
is written with an interface similar toRectangleSelector
andSpanSelector
, and will continue to interact with the axes until disconnected.Example usage:
ax = subplot(111) ax.plot(x, y) def onselect(verts): print(verts) lasso = LassoSelector(ax, onselect)
Parameters: - ax
Axes
The parent axes for the widget.
- onselectfunction
Whenever the lasso is released, the onselect function is called and passed the vertices of the selected path.
- button
MouseButton
or list ofMouseButton
, optional The mouse buttons used for rectangle selection. Default is
None
, which corresponds to all buttons.
- ax
-
class
matplotlib.widgets.
LockDraw
[source]¶ Bases:
object
Some widgets, like the cursor, draw onto the canvas, and this is not desirable under all circumstances, like when the toolbar is in zoom-to-rect mode and drawing a rectangle. To avoid this, a widget can acquire a canvas' lock with
canvas.widgetlock(widget)
before drawing on the canvas; this will prevent other widgets from doing so at the same time (if they also try to acquire the lock first).
-
class
matplotlib.widgets.
MultiCursor
(canvas, axes, useblit=True, horizOn=False, vertOn=True, **lineprops)[source]¶ Bases:
matplotlib.widgets.Widget
Provide a vertical (default) and/or horizontal line cursor shared between multiple axes.
For the cursor to remain responsive you must keep a reference to it.
Example usage:
from matplotlib.widgets import MultiCursor import matplotlib.pyplot as plt import numpy as np fig, (ax1, ax2) = plt.subplots(nrows=2, sharex=True) t = np.arange(0.0, 2.0, 0.01) ax1.plot(t, np.sin(2*np.pi*t)) ax2.plot(t, np.sin(4*np.pi*t)) multi = MultiCursor(fig.canvas, (ax1, ax2), color='r', lw=1, horizOn=False, vertOn=True) plt.show()
-
class
matplotlib.widgets.
PolygonSelector
(ax, onselect, useblit=False, lineprops=None, markerprops=None, vertex_select_radius=15)[source]¶ Bases:
matplotlib.widgets._SelectorWidget
Select a polygon region of an axes.
Place vertices with each mouse click, and make the selection by completing the polygon (clicking on the first vertex). Hold the ctrl key and click and drag a vertex to reposition it (the ctrl key is not necessary if the polygon has already been completed). Hold the shift key and click and drag anywhere in the axes to move all vertices. Press the esc key to start a new polygon.
For the selector to remain responsive you must keep a reference to it.
Parameters: - ax
Axes
The parent axes for the widget.
- onselectfunction
When a polygon is completed or modified after completion, the
onselect
function is called and passed a list of the vertices as(xdata, ydata)
tuples.- useblitbool, optional
- linepropsdict, optional
The line for the sides of the polygon is drawn with the properties given by
lineprops
. The default isdict(color='k', linestyle='-', linewidth=2, alpha=0.5)
.- markerpropsdict, optional
The markers for the vertices of the polygon are drawn with the properties given by
markerprops
. The default isdict(marker='o', markersize=7, mec='k', mfc='k', alpha=0.5)
.- vertex_select_radiusfloat, optional
A vertex is selected (to complete the polygon or to move a vertex) if the mouse click is within
vertex_select_radius
pixels of the vertex. The default radius is 15 pixels.
Examples
-
property
verts
¶ The polygon vertices, as a list of
(x, y)
pairs.
- ax
-
class
matplotlib.widgets.
RadioButtons
(ax, labels, active=0, activecolor='blue')[source]¶ Bases:
matplotlib.widgets.AxesWidget
A GUI neutral radio button.
For the buttons to remain responsive you must keep a reference to this object.
Connect to the RadioButtons with the
on_clicked()
method.Attributes: Add radio buttons to an
Axes
.Parameters: - ax
Axes
The axes to add the buttons to.
- labelslist of str
The button labels.
- activeint
The index of the initially selected button.
- activecolorcolor
The color of the selected button.
- ax
-
class
matplotlib.widgets.
RectangleSelector
(ax, onselect, drawtype='box', minspanx=None, minspany=None, useblit=False, lineprops=None, rectprops=None, spancoords='data', button=None, maxdist=10, marker_props=None, interactive=False, state_modifier_keys=None)[source]¶ Bases:
matplotlib.widgets._SelectorWidget
Select a rectangular region of an axes.
For the cursor to remain responsive you must keep a reference to it.
Example usage:
import numpy as np import matplotlib.pyplot as plt from matplotlib.widgets import RectangleSelector def onselect(eclick, erelease): "eclick and erelease are matplotlib events at press and release." print('startposition: (%f, %f)' % (eclick.xdata, eclick.ydata)) print('endposition : (%f, %f)' % (erelease.xdata, erelease.ydata)) print('used button : ', eclick.button) def toggle_selector(event): print('Key pressed.') if event.key in ['Q', 'q'] and toggle_selector.RS.active: print('RectangleSelector deactivated.') toggle_selector.RS.set_active(False) if event.key in ['A', 'a'] and not toggle_selector.RS.active: print('RectangleSelector activated.') toggle_selector.RS.set_active(True) x = np.arange(100.) / 99 y = np.sin(x) fig, ax = plt.subplots() ax.plot(x, y) toggle_selector.RS = RectangleSelector(ax, onselect, drawtype='line') fig.canvas.mpl_connect('key_press_event', toggle_selector) plt.show()
Create a selector in ax. When a selection is made, clear the span and call onselect with:
onselect(pos_1, pos_2)
and clear the drawn box/line. The
pos_1
andpos_2
are arrays of length 2 containing the x- and y-coordinate.If minspanx is not None then events smaller than minspanx in x direction are ignored (it's the same for y).
The rectangle is drawn with rectprops; default:
rectprops = dict(facecolor='red', edgecolor = 'black', alpha=0.2, fill=True)
The line is drawn with lineprops; default:
lineprops = dict(color='black', linestyle='-', linewidth = 2, alpha=0.5)
Use drawtype if you want the mouse to draw a line, a box or nothing between click and actual position by setting
drawtype = 'line'
,drawtype='box'
ordrawtype = 'none'
. Drawing a line would result in a line from vertex A to vertex C in a rectangle ABCD.spancoords is one of 'data' or 'pixels'. If 'data', minspanx and minspanx will be interpreted in the same coordinates as the x and y axis. If 'pixels', they are in pixels.
button is a list of integers indicating which mouse buttons should be used for rectangle selection. You can also specify a single integer if only a single button is desired. Default is None, which does not limit which button can be used.
- Note, typically:
- 1 = left mouse button 2 = center mouse button (scroll wheel) 3 = right mouse button
interactive will draw a set of handles and allow you interact with the widget after it is drawn.
state_modifier_keys are keyboard modifiers that affect the behavior of the widget.
The defaults are: dict(move=' ', clear='escape', square='shift', center='ctrl')
Keyboard modifiers, which: 'move': Move the existing shape. 'clear': Clear the current shape. 'square': Makes the shape square. 'center': Make the initial point the center of the shape. 'square' and 'center' can be combined.
-
property
center
¶ Center of rectangle
-
property
corners
¶ Corners of rectangle from lower left, moving clockwise.
-
property
edge_centers
¶ Midpoint of rectangle edges from left, moving clockwise.
-
property
extents
¶ Return (xmin, xmax, ymin, ymax).
-
property
geometry
¶ Return an array of shape (2, 5) containing the x (
RectangleSelector.geometry[1, :]
) and y (RectangleSelector.geometry[0, :]
) coordinates of the four corners of the rectangle starting and ending in the top left corner.
-
class
matplotlib.widgets.
Slider
(ax, label, valmin, valmax, valinit=0.5, valfmt='%1.2f', closedmin=True, closedmax=True, slidermin=None, slidermax=None, dragging=True, valstep=None, orientation='horizontal', **kwargs)[source]¶ Bases:
matplotlib.widgets.AxesWidget
A slider representing a floating point range.
Create a slider from valmin to valmax in axes ax. For the slider to remain responsive you must maintain a reference to it. Call
on_changed()
to connect to the slider event.Attributes: - valfloat
Slider value.
Parameters: - axAxes
The Axes to put the slider in.
- labelstr
Slider label.
- valminfloat
The minimum value of the slider.
- valmaxfloat
The maximum value of the slider.
- valinitfloat, optional, default: 0.5
The slider initial position.
- valfmtstr, optional, default: "%1.2f"
Used to format the slider value, fprint format string.
- closedminbool, optional, default: True
Whether the slider interval is closed on the bottom.
- closedmaxbool, optional, default: True
Whether the slider interval is closed on the top.
- sliderminSlider, optional, default: None
Do not allow the current slider to have a value less than the value of the Slider
slidermin
.- slidermaxSlider, optional, default: None
Do not allow the current slider to have a value greater than the value of the Slider
slidermax
.- draggingbool, optional, default: True
If True the slider can be dragged by the mouse.
- valstepfloat, optional, default: None
If given, the slider will snap to multiples of
valstep
.- orientation{'horizontal', 'vertical'}, default: 'horizontal'
The orientation of the slider.
Notes
Additional kwargs are passed on to
self.poly
which is theRectangle
that draws the slider knob. See theRectangle
documentation for valid property names (facecolor
,edgecolor
,alpha
, etc.).-
disconnect
(self, cid)[source]¶ Remove the observer with connection id cid
Parameters: - cidint
Connection id of the observer to be removed
-
class
matplotlib.widgets.
SpanSelector
(ax, onselect, direction, minspan=None, useblit=False, rectprops=None, onmove_callback=None, span_stays=False, button=None)[source]¶ Bases:
matplotlib.widgets._SelectorWidget
Visually select a min/max range on a single axis and call a function with those values.
To guarantee that the selector remains responsive, keep a reference to it.
In order to turn off the SpanSelector, set
span_selector.active=False
. To turn it back on, setspan_selector.active=True
.Parameters: - ax
matplotlib.axes.Axes
object - onselectfunc(min, max), min/max are floats
- direction{"horizontal", "vertical"}
The direction along which to draw the span selector.
- minspanfloat, default is None
If selection is less than minspan, do not call onselect.
- useblitbool, default is False
If True, use the backend-dependent blitting features for faster canvas updates.
- rectpropsdict, default is None
Dictionary of
matplotlib.patches.Patch
properties.- onmove_callbackfunc(min, max), min/max are floats, default is None
Called on mouse move while the span is being selected.
- span_staysbool, default is False
If True, the span stays visible after the mouse is released.
- button
MouseButton
or list ofMouseButton
The mouse buttons which activate the span selector.
Examples
>>> import matplotlib.pyplot as plt >>> import matplotlib.widgets as mwidgets >>> fig, ax = plt.subplots() >>> ax.plot([1, 2, 3], [10, 50, 100]) >>> def onselect(vmin, vmax): ... print(vmin, vmax) >>> rectprops = dict(facecolor='blue', alpha=0.5) >>> span = mwidgets.SpanSelector(ax, onselect, 'horizontal', ... rectprops=rectprops) >>> fig.show()
See also: Span Selector
- ax
-
class
matplotlib.widgets.
SubplotTool
(targetfig, toolfig)[source]¶ Bases:
matplotlib.widgets.Widget
A tool to adjust the subplot params of a
matplotlib.figure.Figure
.Parameters:
-
class
matplotlib.widgets.
TextBox
(ax, label, initial='', color='.95', hovercolor='1', label_pad=0.01)[source]¶ Bases:
matplotlib.widgets.AxesWidget
A GUI neutral text input box.
For the text box to remain responsive you must keep a reference to it.
Call
on_text_change()
to be updated whenever the text changes.Call
on_submit()
to be updated whenever the user hits enter or leaves the text entry field.Attributes: - ax
The
matplotlib.axes.Axes
the button renders into.- label
A
matplotlib.text.Text
instance.- color
The color of the button when not hovering.
- hovercolor
The color of the button when hovering.
Parameters: - ax
Axes
The
Axes
instance the button will be placed into.- labelstr
Label for this text box.
- initialstr
Initial value in the text box.
- colorcolor
The color of the box.
- hovercolorcolor
The color of the box when the mouse is over it.
- label_padfloat
The distance between the label and the right side of the textbox.
-
on_submit
(self, func)[source]¶ When the user hits enter or leaves the submission box, call this func with event.
A connection id is returned which can be used to disconnect.
-
class
matplotlib.widgets.
ToolHandles
(ax, x, y, marker='o', marker_props=None, useblit=True)[source]¶ Bases:
object
Control handles for canvas tools.
Parameters: - ax
matplotlib.axes.Axes
Matplotlib axes where tool handles are displayed.
- x, y1D arrays
Coordinates of control handles.
- markerstr
Shape of marker used to display handle. See
matplotlib.pyplot.plot
.- marker_propsdict
Additional marker properties. See
matplotlib.lines.Line2D
.
-
property
x
¶
-
property
y
¶
- ax
-
class
matplotlib.widgets.
Widget
[source]¶ Bases:
object
Abstract base class for GUI neutral widgets
-
property
active
¶ Is the widget active?
-
drawon
= True¶
-
eventson
= True¶
-
property