merged with inp
This commit is contained in:
commit
dbc8fe423b
37
examples/PanningPlot.py
Normal file
37
examples/PanningPlot.py
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
"""
|
||||||
|
Shows use of PlotWidget to display panning data
|
||||||
|
|
||||||
|
"""
|
||||||
|
import initExample ## Add path to library (just for examples; you do not need this)
|
||||||
|
|
||||||
|
import pyqtgraph as pg
|
||||||
|
from pyqtgraph.Qt import QtCore, QtGui
|
||||||
|
import numpy as np
|
||||||
|
|
||||||
|
win = pg.GraphicsWindow()
|
||||||
|
win.setWindowTitle('pyqtgraph example: PanningPlot')
|
||||||
|
|
||||||
|
plt = win.addPlot()
|
||||||
|
#plt.setAutoVisibleOnly(y=True)
|
||||||
|
curve = plt.plot()
|
||||||
|
|
||||||
|
data = []
|
||||||
|
count = 0
|
||||||
|
def update():
|
||||||
|
global data, curve, count
|
||||||
|
data.append(np.random.normal(size=10) + np.sin(count * 0.1) * 5)
|
||||||
|
if len(data) > 100:
|
||||||
|
data.pop(0)
|
||||||
|
curve.setData(np.hstack(data))
|
||||||
|
count += 1
|
||||||
|
|
||||||
|
timer = QtCore.QTimer()
|
||||||
|
timer.timeout.connect(update)
|
||||||
|
timer.start(50)
|
||||||
|
|
||||||
|
## Start Qt event loop unless running in interactive mode or using pyside.
|
||||||
|
if __name__ == '__main__':
|
||||||
|
import sys
|
||||||
|
if (sys.flags.interactive != 1) or not hasattr(QtCore, 'PYQT_VERSION'):
|
||||||
|
QtGui.QApplication.instance().exec_()
|
@ -380,7 +380,7 @@ class AxisItem(GraphicsWidget):
|
|||||||
This method is called whenever the axis needs to be redrawn and is a
|
This method is called whenever the axis needs to be redrawn and is a
|
||||||
good method to override in subclasses that require control over tick locations.
|
good method to override in subclasses that require control over tick locations.
|
||||||
|
|
||||||
The return value must be a list of three tuples::
|
The return value must be a list of tuples, one for each set of ticks::
|
||||||
|
|
||||||
[
|
[
|
||||||
(major tick spacing, offset),
|
(major tick spacing, offset),
|
||||||
|
@ -950,7 +950,8 @@ class ViewBox(GraphicsWidget):
|
|||||||
dif = dif * -1
|
dif = dif * -1
|
||||||
|
|
||||||
## Ignore axes if mouse is disabled
|
## Ignore axes if mouse is disabled
|
||||||
mask = np.array(self.state['mouseEnabled'], dtype=np.float)
|
mouseEnabled = np.array(self.state['mouseEnabled'], dtype=np.float)
|
||||||
|
mask = mouseEnabled.copy()
|
||||||
if axis is not None:
|
if axis is not None:
|
||||||
mask[1-axis] = 0.0
|
mask[1-axis] = 0.0
|
||||||
|
|
||||||
@ -990,8 +991,8 @@ class ViewBox(GraphicsWidget):
|
|||||||
tr = self.childGroup.transform()
|
tr = self.childGroup.transform()
|
||||||
tr = fn.invertQTransform(tr)
|
tr = fn.invertQTransform(tr)
|
||||||
|
|
||||||
x = s[0] if mask[0] == 1 else None
|
x = s[0] if mouseEnabled[0] == 1 else None
|
||||||
y = s[1] if mask[1] == 1 else None
|
y = s[1] if mouseEnabled[1] == 1 else None
|
||||||
|
|
||||||
center = Point(tr.map(ev.buttonDownPos(QtCore.Qt.RightButton)))
|
center = Point(tr.map(ev.buttonDownPos(QtCore.Qt.RightButton)))
|
||||||
self.scaleBy(x=x, y=y, center=center)
|
self.scaleBy(x=x, y=y, center=center)
|
||||||
@ -1321,6 +1322,8 @@ class ViewBox(GraphicsWidget):
|
|||||||
k.destroyed.disconnect()
|
k.destroyed.disconnect()
|
||||||
except RuntimeError: ## signal is already disconnected.
|
except RuntimeError: ## signal is already disconnected.
|
||||||
pass
|
pass
|
||||||
|
except TypeError: ## view has already been deleted (?)
|
||||||
|
pass
|
||||||
|
|
||||||
def locate(self, item, timeout=3.0, children=False):
|
def locate(self, item, timeout=3.0, children=False):
|
||||||
"""
|
"""
|
||||||
|
@ -79,7 +79,11 @@ class Process(RemoteEventHandler):
|
|||||||
sysPath = sys.path if copySysPath else None
|
sysPath = sys.path if copySysPath else None
|
||||||
bootstrap = os.path.abspath(os.path.join(os.path.dirname(__file__), 'bootstrap.py'))
|
bootstrap = os.path.abspath(os.path.join(os.path.dirname(__file__), 'bootstrap.py'))
|
||||||
self.debugMsg('Starting child process (%s %s)' % (executable, bootstrap))
|
self.debugMsg('Starting child process (%s %s)' % (executable, bootstrap))
|
||||||
self.proc = subprocess.Popen((executable, bootstrap), stdin=subprocess.PIPE)
|
|
||||||
|
## note: we need all three streams to have their own PIPE due to this bug:
|
||||||
|
## http://bugs.python.org/issue3905
|
||||||
|
self.proc = subprocess.Popen((executable, bootstrap), stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
||||||
|
|
||||||
targetStr = pickle.dumps(target) ## double-pickle target so that child has a chance to
|
targetStr = pickle.dumps(target) ## double-pickle target so that child has a chance to
|
||||||
## set its sys.path properly before unpickling the target
|
## set its sys.path properly before unpickling the target
|
||||||
pid = os.getpid() # we must send pid to child because windows does not have getppid
|
pid = os.getpid() # we must send pid to child because windows does not have getppid
|
||||||
|
@ -181,6 +181,7 @@ class GraphicsView(QtGui.QGraphicsView):
|
|||||||
if self.centralWidget is not None:
|
if self.centralWidget is not None:
|
||||||
self.scene().removeItem(self.centralWidget)
|
self.scene().removeItem(self.centralWidget)
|
||||||
self.centralWidget = item
|
self.centralWidget = item
|
||||||
|
if item is not None:
|
||||||
self.sceneObj.addItem(item)
|
self.sceneObj.addItem(item)
|
||||||
self.resizeEvent(None)
|
self.resizeEvent(None)
|
||||||
|
|
||||||
@ -272,6 +273,7 @@ class GraphicsView(QtGui.QGraphicsView):
|
|||||||
scaleChanged = True
|
scaleChanged = True
|
||||||
self.range = newRect
|
self.range = newRect
|
||||||
#print "New Range:", self.range
|
#print "New Range:", self.range
|
||||||
|
if self.centralWidget is not None:
|
||||||
self.centralWidget.setGeometry(self.range)
|
self.centralWidget.setGeometry(self.range)
|
||||||
self.updateMatrix(propagate)
|
self.updateMatrix(propagate)
|
||||||
if scaleChanged:
|
if scaleChanged:
|
||||||
|
Loading…
Reference in New Issue
Block a user