本文整理匯總了Python中pyqtgraph.GraphicsWindow方法的典型用法代碼示例。如果您正苦於以下問題:Python pyqtgraph.GraphicsWindow方法的具體用法?Python pyqtgraph.GraphicsWindow怎麽用?Python pyqtgraph.GraphicsWindow使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類pyqtgraph
的用法示例。
在下文中一共展示了pyqtgraph.GraphicsWindow方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_plotscene
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def test_plotscene():
tempfilename = tempfile.NamedTemporaryFile(suffix='.svg').name
print("using %s as a temporary file" % tempfilename)
pg.setConfigOption('foreground', (0,0,0))
w = pg.GraphicsWindow()
w.show()
p1 = w.addPlot()
p2 = w.addPlot()
p1.plot([1,3,2,3,1,6,9,8,4,2,3,5,3], pen={'color':'k'})
p1.setXRange(0,5)
p2.plot([1,5,2,3,4,6,1,2,4,2,3,5,3], pen={'color':'k', 'cosmetic':False, 'width': 0.3})
app.processEvents()
app.processEvents()
ex = pg.exporters.SVGExporter(w.scene())
ex.export(fileName=tempfilename)
# clean up after the test is done
os.unlink(tempfilename)
示例2: init_viewbox
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def init_viewbox():
"""Helper function to init the ViewBox
"""
global win, vb
win = pg.GraphicsWindow()
win.ci.layout.setContentsMargins(0,0,0,0)
win.resize(200, 200)
win.show()
vb = win.addViewBox()
# set range before viewbox is shown
vb.setRange(xRange=[0, 10], yRange=[0, 10], padding=0)
# required to make mapFromView work properly.
qtest.qWaitForWindowShown(win)
g = pg.GridItem()
vb.addItem(g)
app.processEvents()
示例3: test_PlotCurveItem
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def test_PlotCurveItem():
p = pg.GraphicsWindow()
p.ci.layout.setContentsMargins(4, 4, 4, 4) # default margins vary by platform
v = p.addViewBox()
p.resize(200, 150)
data = np.array([1,4,2,3,np.inf,5,7,6,-np.inf,8,10,9,np.nan,-1,-2,0])
c = pg.PlotCurveItem(data)
v.addItem(c)
v.autoRange()
# Check auto-range works. Some platform differences may be expected..
checkRange = np.array([[-1.1457564053237301, 16.145756405323731], [-3.076811473165955, 11.076811473165955]])
assert np.allclose(v.viewRange(), checkRange)
assertImageApproved(p, 'plotcurveitem/connectall', "Plot curve with all points connected.")
c.setData(data, connect='pairs')
assertImageApproved(p, 'plotcurveitem/connectpairs', "Plot curve with pairs connected.")
c.setData(data, connect='finite')
assertImageApproved(p, 'plotcurveitem/connectfinite', "Plot curve with finite points connected.")
c.setData(data, connect=np.array([1,1,1,0,1,1,0,0,1,0,0,0,1,1,0,0]))
assertImageApproved(p, 'plotcurveitem/connectarray', "Plot curve with connection array.")
示例4: init_gui
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def init_gui(self):
#self.main_layout = QtWidgets.QVBoxLayout(self)
self.init_main_layout(orientation="vertical")
self.init_attribute_layout()
self.win = pg.GraphicsWindow(title="Expected signal")
self.plot_item = self.win.addPlot(title='Expected ' + self.module.name)
self.plot_item.showGrid(y=True, x=True, alpha=1.)
self.curve = self.plot_item.plot(pen='y')
self.curve_slope = self.plot_item.plot(pen=pg.mkPen('b', width=5))
self.symbol = self.plot_item.plot(pen='b', symbol='o')
self.main_layout.addWidget(self.win)
self.button_calibrate = QtWidgets.QPushButton('Calibrate')
self.main_layout.addWidget(self.button_calibrate)
self.button_calibrate.clicked.connect(lambda: self.module.calibrate())
self.input_calibrated()
示例5: test_GraphicsWindow
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def test_GraphicsWindow():
def mkobjs():
w = pg.GraphicsWindow()
p1 = w.addPlot()
v1 = w.addViewBox()
return mkrefs(w, p1, v1)
for i in range(5):
assert_alldead(mkobjs())
示例6: draw_net
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def draw_net(self):
pg.setConfigOptions(antialias=True)
self.w = pg.GraphicsWindow() # Create new window like matplotlib pyplot
self.w.resize(800, 600)
self.w.setWindowTitle('Overlay Network of the Team')
self.v = self.w.addViewBox() # Add ViewBox that would contain all the graphics i.e graph structure
self.v.setAspectLocked()
self.G = Graph() # Child class of pg.GraphItem that would contain all the nodes and edges
self.v.addItem(self.G)
self.color_map = {'peer': (169, 188, 245, 255), 'monitor': (
169, 245, 208, 255), 'malicious': (247, 129, 129, 255)}
示例7: __init__
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def __init__(self, parent=None, **kargs):
pg.GraphicsWindow.__init__(self, **kargs)
self.setParent(parent)
self.setWindowTitle('')
# Enable antialiasing for prettier plots
pg.setConfigOptions(antialias=True)
self.p6 = self.addPlot(title="")
self.curve = self.p6.plot(pen='r')
示例8: _make_widget
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def _make_widget(self):
"""
Sets the widget (here a QCheckbox)
:return:
"""
self.widget = pg.GraphicsWindow(title="Plot")
legend = getattr(self.module.__class__, self.attribute_name).legend
self.pw = self.widget.addPlot(title="%s vs. time (s)"%legend)
self.plot_start_time = self.time()
self.curves = {}
setattr(self.module.__class__, '_' + self.attribute_name + '_pw', self.pw)
示例9: __init__
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def __init__(self, title="plotwindow"):
self.win = pg.GraphicsWindow(title=title)
self.pw = self.win.addPlot()
self.curves = {}
self.win.show()
self.plot_start_time = time()
示例10: __init__
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def __init__(self, width=800, height=450, title=''):
# Create GUI window
self.app = QtGui.QApplication([])
self.win = pg.GraphicsWindow(title)
self.win.resize(width, height)
self.win.setWindowTitle(title)
# Create GUI layout
self.layout = QtGui.QVBoxLayout()
self.win.setLayout(self.layout)
示例11: init_gui
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def init_gui(self):
"""
Sets up the gui.
"""
self.ch_col = ('magenta', 'blue', 'green')
self.last_data = None
self.init_main_layout(orientation="vertical")
#self.main_layout = QtWidgets.QVBoxLayout()
self.module.__dict__['curve_name'] = 'pyrpl spectrum'
self.init_attribute_layout()
self.other_widget = OtherAttributesWidget(self)
self.attribute_layout.addWidget(self.other_widget)
self.iqmode_widget = IqModeAttributesWidget(self)
self.attribute_layout.addWidget(self.iqmode_widget)
self.baseband_widget = BasebandAttributesWidget(self)
self.attribute_layout.addWidget(self.baseband_widget)
self.button_layout = QtWidgets.QHBoxLayout()
self.setLayout(self.main_layout)
# self.setWindowTitle("Spec. An.")
#self.win = pg.GraphicsWindow(title="PSD")
#self.main_layout.addWidget(self.win)
self.win2 = DataWidget(title='Spectrum')
self.main_layout.addWidget(self.win2)
#self.plot_item = self.win.addPlot(title="PSD")
#self.curve = self.plot_item.plot(pen=self.ch_col[0][0])
#self.curve2 = self.plot_item.plot(pen=self.ch_col[1][0]) # input2
# spectrum in
# baseband
#self.curve_cross = self.plot_item.plot(pen=self.ch_col[2][0]) #
# curve for
super(SpecAnWidget, self).init_gui()
aws = self.attribute_widgets
aws['display_input1_baseband'].setStyleSheet("color: %s" %
self.ch_col[0])
aws['display_input2_baseband'].setStyleSheet("color: %s" %
self.ch_col[1])
aws['display_cross_amplitude'].setStyleSheet("color: %s" %
self.ch_col[2])
# Not sure why the stretch factors in button_layout are not good by
# default...
self.attribute_layout.addStretch(1)
self.update_baseband_visibility()
示例12: _qtg_plot_graph
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def _qtg_plot_graph(G, edges, vertex_size, title):
qtg, gl, QtGui = _import_qtg()
if G.coords.shape[1] == 2:
window = qtg.GraphicsWindow()
window.setWindowTitle(title)
view = window.addViewBox()
view.setAspectLocked()
if edges:
pen = tuple(np.array(G.plotting['edge_color']) * 255)
else:
pen = None
adj = _get_coords(G, edge_list=True)
g = qtg.GraphItem(pos=G.coords, adj=adj, pen=pen,
size=vertex_size/10)
view.addItem(g)
global _qtg_windows
_qtg_windows.append(window)
elif G.coords.shape[1] == 3:
if not QtGui.QApplication.instance():
QtGui.QApplication([]) # We want only one application.
widget = gl.GLViewWidget()
widget.opts['distance'] = 10
widget.show()
widget.setWindowTitle(title)
if edges:
x, y, z = _get_coords(G)
pos = np.stack((x, y, z), axis=1)
g = gl.GLLinePlotItem(pos=pos, mode='lines',
color=G.plotting['edge_color'])
widget.addItem(g)
gp = gl.GLScatterPlotItem(pos=G.coords, size=vertex_size/3,
color=G.plotting['vertex_color'])
widget.addItem(gp)
global _qtg_widgets
_qtg_widgets.append(widget)
示例13: _qtg_plot_signal
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def _qtg_plot_signal(G, signal, edges, vertex_size, limits, title):
qtg, gl, QtGui = _import_qtg()
if G.coords.shape[1] == 2:
window = qtg.GraphicsWindow(title)
view = window.addViewBox()
elif G.coords.shape[1] == 3:
if not QtGui.QApplication.instance():
QtGui.QApplication([]) # We want only one application.
widget = gl.GLViewWidget()
widget.opts['distance'] = 10
widget.show()
widget.setWindowTitle(title)
if edges:
if G.coords.shape[1] == 2:
adj = _get_coords(G, edge_list=True)
pen = tuple(np.array(G.plotting['edge_color']) * 255)
g = qtg.GraphItem(pos=G.coords, adj=adj, symbolBrush=None,
symbolPen=None, pen=pen)
view.addItem(g)
elif G.coords.shape[1] == 3:
x, y, z = _get_coords(G)
pos = np.stack((x, y, z), axis=1)
g = gl.GLLinePlotItem(pos=pos, mode='lines',
color=G.plotting['edge_color'])
widget.addItem(g)
pos = [1, 8, 24, 40, 56, 64]
color = np.array([[0, 0, 143, 255], [0, 0, 255, 255], [0, 255, 255, 255],
[255, 255, 0, 255], [255, 0, 0, 255], [128, 0, 0, 255]])
cmap = qtg.ColorMap(pos, color)
signal = 1 + 63 * (signal - limits[0]) / limits[1] - limits[0]
if G.coords.shape[1] == 2:
gp = qtg.ScatterPlotItem(G.coords[:, 0],
G.coords[:, 1],
size=vertex_size/10,
brush=cmap.map(signal, 'qcolor'))
view.addItem(gp)
if G.coords.shape[1] == 3:
gp = gl.GLScatterPlotItem(pos=G.coords,
size=vertex_size/3,
color=cmap.map(signal, 'float'))
widget.addItem(gp)
if G.coords.shape[1] == 2:
global _qtg_windows
_qtg_windows.append(window)
elif G.coords.shape[1] == 3:
global _qtg_widgets
_qtg_widgets.append(widget)
示例14: _plot_spectrogram
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import GraphicsWindow [as 別名]
def _plot_spectrogram(G, node_idx):
r"""Plot the graph's spectrogram.
Parameters
----------
node_idx : ndarray
Order to sort the nodes in the spectrogram.
By default, does not reorder the nodes.
Notes
-----
This function is only implemented for the pyqtgraph backend at the moment.
Examples
--------
>>> G = graphs.Ring(15)
>>> G.plot_spectrogram()
"""
from pygsp import features
qtg, _, _ = _import_qtg()
if not hasattr(G, 'spectr'):
features.compute_spectrogram(G)
M = G.spectr.shape[1]
spectr = G.spectr[node_idx, :] if node_idx is not None else G.spectr
spectr = np.ravel(spectr)
min_spec, max_spec = spectr.min(), spectr.max()
pos = np.array([0., 0.25, 0.5, 0.75, 1.])
color = [[20, 133, 212, 255], [53, 42, 135, 255], [48, 174, 170, 255],
[210, 184, 87, 255], [249, 251, 14, 255]]
color = np.array(color, dtype=np.ubyte)
cmap = qtg.ColorMap(pos, color)
spectr = (spectr.astype(float) - min_spec) / (max_spec - min_spec)
w = qtg.GraphicsWindow()
w.setWindowTitle("Spectrogram of {}".format(G.__repr__(limit=4)))
label = 'frequencies {}:{:.2f}:{:.2f}'.format(0, G.lmax/M, G.lmax)
v = w.addPlot(labels={'bottom': 'nodes',
'left': label})
v.setAspectLocked()
spi = qtg.ScatterPlotItem(np.repeat(np.arange(G.N), M),
np.ravel(np.tile(np.arange(M), (1, G.N))),
pxMode=False,
symbol='s',
size=1,
brush=cmap.map(spectr, 'qcolor'))
v.addItem(spi)
global _qtg_windows
_qtg_windows.append(w)