2020-06-28 08:51:34 -07:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
import pytest
|
|
|
|
import pyqtgraph as pg
|
|
|
|
from pyqtgraph.exporters import MatplotlibExporter
|
|
|
|
pytest.importorskip("matplotlib")
|
|
|
|
|
|
|
|
app = pg.mkQApp()
|
|
|
|
|
2021-01-15 21:08:21 -08:00
|
|
|
skip_qt6 = pytest.mark.skipif(
|
2021-06-20 10:51:44 +08:00
|
|
|
pg.Qt.QT_LIB in ["PySide6", "PyQt6"],
|
2021-01-15 21:08:21 -08:00
|
|
|
reason= (
|
|
|
|
"Matplotlib has no Qt6 support yet, "
|
|
|
|
"see https://github.com/matplotlib/matplotlib/pull/19255"
|
|
|
|
)
|
|
|
|
)
|
2020-06-28 08:51:34 -07:00
|
|
|
|
2021-01-15 21:08:21 -08:00
|
|
|
|
|
|
|
@skip_qt6
|
2020-06-28 08:51:34 -07:00
|
|
|
def test_MatplotlibExporter():
|
|
|
|
plt = pg.plot()
|
|
|
|
|
|
|
|
# curve item
|
|
|
|
plt.plot([0, 1, 2], [0, 1, 2])
|
|
|
|
# scatter item
|
|
|
|
plt.plot([0, 1, 2], [1, 2, 3], pen=None, symbolBrush='r')
|
|
|
|
# curve + scatter
|
|
|
|
plt.plot([0, 1, 2], [2, 3, 4], pen='k', symbolBrush='r')
|
|
|
|
|
|
|
|
exp = MatplotlibExporter(plt.getPlotItem())
|
|
|
|
exp.export()
|
|
|
|
|
2021-01-15 21:08:21 -08:00
|
|
|
@skip_qt6
|
2020-06-28 08:51:34 -07:00
|
|
|
def test_MatplotlibExporter_nonplotitem():
|
|
|
|
# attempting to export something other than a PlotItem raises an exception
|
|
|
|
plt = pg.plot()
|
|
|
|
plt.plot([0, 1, 2], [2, 3, 4])
|
|
|
|
exp = MatplotlibExporter(plt.getPlotItem().getViewBox())
|
|
|
|
with pytest.raises(Exception):
|
|
|
|
exp.export()
|
|
|
|
|
2021-01-15 21:08:21 -08:00
|
|
|
@skip_qt6
|
2020-06-28 08:51:34 -07:00
|
|
|
@pytest.mark.parametrize('scale', [1e10, 1e-9])
|
|
|
|
def test_MatplotlibExporter_siscale(scale):
|
|
|
|
# coarse test to verify that plot data is scaled before export when
|
|
|
|
# autoSIPrefix is in effect (so mpl doesn't add its own multiplier label)
|
|
|
|
plt = pg.plot([0, 1, 2], [(i+1)*scale for i in range(3)])
|
|
|
|
# set the label so autoSIPrefix works
|
|
|
|
plt.setLabel('left', 'magnitude')
|
|
|
|
exp = MatplotlibExporter(plt.getPlotItem())
|
|
|
|
exp.export()
|
|
|
|
|
|
|
|
mpw = MatplotlibExporter.windows[-1]
|
|
|
|
fig = mpw.getFigure()
|
|
|
|
ymin, ymax = fig.axes[0].get_ylim()
|
|
|
|
|
|
|
|
if scale < 1:
|
|
|
|
assert ymax > scale
|
|
|
|
else:
|
|
|
|
assert ymax < scale
|