2018-01-28 18:10:39 -05:00
|
|
|
from pyqtgraph.Qt import QtGui, QtCore
|
2014-10-25 13:01:10 -04:00
|
|
|
import pyqtgraph as pg
|
|
|
|
import numpy as np
|
|
|
|
|
|
|
|
|
|
|
|
def test_scatterplotitem():
|
2020-10-21 05:02:53 +02:00
|
|
|
app = pg.mkQApp()
|
|
|
|
|
2016-06-03 17:30:05 -07:00
|
|
|
plot = pg.PlotWidget()
|
2018-01-28 18:10:39 -05:00
|
|
|
# set view range equal to its bounding rect.
|
2016-06-03 17:30:05 -07:00
|
|
|
# This causes plots to look the same regardless of pxMode.
|
|
|
|
plot.setRange(rect=plot.boundingRect())
|
2018-01-28 18:10:39 -05:00
|
|
|
|
|
|
|
# test SymbolAtlas accepts custom symbol
|
2020-10-21 05:02:53 +02:00
|
|
|
s = pg.ScatterPlotItem(name="Scatter")
|
2018-01-28 18:10:39 -05:00
|
|
|
symbol = QtGui.QPainterPath()
|
|
|
|
symbol.addEllipse(QtCore.QRectF(-0.5, -0.5, 1, 1))
|
2020-10-21 05:02:53 +02:00
|
|
|
s.addPoints([{'pos': [0, 0], 'data': 1, 'symbol': symbol}])
|
|
|
|
|
|
|
|
assert s.name() == "Scatter"
|
2018-01-28 18:10:39 -05:00
|
|
|
|
2014-10-25 13:01:10 -04:00
|
|
|
for i, pxMode in enumerate([True, False]):
|
|
|
|
for j, useCache in enumerate([True, False]):
|
|
|
|
s = pg.ScatterPlotItem()
|
|
|
|
s.opts['useCache'] = useCache
|
|
|
|
plot.addItem(s)
|
2020-10-21 05:02:53 +02:00
|
|
|
s.setData(x=np.array([10, 40, 20, 30]) + i * 100,
|
|
|
|
y=np.array([40, 60, 10, 30]) + j * 100, pxMode=pxMode,
|
|
|
|
name="MoreScatter")
|
|
|
|
s.addPoints(x=np.array([60, 70]) + i * 100,
|
|
|
|
y=np.array([60, 70]) + j * 100, size=[20, 30])
|
2018-01-28 18:10:39 -05:00
|
|
|
|
2020-10-21 05:02:53 +02:00
|
|
|
assert s.name() == "MoreScatter"
|
2014-10-25 13:01:10 -04:00
|
|
|
# Test uniform spot updates
|
|
|
|
s.setSize(10)
|
|
|
|
s.setBrush('r')
|
|
|
|
s.setPen('g')
|
|
|
|
s.setSymbol('+')
|
|
|
|
app.processEvents()
|
2018-01-28 18:10:39 -05:00
|
|
|
|
2014-10-25 13:01:10 -04:00
|
|
|
# Test list spot updates
|
|
|
|
s.setSize([10] * 6)
|
|
|
|
s.setBrush([pg.mkBrush('r')] * 6)
|
|
|
|
s.setPen([pg.mkPen('g')] * 6)
|
|
|
|
s.setSymbol(['+'] * 6)
|
|
|
|
s.setPointData([s] * 6)
|
|
|
|
app.processEvents()
|
|
|
|
|
|
|
|
# Test array spot updates
|
|
|
|
s.setSize(np.array([10] * 6))
|
|
|
|
s.setBrush(np.array([pg.mkBrush('r')] * 6))
|
|
|
|
s.setPen(np.array([pg.mkPen('g')] * 6))
|
|
|
|
s.setSymbol(np.array(['+'] * 6))
|
|
|
|
s.setPointData(np.array([s] * 6))
|
|
|
|
app.processEvents()
|
|
|
|
|
|
|
|
# Test per-spot updates
|
|
|
|
spot = s.points()[0]
|
|
|
|
spot.setSize(20)
|
|
|
|
spot.setBrush('b')
|
|
|
|
spot.setPen('g')
|
|
|
|
spot.setSymbol('o')
|
|
|
|
spot.setData(None)
|
2014-10-25 14:24:15 -04:00
|
|
|
app.processEvents()
|
|
|
|
|
2021-06-06 09:31:16 -07:00
|
|
|
plot.close()
|
2014-10-25 14:24:15 -04:00
|
|
|
|
|
|
|
|
|
|
|
def test_init_spots():
|
2020-10-21 05:02:53 +02:00
|
|
|
app = pg.mkQApp()
|
2016-06-03 17:30:05 -07:00
|
|
|
plot = pg.PlotWidget()
|
2018-01-28 18:10:39 -05:00
|
|
|
# set view range equal to its bounding rect.
|
2016-06-03 17:30:05 -07:00
|
|
|
# This causes plots to look the same regardless of pxMode.
|
|
|
|
plot.setRange(rect=plot.boundingRect())
|
2014-10-25 14:24:15 -04:00
|
|
|
spots = [
|
|
|
|
{'x': 0, 'y': 1},
|
|
|
|
{'pos': (1, 2), 'pen': None, 'brush': None, 'data': 'zzz'},
|
|
|
|
]
|
|
|
|
s = pg.ScatterPlotItem(spots=spots)
|
2018-01-28 18:10:39 -05:00
|
|
|
|
2014-10-25 14:24:15 -04:00
|
|
|
# Check we can display without errors
|
|
|
|
plot.addItem(s)
|
|
|
|
app.processEvents()
|
|
|
|
plot.clear()
|
2018-01-28 18:10:39 -05:00
|
|
|
|
2014-10-25 14:24:15 -04:00
|
|
|
# check data is correct
|
|
|
|
spots = s.points()
|
2018-01-28 18:10:39 -05:00
|
|
|
|
2014-10-25 14:24:15 -04:00
|
|
|
defPen = pg.mkPen(pg.getConfigOption('foreground'))
|
|
|
|
|
|
|
|
assert spots[0].pos().x() == 0
|
|
|
|
assert spots[0].pos().y() == 1
|
|
|
|
assert spots[0].pen() == defPen
|
|
|
|
assert spots[0].data() is None
|
2018-01-28 18:10:39 -05:00
|
|
|
|
2014-10-25 14:24:15 -04:00
|
|
|
assert spots[1].pos().x() == 1
|
|
|
|
assert spots[1].pos().y() == 2
|
|
|
|
assert spots[1].pen() == pg.mkPen(None)
|
|
|
|
assert spots[1].brush() == pg.mkBrush(None)
|
|
|
|
assert spots[1].data() == 'zzz'
|
2021-05-28 07:39:00 -07:00
|
|
|
plot.close()
|