.. DO NOT EDIT. .. THIS FILE WAS AUTOMATICALLY GENERATED BY SPHINX-GALLERY. .. TO MAKE CHANGES, EDIT THE SOURCE PYTHON FILE: .. "gallery/event_handling/legend_picking.py" .. LINE NUMBERS ARE GIVEN BELOW. .. only:: html .. meta:: :keywords: codex .. note:: :class: sphx-glr-download-link-note :ref:`Go to the end ` to download the full example code .. rst-class:: sphx-glr-example-title .. _sphx_glr_gallery_event_handling_legend_picking.py: ============== Legend picking ============== Enable picking on the legend to toggle the original line on and off .. note:: This example exercises the interactive capabilities of Matplotlib, and this will not appear in the static documentation. Please run this code on your machine to see the interactivity. You can copy and paste individual parts, or download the entire example using the link at the bottom of the page. .. GENERATED FROM PYTHON SOURCE LINES 16-64 .. image-sg:: /gallery/event_handling/images/sphx_glr_legend_picking_001.png :alt: Click on legend line to toggle line on/off :srcset: /gallery/event_handling/images/sphx_glr_legend_picking_001.png, /gallery/event_handling/images/sphx_glr_legend_picking_001_2_00x.png 2.00x :class: sphx-glr-single-img .. code-block:: Python import matplotlib.pyplot as plt import numpy as np t = np.linspace(0, 1) y1 = 2 * np.sin(2 * np.pi * t) y2 = 4 * np.sin(2 * np.pi * 2 * t) fig, ax = plt.subplots() ax.set_title('Click on legend line to toggle line on/off') (line1, ) = ax.plot(t, y1, lw=2, label='1 Hz') (line2, ) = ax.plot(t, y2, lw=2, label='2 Hz') leg = ax.legend(fancybox=True, shadow=True) lines = [line1, line2] map_legend_to_ax = {} # Will map legend lines to original lines. pickradius = 5 # Points (Pt). How close the click needs to be to trigger an event. for legend_line, ax_line in zip(leg.get_lines(), lines): legend_line.set_picker(pickradius) # Enable picking on the legend line. map_legend_to_ax[legend_line] = ax_line def on_pick(event): # On the pick event, find the original line corresponding to the legend # proxy line, and toggle its visibility. legend_line = event.artist # Do nothing if the source of the event is not a legend line. if legend_line not in map_legend_to_ax: return ax_line = map_legend_to_ax[legend_line] visible = not ax_line.get_visible() ax_line.set_visible(visible) # Change the alpha on the line in the legend, so we can see what lines # have been toggled. legend_line.set_alpha(1.0 if visible else 0.2) fig.canvas.draw() fig.canvas.mpl_connect('pick_event', on_pick) # Works even if the legend is draggable. This is independent from picking legend lines. leg.set_draggable(True) plt.show() .. _sphx_glr_download_gallery_event_handling_legend_picking.py: .. only:: html .. container:: sphx-glr-footer sphx-glr-footer-example .. container:: sphx-glr-download sphx-glr-download-jupyter :download:`Download Jupyter notebook: legend_picking.ipynb ` .. container:: sphx-glr-download sphx-glr-download-python :download:`Download Python source code: legend_picking.py ` .. only:: html .. rst-class:: sphx-glr-signature `Gallery generated by Sphinx-Gallery `_