pyqtgraph/examples/GLLinePlotItem.py

45 lines
1.0 KiB
Python
Raw Normal View History

2012-12-26 20:22:44 +00:00
# -*- coding: utf-8 -*-
2013-02-25 04:09:03 +00:00
"""
Demonstrate use of GLLinePlotItem to draw cross-sections of a surface.
"""
2012-12-26 20:22:44 +00:00
## Add path to library (just for examples; you do not need this)
import initExample
2012-12-26 20:22:44 +00:00
from pyqtgraph.Qt import QtCore, QtGui
import pyqtgraph.opengl as gl
import pyqtgraph as pg
import numpy as np
app = pg.mkQApp("GLLinePlotItem Example")
2012-12-26 20:22:44 +00:00
w = gl.GLViewWidget()
w.opts['distance'] = 40
w.show()
2013-02-25 04:09:03 +00:00
w.setWindowTitle('pyqtgraph example: GLLinePlotItem')
2012-12-26 20:22:44 +00:00
gx = gl.GLGridItem()
gx.rotate(90, 0, 1, 0)
gx.translate(-10, 0, 0)
w.addItem(gx)
gy = gl.GLGridItem()
gy.rotate(90, 1, 0, 0)
gy.translate(0, -10, 0)
w.addItem(gy)
gz = gl.GLGridItem()
gz.translate(0, 0, -10)
w.addItem(gz)
n = 51
y = np.linspace(-10,10,n)
x = np.linspace(-10,10,100)
for i in range(n):
yi = y[i]
d = np.hypot(x, yi)
2012-12-26 20:22:44 +00:00
z = 10 * np.cos(d) / (d+1)
pts = np.column_stack([x, np.full_like(x, yi), z])
plt = gl.GLLinePlotItem(pos=pts, color=pg.glColor((i,n*1.3)), width=(i+1)/10., antialias=True)
2012-12-26 20:22:44 +00:00
w.addItem(plt)
2012-12-26 20:22:44 +00:00
if __name__ == '__main__':
2021-05-13 21:28:22 +00:00
pg.exec()