Source code for edifice.extra.pyqtgraph_plot
import typing as tp
from edifice.base_components.base_components import CommandType, QtWidgetElement
# Import PySide6 or PyQt6 before importing pyqtgraph so that pyqtgraph detects the same
from edifice.qt import QT_VERSION
if QT_VERSION == "PyQt6" and not tp.TYPE_CHECKING:
pass
else:
pass
import pyqtgraph as pg
[docs]
class PyQtPlot(QtWidgetElement[pg.PlotWidget]):
"""
A **PyQtGraph**
`PlotWidget <https://pyqtgraph.readthedocs.io/en/latest/api_reference/widgets/plotwidget.html>`_.
Requires
`PyQtGraph <https://pyqtgraph.readthedocs.io/en/latest/>`_.
.. rubric:: Props
All **props** from :class:`edifice.QtWidgetElement` plus:
Args:
plot_fun:
Function which takes a **PyQtGraph**
`PlotItem <https://pyqtgraph.readthedocs.io/en/latest/api_reference/graphicsItems/plotitem.html>`_
and calls
`plot() <https://pyqtgraph.readthedocs.io/en/latest/api_reference/graphicsItems/plotitem.html#pyqtgraph.PlotItem.plot>`_.
Edifice will call
`clear() <https://pyqtgraph.readthedocs.io/en/latest/api_reference/graphicsItems/plotitem.html#pyqtgraph.PlotItem.clear>`_
before calling :code:`plot_fun`.
.. rubric:: Usage
.. important::
It’s important to import **edifice** before importing **pyqtgraph**, so that **pyqtgraph**
`detects the same PyQt6 or PySide6 <https://pyqtgraph.readthedocs.io/en/latest/getting_started/how_to_use.html#pyqt-and-pyside>`_
package used by **edifice**.
.. code-block:: python
import numpy as np
from edifice import View, component
from edifice.extra import PyQtPlot
import pyqtgraph as pg
@component
def Component(self):
def plot_fun(plot_item: pg.PlotItem):
xs = np.linspace(-10, 10, 100)
ys = np.sin(xs)
plot_item.plot(x=xs, y=ys)
PyQtPlot(plot_fun=plot_fun)
If you want a non-interactive plot that doesn’t respond to the mouse,
you can disable mouse interaction with the plot by setting properties
on the `PlotItem <https://pyqtgraph.readthedocs.io/en/latest/api_reference/graphicsItems/plotitem.html>`_.
.. code-block:: python
:caption: Disable mouse interaction
def plot_fun(plot_item: pg.PlotItem):
plot_item.setMouseEnabled(x=False, y=False)
plot_item.hideButtons()
...
A more complete way to disable mouse interaction is to set the
:code:`PlotWidget` to be transparent for mouse events.
.. code-block:: python
:caption: Disable mouse interaction
def plot_fun(plot_item: pg.PlotItem):
cast(
pg.PlotWidget, plot_item.getViewWidget()
).setAttribute(PySide6.QtCore.Qt.WidgetAttribute.WA_TransparentForMouseEvents)
"""
[docs]
def __init__(self, plot_fun: tp.Callable[[pg.PlotItem], None], **kwargs):
super().__init__(**kwargs)
self._register_props(
{
"plot_fun": plot_fun,
},
)
def _qt_update_commands(self, children, newprops):
if self.underlying is None:
self.underlying = pg.PlotWidget()
commands = super()._qt_update_commands_super(children, newprops, self.underlying)
if "plot_fun" in newprops:
plot_fun = tp.cast(tp.Callable[[pg.PlotItem], None], self.props.plot_fun)
plot_widget = tp.cast(pg.PlotWidget, self.underlying)
plot_item = tp.cast(pg.PlotItem, plot_widget.getPlotItem())
def _update_plot():
plot_item.clear()
plot_fun(plot_item)
commands.append(CommandType(_update_plot))
return commands