2010-03-22 01:48:52 -04:00
|
|
|
# -*- coding: utf-8 -*-
|
2013-02-20 11:13:50 -05:00
|
|
|
"""
|
2021-02-25 16:14:34 -08:00
|
|
|
This example demonstrates the use of ImageView with 3-color image stacks.
|
|
|
|
ImageView is a high-level widget for displaying and analyzing 2D and 3D data.
|
|
|
|
ImageView provides:
|
2013-02-20 11:13:50 -05:00
|
|
|
|
|
|
|
1. A zoomable region (ViewBox) for displaying the image
|
|
|
|
2. A combination histogram and gradient editor (HistogramLUTItem) for
|
|
|
|
controlling the visual appearance of the image
|
|
|
|
3. A timeline for selecting the currently displayed frame (for 3D data only).
|
|
|
|
4. Tools for very basic analysis of image data (see ROI and Norm buttons)
|
|
|
|
|
|
|
|
"""
|
2010-03-22 02:21:56 -04:00
|
|
|
## Add path to library (just for examples; you do not need this)
|
2012-12-26 17:51:52 -05:00
|
|
|
import initExample
|
2011-04-05 10:35:50 -04:00
|
|
|
|
|
|
|
import numpy as np
|
2012-03-01 22:58:02 -05:00
|
|
|
from pyqtgraph.Qt import QtCore, QtGui
|
2011-04-05 10:35:50 -04:00
|
|
|
import pyqtgraph as pg
|
2010-03-22 01:48:52 -04:00
|
|
|
|
2016-08-31 15:14:25 -07:00
|
|
|
# Interpret image data as row-major instead of col-major
|
|
|
|
pg.setConfigOptions(imageAxisOrder='row-major')
|
2016-04-27 22:33:51 -07:00
|
|
|
|
2021-01-27 10:59:07 -08:00
|
|
|
app = pg.mkQApp("ImageView Example")
|
2010-03-22 02:21:56 -04:00
|
|
|
|
|
|
|
## Create window with ImageView widget
|
2010-03-22 01:48:52 -04:00
|
|
|
win = QtGui.QMainWindow()
|
2011-06-14 19:47:52 -04:00
|
|
|
win.resize(800,800)
|
2011-04-05 10:35:50 -04:00
|
|
|
imv = pg.ImageView()
|
2010-03-22 01:48:52 -04:00
|
|
|
win.setCentralWidget(imv)
|
|
|
|
win.show()
|
2013-02-24 23:09:03 -05:00
|
|
|
win.setWindowTitle('pyqtgraph example: ImageView')
|
2010-03-22 01:48:52 -04:00
|
|
|
|
2021-02-25 16:14:34 -08:00
|
|
|
## Create random 3D data set with time varying signals
|
|
|
|
dataRed = np.ones((100, 200, 200)) * np.linspace(90, 150, 100)[:, np.newaxis, np.newaxis]
|
|
|
|
dataRed += pg.gaussianFilter(np.random.normal(size=(200, 200)), (5, 5)) * 100
|
|
|
|
dataGrn = np.ones((100, 200, 200)) * np.linspace(90, 180, 100)[:, np.newaxis, np.newaxis]
|
|
|
|
dataGrn += pg.gaussianFilter(np.random.normal(size=(200, 200)), (5, 5)) * 100
|
|
|
|
dataBlu = np.ones((100, 200, 200)) * np.linspace(180, 90, 100)[:, np.newaxis, np.newaxis]
|
|
|
|
dataBlu += pg.gaussianFilter(np.random.normal(size=(200, 200)), (5, 5)) * 100
|
2010-07-24 14:29:09 -04:00
|
|
|
|
2021-02-25 16:14:34 -08:00
|
|
|
data = np.concatenate(
|
|
|
|
(dataRed[:, :, :, np.newaxis], dataGrn[:, :, :, np.newaxis], dataBlu[:, :, :, np.newaxis]), axis=3
|
|
|
|
)
|
2010-07-24 14:29:09 -04:00
|
|
|
|
2010-03-22 02:21:56 -04:00
|
|
|
|
2013-02-20 11:13:50 -05:00
|
|
|
## Display the data and assign each frame a time value from 1.0 to 3.0
|
2011-04-05 10:35:50 -04:00
|
|
|
imv.setImage(data, xvals=np.linspace(1., 3., data.shape[0]))
|
2010-03-22 02:21:56 -04:00
|
|
|
|
2016-02-15 16:58:57 -05:00
|
|
|
## Set a custom color map
|
2016-04-02 23:27:20 -07:00
|
|
|
colors = [
|
|
|
|
(0, 0, 0),
|
|
|
|
(45, 5, 61),
|
|
|
|
(84, 42, 55),
|
|
|
|
(150, 87, 60),
|
|
|
|
(208, 171, 141),
|
|
|
|
(255, 255, 255)
|
|
|
|
]
|
|
|
|
cmap = pg.ColorMap(pos=np.linspace(0.0, 1.0, 6), color=colors)
|
|
|
|
imv.setColorMap(cmap)
|
2016-02-15 16:58:57 -05:00
|
|
|
|
2021-02-25 16:14:34 -08:00
|
|
|
# Start up with an ROI
|
|
|
|
imv.ui.roiBtn.setChecked(True)
|
|
|
|
imv.roiClicked()
|
|
|
|
|
2011-04-05 10:35:50 -04:00
|
|
|
## Start Qt event loop unless running in interactive mode.
|
2012-12-05 00:25:45 -05:00
|
|
|
if __name__ == '__main__':
|
|
|
|
import sys
|
|
|
|
if (sys.flags.interactive != 1) or not hasattr(QtCore, 'PYQT_VERSION'):
|
|
|
|
QtGui.QApplication.instance().exec_()
|