2020-06-23 19:59:04 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
2020-06-26 18:12:17 +02:00
|
|
|
Demonstrates very basic use of PColorMeshItem
|
2020-06-23 19:59:04 +02:00
|
|
|
"""
|
|
|
|
|
|
|
|
## Add path to library (just for examples; you do not need this)
|
|
|
|
import initExample
|
|
|
|
|
|
|
|
from pyqtgraph.Qt import QtCore, QtGui
|
|
|
|
import numpy as np
|
|
|
|
import pyqtgraph as pg
|
|
|
|
import pyqtgraph.ptime as ptime
|
|
|
|
|
2021-01-27 10:59:07 -08:00
|
|
|
app = pg.mkQApp("PColorMesh Example")
|
2020-06-23 19:59:04 +02:00
|
|
|
|
|
|
|
## Create window with GraphicsView widget
|
|
|
|
win = pg.GraphicsLayoutWidget()
|
|
|
|
win.show() ## show widget alone in its own window
|
|
|
|
win.setWindowTitle('pyqtgraph example: pColorMeshItem')
|
|
|
|
view = win.addViewBox()
|
|
|
|
|
|
|
|
|
|
|
|
## Create data
|
2020-06-28 14:49:20 +02:00
|
|
|
|
2020-06-28 15:05:29 +02:00
|
|
|
# To enhance the non-grid meshing, we randomize the polygon vertices per and
|
|
|
|
# certain amount
|
|
|
|
randomness = 5
|
|
|
|
|
|
|
|
# x and y being the vertices of the polygons, they share the same shape
|
2020-06-28 14:49:20 +02:00
|
|
|
# However the shape can be different in both dimension
|
|
|
|
xn = 50 # nb points along x
|
|
|
|
yn = 40 # nb points along y
|
2020-06-28 15:05:29 +02:00
|
|
|
|
|
|
|
|
|
|
|
x = np.repeat(np.arange(1, xn+1), yn).reshape(xn, yn)\
|
|
|
|
+ np.random.random((xn, yn))*randomness
|
|
|
|
y = np.tile(np.arange(1, yn+1), xn).reshape(xn, yn)\
|
|
|
|
+ np.random.random((xn, yn))*randomness
|
|
|
|
x.sort(axis=0)
|
|
|
|
y.sort(axis=0)
|
|
|
|
|
2020-06-28 14:49:20 +02:00
|
|
|
|
|
|
|
# z being the color of the polygons its shape must be decreased by one in each dimension
|
|
|
|
z = np.exp(-(x*xn)**2/1000)[:-1,:-1]
|
2020-06-23 19:59:04 +02:00
|
|
|
|
|
|
|
## Create image item
|
2020-10-12 12:45:13 +02:00
|
|
|
edgecolors = None
|
|
|
|
antialiasing = False
|
2020-06-28 14:50:44 +02:00
|
|
|
# edgecolors = {'color':'w', 'width':2} # May be uncommened to see edgecolor effect
|
2020-10-12 12:45:13 +02:00
|
|
|
# antialiasing = True # May be uncommened to see antialiasing effect
|
|
|
|
pcmi = pg.PColorMeshItem(edgecolors=edgecolors, antialiasing=antialiasing)
|
2020-06-23 19:59:04 +02:00
|
|
|
view.addItem(pcmi)
|
|
|
|
|
|
|
|
|
2020-06-28 14:49:20 +02:00
|
|
|
## Set the animation
|
|
|
|
fps = 25 # Frame per second of the animation
|
2020-06-23 19:59:04 +02:00
|
|
|
|
2020-06-28 14:49:20 +02:00
|
|
|
# Wave parameters
|
|
|
|
wave_amplitude = 3
|
|
|
|
wave_speed = 0.3
|
|
|
|
wave_length = 10
|
|
|
|
color_speed = 0.3
|
2020-06-23 19:59:04 +02:00
|
|
|
|
2021-03-01 13:45:00 +08:00
|
|
|
timer = QtCore.QTimer()
|
|
|
|
timer.setSingleShot(True)
|
|
|
|
# not using QTimer.singleShot() because of persistence on PyQt. see PR #1605
|
|
|
|
|
2020-06-28 14:49:20 +02:00
|
|
|
i=0
|
2020-06-23 19:59:04 +02:00
|
|
|
def updateData():
|
2020-06-28 14:49:20 +02:00
|
|
|
global i
|
2020-06-23 19:59:04 +02:00
|
|
|
|
2020-06-28 14:49:20 +02:00
|
|
|
## Display the new data set
|
|
|
|
new_x = x
|
|
|
|
new_y = y+wave_amplitude*np.cos(x/wave_length+i)
|
|
|
|
new_z = np.exp(-(x-np.cos(i*color_speed)*xn)**2/1000)[:-1,:-1]
|
|
|
|
pcmi.setData(new_x,
|
|
|
|
new_y,
|
|
|
|
new_z)
|
|
|
|
|
|
|
|
i += wave_speed
|
2021-03-01 13:45:00 +08:00
|
|
|
timer.start(1000//fps)
|
2020-06-23 19:59:04 +02:00
|
|
|
|
2021-03-01 13:45:00 +08:00
|
|
|
timer.timeout.connect(updateData)
|
2020-06-23 19:59:04 +02:00
|
|
|
updateData()
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2021-03-22 11:17:12 -07:00
|
|
|
pg.mkQApp().exec_()
|