1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300
|
.. currentmodule:: matplotlib
.. _mpl-shell:
=====================
Interactive Figures
=====================
.. toctree::
When working with data, interactivity can be invaluable. The pan/zoom and
mouse-location tools built into the Matplotlib GUI windows are often sufficient, but
you can also use the event system to build customized data exploration tools.
Matplotlib ships with :ref:`backends <what-is-a-backend>` binding to
several GUI toolkits (Qt, Tk, Wx, GTK, macOS, JavaScript) and third party
packages provide bindings to `kivy
<https://github.com/kivy-garden/garden.matplotlib>`__ and `Jupyter Lab
<https://github.com/matplotlib/ipympl>`__. For the figures to be responsive to
mouse, keyboard, and paint events, the GUI event loop needs to be integrated
with an interactive prompt. We recommend using IPython (see :ref:`below <ipython-pylab>`).
The `.pyplot` module provides functions for explicitly creating figures
that include interactive tools, a toolbar, a tool-tip, and
:ref:`key bindings <key-event-handling>`:
`.pyplot.figure`
Creates a new empty `.figure.Figure` or selects an existing figure
`.pyplot.subplots`
Creates a new `.figure.Figure` and fills it with a grid of `.axes.Axes`
`.pyplot` has a notion of "The Current Figure" which can be accessed
through `.pyplot.gcf` and a notion of "The Current Axes" accessed
through `.pyplot.gca`. Almost all of the functions in `.pyplot` pass
through the current `.Figure` / `.axes.Axes` (or create one) as
appropriate.
Matplotlib keeps a reference to all of the open figures
created via `pyplot.figure` or `pyplot.subplots` so that the figures will not be garbage
collected. `.Figure`\s can be closed and deregistered from `.pyplot` individually via
`.pyplot.close`; all open `.Figure`\s can be closed via ``plt.close('all')``.
For more discussion of Matplotlib's event system and integrated event loops, please read:
.. toctree::
:maxdepth: 1
interactive_guide.rst
event_handling.rst
.. _ipython-pylab:
IPython integration
===================
We recommend using IPython for an interactive shell. In addition to
all of its features (improved tab-completion, magics, multiline editing, etc),
it also ensures that the GUI toolkit event loop is properly integrated
with the command line (see :ref:`cp_integration`).
In this example, we create and modify a figure via an IPython prompt.
The figure displays in a Qt5Agg GUI window. To configure the integration
and enable :ref:`interactive mode <controlling-interactive>` use the
``%matplotlib`` magic:
.. highlight:: ipython
::
In [1]: %matplotlib
Using matplotlib backend: Qt5Agg
In [2]: import matplotlib.pyplot as plt
Create a new figure window:
::
In [3]: fig, ax = plt.subplots()
Add a line plot of the data to the window:
::
In [4]: ln, = ax.plot(range(5))
Change the color of the line from blue to orange:
::
In [5]: ln.set_color('orange')
If you wish to disable automatic redrawing of the plot:
::
In [6]: plt.ioff()
If you wish to re-enable automatic redrawing of the plot:
::
In [7]: plt.ion()
In recent versions of ``Matplotlib`` and ``IPython``, it is
sufficient to import `matplotlib.pyplot` and call `.pyplot.ion`.
Using the ``%`` magic is guaranteed to work in all versions of Matplotlib and IPython.
.. highlight:: python
.. _controlling-interactive:
Interactive mode
================
.. autosummary::
:template: autosummary.rst
:nosignatures:
pyplot.ion
pyplot.ioff
pyplot.isinteractive
.. autosummary::
:template: autosummary.rst
:nosignatures:
pyplot.show
pyplot.pause
Interactive mode controls:
- whether created figures are automatically shown
- whether changes to artists automatically trigger re-drawing existing figures
- when `.pyplot.show()` returns if given no arguments: immediately, or after all of the figures have been closed
If in interactive mode:
- newly created figures will be displayed immediately
- figures will automatically redraw when elements are changed
- `pyplot.show()` displays the figures and immediately returns
If not in interactive mode:
- newly created figures and changes to figures are not displayed until
* `.pyplot.show()` is called
* `.pyplot.pause()` is called
* `.FigureCanvasBase.flush_events()` is called
- `pyplot.show()` runs the GUI event loop and does not return until all the plot windows are closed
If you are in non-interactive mode (or created figures while in
non-interactive mode) you may need to explicitly call `.pyplot.show`
to display the windows on your screen. If you only want to run the
GUI event loop for a fixed amount of time, you can use `.pyplot.pause`.
This will block the progress of your code as if you had called
`time.sleep`, ensure the current window is shown and re-drawn if needed,
and run the GUI event loop for the specified period of time.
The GUI event loop being integrated with your command prompt and
the figures being in interactive mode are independent of each other.
If you use `pyplot.ion` but have not arranged for the event loop integration,
your figures will appear but will not be interactive while the prompt is waiting for input.
You will not be able to pan/zoom and the figure may not even render
(the window might appear black, transparent, or as a snapshot of the
desktop under it). Conversely, if you configure the event loop
integration, displayed figures will be responsive while waiting for input
at the prompt, regardless of pyplot's "interactive mode".
No matter what combination of interactive mode setting and event loop integration,
figures will be responsive if you use ``pyplot.show(block=True)``, `.pyplot.pause`, or run
the GUI main loop in some other way.
.. warning::
Using `.figure.Figure.show` it is possible to display a figure on
the screen without starting the event loop and without being in
interactive mode. This may work (depending on the GUI toolkit) but
will likely result in a non-responsive figure.
.. _navigation-toolbar:
Default UI
==========
The windows created by :mod:`~.pyplot` have an interactive toolbar with navigation
buttons and a readout of the data values the cursor is pointing at. A number of
helpful keybindings are registered by default.
.. _key-event-handling:
Navigation Keyboard Shortcuts
-----------------------------
The following table holds all the default keys, which can be
overwritten by use of your :ref:`matplotlibrc
<sphx_glr_tutorials_introductory_customizing.py>`.
================================== ===============================
Command Default key binding and rcParam
================================== ===============================
Home/Reset :rc:`keymap.home`
Back :rc:`keymap.back`
Forward :rc:`keymap.forward`
Pan/Zoom :rc:`keymap.pan`
Zoom-to-rect :rc:`keymap.zoom`
Save :rc:`keymap.save`
Toggle fullscreen :rc:`keymap.fullscreen`
Toggle major grids :rc:`keymap.grid`
Toggle minor grids :rc:`keymap.grid_minor`
Toggle x axis scale (log/linear) :rc:`keymap.xscale`
Toggle y axis scale (log/linear) :rc:`keymap.yscale`
Close Figure :rc:`keymap.quit`
Constrain pan/zoom to x axis hold **x** when panning/zooming with mouse
Constrain pan/zoom to y axis hold **y** when panning/zooming with mouse
Preserve aspect ratio hold **CONTROL** when panning/zooming with mouse
================================== ===============================
.. _other-shells:
Other Python prompts
====================
Interactive mode works in the default Python prompt:
.. sourcecode:: pycon
>>> import matplotlib.pyplot as plt
>>> plt.ion()
>>>
however this does not ensure that the event hook is properly installed
and your figures may not be responsive. Please consult the
documentation of your GUI toolkit for details.
Jupyter Notebooks / Lab
-----------------------
.. note::
To get the interactive functionality described here, you must be
using an interactive backend. The default backend in notebooks,
the inline backend, is not. `~ipykernel.pylab.backend_inline`
renders the figure once and inserts a static image into the
notebook when the cell is executed. Because the images are static, they
can not be panned / zoomed, take user input, or be updated from other
cells.
To get interactive figures in the 'classic' notebook or Jupyter lab,
use the `ipympl <https://github.com/matplotlib/ipympl>`__ backend
(must be installed separately) which uses the **ipywidget** framework.
If ``ipympl`` is installed use the magic:
.. sourcecode:: ipython
%matplotlib widget
to select and enable it.
If you only need to use the classic notebook, you can use
.. sourcecode:: ipython
%matplotlib notebook
which uses the `.backend_nbagg` backend provided by Matplotlib;
however, nbagg does not work in Jupyter Lab.
GUIs + Jupyter
~~~~~~~~~~~~~~
You can also use one of the non-``ipympl`` GUI backends in a Jupyter Notebook.
If you are running your Jupyter kernel locally, the GUI window will spawn on
your desktop adjacent to your web browser. If you run your notebook on a remote server,
the kernel will try to open the GUI window on the remote computer. Unless you have
arranged to forward the xserver back to your desktop, you will not be able to
see or interact with the window. It may also raise an exception.
PyCharm, Spyder, and VSCode
---------------------------
Many IDEs have built-in integration with Matplotlib, please consult their
documentation for configuration details.
|