From a5998a560c1b56868f7c40e436a4c7bccc7bb20f Mon Sep 17 00:00:00 2001 From: Antony Lee Date: Thu, 17 Feb 2022 22:41:28 +0100 Subject: [PATCH] Small cleanup to VertexSelector. Make the class picklable, by making `canvas` a property and using a picklable callback connect. Also some docstring fixes. --- lib/matplotlib/lines.py | 23 ++++++++++++----------- lib/matplotlib/tests/test_pickle.py | 6 ++++++ 2 files changed, 18 insertions(+), 11 deletions(-) diff --git a/lib/matplotlib/lines.py b/lib/matplotlib/lines.py index 35bebe92e57b..703307ee584a 100644 --- a/lib/matplotlib/lines.py +++ b/lib/matplotlib/lines.py @@ -1515,8 +1515,7 @@ class VertexSelector: Derived classes should override the `process_selected` method to do something with the picks. - Here is an example which highlights the selected verts with red - circles:: + Here is an example which highlights the selected verts with red circles:: import numpy as np import matplotlib.pyplot as plt @@ -1524,7 +1523,7 @@ class VertexSelector: class HighlightSelected(lines.VertexSelector): def __init__(self, line, fmt='ro', **kwargs): - lines.VertexSelector.__init__(self, line) + super().__init__(line) self.markers, = self.axes.plot([], [], fmt, **kwargs) def process_selected(self, ind, xs, ys): @@ -1537,27 +1536,29 @@ def process_selected(self, ind, xs, ys): selector = HighlightSelected(line) plt.show() - """ + def __init__(self, line): """ - Initialize the class with a `.Line2D`. The line should already be - added to an `~.axes.Axes` and should have the picker property set. + Parameters + ---------- + line : `.Line2D` + The line must already have been added to an `~.axes.Axes` and must + have its picker property set. """ if line.axes is None: raise RuntimeError('You must first add the line to the Axes') - if line.get_picker() is None: raise RuntimeError('You must first set the picker property ' 'of the line') - self.axes = line.axes self.line = line - self.canvas = self.axes.figure.canvas - self.cid = self.canvas.mpl_connect('pick_event', self.onpick) - + self.cid = self.canvas.callbacks._connect_picklable( + 'pick_event', self.onpick) self.ind = set() + canvas = property(lambda self: self.axes.figure.canvas) + def process_selected(self, ind, xs, ys): """ Default "do nothing" implementation of the `process_selected` method. diff --git a/lib/matplotlib/tests/test_pickle.py b/lib/matplotlib/tests/test_pickle.py index af24e4ac6fe7..0d0a5e597767 100644 --- a/lib/matplotlib/tests/test_pickle.py +++ b/lib/matplotlib/tests/test_pickle.py @@ -8,6 +8,7 @@ from matplotlib import cm from matplotlib.testing.decorators import check_figures_equal from matplotlib.dates import rrulewrapper +from matplotlib.lines import VertexSelector import matplotlib.pyplot as plt import matplotlib.transforms as mtransforms import matplotlib.figure as mfigure @@ -231,3 +232,8 @@ def test_dynamic_norm(): mpl.scale.LogitScale, mpl.colors.Normalize)() assert type(pickle.loads(pickle.dumps(logit_norm_instance))) \ == type(logit_norm_instance) + + +def test_vertexselector(): + line, = plt.plot([0, 1], picker=True) + pickle.loads(pickle.dumps(VertexSelector(line)))