code cleanup

This commit is contained in:
Luke Campagnola 2017-09-13 21:01:38 -07:00
parent 1f77433755
commit e88e3a4232
2 changed files with 3 additions and 188 deletions

View File

@ -32,7 +32,6 @@ class Canvas(QtGui.QWidget):
QtGui.QWidget.__init__(self, parent) QtGui.QWidget.__init__(self, parent)
self.ui = Ui_Form() self.ui = Ui_Form()
self.ui.setupUi(self) self.ui.setupUi(self)
#self.view = self.ui.view
self.view = ViewBox() self.view = ViewBox()
self.ui.view.setCentralItem(self.view) self.ui.view.setCentralItem(self.view)
self.itemList = self.ui.itemList self.itemList = self.ui.itemList
@ -49,9 +48,7 @@ class Canvas(QtGui.QWidget):
self.redirect = None ## which canvas to redirect items to self.redirect = None ## which canvas to redirect items to
self.items = [] self.items = []
#self.view.enableMouse()
self.view.setAspectLocked(True) self.view.setAspectLocked(True)
#self.view.invertY()
grid = GridItem() grid = GridItem()
self.grid = CanvasItem(grid, name='Grid', movable=False) self.grid = CanvasItem(grid, name='Grid', movable=False)
@ -69,8 +66,6 @@ class Canvas(QtGui.QWidget):
self.ui.itemList.sigItemMoved.connect(self.treeItemMoved) self.ui.itemList.sigItemMoved.connect(self.treeItemMoved)
self.ui.itemList.itemSelectionChanged.connect(self.treeItemSelected) self.ui.itemList.itemSelectionChanged.connect(self.treeItemSelected)
self.ui.autoRangeBtn.clicked.connect(self.autoRange) self.ui.autoRangeBtn.clicked.connect(self.autoRange)
#self.ui.storeSvgBtn.clicked.connect(self.storeSvg)
#self.ui.storePngBtn.clicked.connect(self.storePng)
self.ui.redirectCheck.toggled.connect(self.updateRedirect) self.ui.redirectCheck.toggled.connect(self.updateRedirect)
self.ui.redirectCombo.currentIndexChanged.connect(self.updateRedirect) self.ui.redirectCombo.currentIndexChanged.connect(self.updateRedirect)
self.multiSelectBox.sigRegionChanged.connect(self.multiSelectBoxChanged) self.multiSelectBox.sigRegionChanged.connect(self.multiSelectBoxChanged)
@ -88,22 +83,12 @@ class Canvas(QtGui.QWidget):
self.ui.redirectCombo.setHostName(self.registeredName) self.ui.redirectCombo.setHostName(self.registeredName)
self.menu = QtGui.QMenu() self.menu = QtGui.QMenu()
#self.menu.setTitle("Image")
remAct = QtGui.QAction("Remove item", self.menu) remAct = QtGui.QAction("Remove item", self.menu)
remAct.triggered.connect(self.removeClicked) remAct.triggered.connect(self.removeClicked)
self.menu.addAction(remAct) self.menu.addAction(remAct)
self.menu.remAct = remAct self.menu.remAct = remAct
self.ui.itemList.contextMenuEvent = self.itemListContextMenuEvent self.ui.itemList.contextMenuEvent = self.itemListContextMenuEvent
#def storeSvg(self):
#from pyqtgraph.GraphicsScene.exportDialog import ExportDialog
#ex = ExportDialog(self.ui.view)
#ex.show()
#def storePng(self):
#self.ui.view.writeImage()
def splitterMoved(self): def splitterMoved(self):
self.resizeEvent() self.resizeEvent()
@ -136,7 +121,6 @@ class Canvas(QtGui.QWidget):
s2 = self.width()-s s2 = self.width()-s
self.ui.splitter.setSizes([s2, s]) self.ui.splitter.setSizes([s2, s])
def updateRedirect(self, *args): def updateRedirect(self, *args):
### Decide whether/where to redirect items and make it so ### Decide whether/where to redirect items and make it so
cname = str(self.ui.redirectCombo.currentText()) cname = str(self.ui.redirectCombo.currentText())
@ -155,7 +139,6 @@ class Canvas(QtGui.QWidget):
else: else:
self.redirectItems(redirect) self.redirectItems(redirect)
def redirectItems(self, canvas): def redirectItems(self, canvas):
for i in self.items: for i in self.items:
if i is self.grid: if i is self.grid:
@ -172,11 +155,8 @@ class Canvas(QtGui.QWidget):
parent.removeChild(li) parent.removeChild(li)
canvas.addItem(i) canvas.addItem(i)
def reclaimItems(self): def reclaimItems(self):
items = self.items items = self.items
#self.items = {'Grid': items['Grid']}
#del items['Grid']
self.items = [self.grid] self.items = [self.grid]
items.remove(self.grid) items.remove(self.grid)
@ -185,9 +165,6 @@ class Canvas(QtGui.QWidget):
self.addItem(i) self.addItem(i)
def treeItemChanged(self, item, col): def treeItemChanged(self, item, col):
#gi = self.items.get(item.name, None)
#if gi is None:
#return
try: try:
citem = item.canvasItem() citem = item.canvasItem()
except AttributeError: except AttributeError:
@ -203,25 +180,16 @@ class Canvas(QtGui.QWidget):
def treeItemSelected(self): def treeItemSelected(self):
sel = self.selectedItems() sel = self.selectedItems()
#sel = []
#for listItem in self.itemList.selectedItems():
#if hasattr(listItem, 'canvasItem') and listItem.canvasItem is not None:
#sel.append(listItem.canvasItem)
#sel = [self.items[item.name] for item in sel]
if len(sel) == 0: if len(sel) == 0:
#self.selectWidget.hide()
return return
multi = len(sel) > 1 multi = len(sel) > 1
for i in self.items: for i in self.items:
#i.ctrlWidget().hide()
## updated the selected state of every item ## updated the selected state of every item
i.selectionChanged(i in sel, multi) i.selectionChanged(i in sel, multi)
if len(sel)==1: if len(sel)==1:
#item = sel[0]
#item.ctrlWidget().show()
self.multiSelectBox.hide() self.multiSelectBox.hide()
self.ui.mirrorSelectionBtn.hide() self.ui.mirrorSelectionBtn.hide()
self.ui.reflectSelectionBtn.hide() self.ui.reflectSelectionBtn.hide()
@ -229,14 +197,6 @@ class Canvas(QtGui.QWidget):
elif len(sel) > 1: elif len(sel) > 1:
self.showMultiSelectBox() self.showMultiSelectBox()
#if item.isMovable():
#self.selectBox.setPos(item.item.pos())
#self.selectBox.setSize(item.item.sceneBoundingRect().size())
#self.selectBox.show()
#else:
#self.selectBox.hide()
#self.emit(QtCore.SIGNAL('itemSelected'), self, item)
self.sigSelectionChanged.emit(self, sel) self.sigSelectionChanged.emit(self, sel)
def selectedItems(self): def selectedItems(self):
@ -245,20 +205,10 @@ class Canvas(QtGui.QWidget):
""" """
return [item.canvasItem() for item in self.itemList.selectedItems() if item.canvasItem() is not None] return [item.canvasItem() for item in self.itemList.selectedItems() if item.canvasItem() is not None]
#def selectedItem(self):
#sel = self.itemList.selectedItems()
#if sel is None or len(sel) < 1:
#return
#return self.items.get(sel[0].name, None)
def selectItem(self, item): def selectItem(self, item):
li = item.listItem li = item.listItem
#li = self.getListItem(item.name())
#print "select", li
self.itemList.setCurrentItem(li) self.itemList.setCurrentItem(li)
def showMultiSelectBox(self): def showMultiSelectBox(self):
## Get list of selected canvas items ## Get list of selected canvas items
items = self.selectedItems() items = self.selectedItems()
@ -281,7 +231,6 @@ class Canvas(QtGui.QWidget):
self.ui.mirrorSelectionBtn.show() self.ui.mirrorSelectionBtn.show()
self.ui.reflectSelectionBtn.show() self.ui.reflectSelectionBtn.show()
self.ui.resetTransformsBtn.show() self.ui.resetTransformsBtn.show()
#self.multiSelectBoxBase = self.multiSelectBox.getState().copy()
def mirrorSelectionClicked(self): def mirrorSelectionClicked(self):
for ci in self.selectedItems(): for ci in self.selectedItems():
@ -312,7 +261,6 @@ class Canvas(QtGui.QWidget):
ci.setTemporaryTransform(transform) ci.setTemporaryTransform(transform)
ci.sigTransformChanged.emit(ci) ci.sigTransformChanged.emit(ci)
def addGraphicsItem(self, item, **opts): def addGraphicsItem(self, item, **opts):
"""Add a new GraphicsItem to the scene at pos. """Add a new GraphicsItem to the scene at pos.
Common options are name, pos, scale, and z Common options are name, pos, scale, and z
@ -322,13 +270,11 @@ class Canvas(QtGui.QWidget):
self.addItem(citem) self.addItem(citem)
return citem return citem
def addGroup(self, name, **kargs): def addGroup(self, name, **kargs):
group = GroupCanvasItem(name=name) group = GroupCanvasItem(name=name)
self.addItem(group, **kargs) self.addItem(group, **kargs)
return group return group
def addItem(self, citem): def addItem(self, citem):
""" """
Add an item to the canvas. Add an item to the canvas.
@ -363,7 +309,6 @@ class Canvas(QtGui.QWidget):
#name = newname #name = newname
## find parent and add item to tree ## find parent and add item to tree
#currentNode = self.itemList.invisibleRootItem()
insertLocation = 0 insertLocation = 0
#print "Inserting node:", name #print "Inserting node:", name
@ -413,11 +358,7 @@ class Canvas(QtGui.QWidget):
node.setCheckState(0, QtCore.Qt.Unchecked) node.setCheckState(0, QtCore.Qt.Unchecked)
node.name = name node.name = name
#if citem.opts['parent'] != None:
## insertLocation is incorrect in this case
parent.insertChild(insertLocation, node) parent.insertChild(insertLocation, node)
#else:
#root.insertChild(insertLocation, node)
citem.name = name citem.name = name
citem.listItem = node citem.listItem = node
@ -435,36 +376,6 @@ class Canvas(QtGui.QWidget):
if len(self.items) == 2: if len(self.items) == 2:
self.autoRange() self.autoRange()
#for n in name:
#nextnode = None
#for x in range(currentNode.childCount()):
#ch = currentNode.child(x)
#if hasattr(ch, 'name'): ## check Z-value of current item to determine insert location
#zval = ch.canvasItem.zValue()
#if zval > z:
###print " ->", x
#insertLocation = x+1
#if n == ch.text(0):
#nextnode = ch
#break
#if nextnode is None: ## If name doesn't exist, create it
#nextnode = QtGui.QTreeWidgetItem([n])
#nextnode.setFlags((nextnode.flags() | QtCore.Qt.ItemIsUserCheckable) & ~QtCore.Qt.ItemIsDropEnabled)
#nextnode.setCheckState(0, QtCore.Qt.Checked)
### Add node to correct position in list by Z-value
###print " ==>", insertLocation
#currentNode.insertChild(insertLocation, nextnode)
#if n == name[-1]: ## This is the leaf; add some extra properties.
#nextnode.name = name
#if n == name[0]: ## This is the root; make the item movable
#nextnode.setFlags(nextnode.flags() | QtCore.Qt.ItemIsDragEnabled)
#else:
#nextnode.setFlags(nextnode.flags() & ~QtCore.Qt.ItemIsDragEnabled)
#currentNode = nextnode
return citem return citem
def treeItemMoved(self, item, parent, index): def treeItemMoved(self, item, parent, index):
@ -481,31 +392,6 @@ class Canvas(QtGui.QWidget):
for i in range(len(siblings)): for i in range(len(siblings)):
item = siblings[i] item = siblings[i]
item.setZValue(zvals[i]) item.setZValue(zvals[i])
#item = self.itemList.topLevelItem(i)
##ci = self.items[item.name]
#ci = item.canvasItem
#if ci is None:
#continue
#if ci.zValue() != zvals[i]:
#ci.setZValue(zvals[i])
#if self.itemList.topLevelItemCount() < 2:
#return
#name = item.name
#gi = self.items[name]
#if index == 0:
#next = self.itemList.topLevelItem(1)
#z = self.items[next.name].zValue()+1
#else:
#prev = self.itemList.topLevelItem(index-1)
#z = self.items[prev.name].zValue()-1
#gi.setZValue(z)
def itemVisibilityChanged(self, item): def itemVisibilityChanged(self, item):
listItem = item.listItem listItem = item.listItem
@ -521,7 +407,6 @@ class Canvas(QtGui.QWidget):
if isinstance(item, QtGui.QTreeWidgetItem): if isinstance(item, QtGui.QTreeWidgetItem):
item = item.canvasItem() item = item.canvasItem()
if isinstance(item, CanvasItem): if isinstance(item, CanvasItem):
item.setCanvas(None) item.setCanvas(None)
listItem = item.listItem listItem = item.listItem
@ -559,15 +444,10 @@ class Canvas(QtGui.QWidget):
def getListItem(self, name): def getListItem(self, name):
return self.items[name] return self.items[name]
#def scene(self):
#return self.view.scene()
def itemTransformChanged(self, item): def itemTransformChanged(self, item):
#self.emit(QtCore.SIGNAL('itemTransformChanged'), self, item)
self.sigItemTransformChanged.emit(self, item) self.sigItemTransformChanged.emit(self, item)
def itemTransformChangeFinished(self, item): def itemTransformChangeFinished(self, item):
#self.emit(QtCore.SIGNAL('itemTransformChangeFinished'), self, item)
self.sigItemTransformChangeFinished.emit(self, item) self.sigItemTransformChangeFinished.emit(self, item)
def itemListContextMenuEvent(self, ev): def itemListContextMenuEvent(self, ev):
@ -575,13 +455,13 @@ class Canvas(QtGui.QWidget):
self.menu.popup(ev.globalPos()) self.menu.popup(ev.globalPos())
def removeClicked(self): def removeClicked(self):
#self.removeItem(self.menuItem)
for item in self.selectedItems(): for item in self.selectedItems():
self.removeItem(item) self.removeItem(item)
self.menuItem = None self.menuItem = None
import gc import gc
gc.collect() gc.collect()
class SelectBox(ROI): class SelectBox(ROI):
def __init__(self, scalable=False): def __init__(self, scalable=False):
#QtGui.QGraphicsRectItem.__init__(self, 0, 0, size[0], size[1]) #QtGui.QGraphicsRectItem.__init__(self, 0, 0, size[0], size[1])
@ -593,14 +473,3 @@ class SelectBox(ROI):
self.addScaleHandle([0, 0], center, lockAspect=True) self.addScaleHandle([0, 0], center, lockAspect=True)
self.addRotateHandle([0, 1], center) self.addRotateHandle([0, 1], center)
self.addRotateHandle([1, 0], center) self.addRotateHandle([1, 0], center)

View File

@ -87,14 +87,12 @@ class CanvasItem(QtCore.QObject):
self.alphaSlider.valueChanged.connect(self.alphaChanged) self.alphaSlider.valueChanged.connect(self.alphaChanged)
self.alphaSlider.sliderPressed.connect(self.alphaPressed) self.alphaSlider.sliderPressed.connect(self.alphaPressed)
self.alphaSlider.sliderReleased.connect(self.alphaReleased) self.alphaSlider.sliderReleased.connect(self.alphaReleased)
#self.canvas.sigSelectionChanged.connect(self.selectionChanged)
self.resetTransformBtn.clicked.connect(self.resetTransformClicked) self.resetTransformBtn.clicked.connect(self.resetTransformClicked)
self.copyBtn.clicked.connect(self.copyClicked) self.copyBtn.clicked.connect(self.copyClicked)
self.pasteBtn.clicked.connect(self.pasteClicked) self.pasteBtn.clicked.connect(self.pasteClicked)
self.setMovable(self.opts['movable']) ## update gui to reflect this option self.setMovable(self.opts['movable']) ## update gui to reflect this option
if 'transform' in self.opts: if 'transform' in self.opts:
self.baseTransform = self.opts['transform'] self.baseTransform = self.opts['transform']
else: else:
@ -114,7 +112,6 @@ class CanvasItem(QtCore.QObject):
## every CanvasItem implements its own individual selection box ## every CanvasItem implements its own individual selection box
## so that subclasses are free to make their own. ## so that subclasses are free to make their own.
self.selectBox = SelectBox(scalable=self.opts['scalable'], rotatable=self.opts['rotatable']) self.selectBox = SelectBox(scalable=self.opts['scalable'], rotatable=self.opts['rotatable'])
#self.canvas.scene().addItem(self.selectBox)
self.selectBox.hide() self.selectBox.hide()
self.selectBox.setZValue(1e6) self.selectBox.setZValue(1e6)
self.selectBox.sigRegionChanged.connect(self.selectBoxChanged) ## calls selectBoxMoved self.selectBox.sigRegionChanged.connect(self.selectBoxChanged) ## calls selectBoxMoved
@ -130,15 +127,6 @@ class CanvasItem(QtCore.QObject):
self.userTransform = SRTTransform() ## stores the total transform of the object self.userTransform = SRTTransform() ## stores the total transform of the object
self.resetUserTransform() self.resetUserTransform()
## now happens inside resetUserTransform -> selectBoxToItem
# self.selectBoxBase = self.selectBox.getState().copy()
#print "Created canvas item", self
#print " base:", self.baseTransform
#print " user:", self.userTransform
#print " temp:", self.tempTransform
#print " bounds:", self.item.sceneBoundingRect()
def setMovable(self, m): def setMovable(self, m):
self.opts['movable'] = m self.opts['movable'] = m
@ -240,7 +228,6 @@ class CanvasItem(QtCore.QObject):
# self.setTranslate(-2*s['pos'][0], -2*s['pos'][1]) # self.setTranslate(-2*s['pos'][0], -2*s['pos'][1])
# self.selectBoxFromUser() # self.selectBoxFromUser()
def hasUserTransform(self): def hasUserTransform(self):
#print self.userRotate, self.userTranslate #print self.userRotate, self.userTranslate
return not self.userTransform.isIdentity() return not self.userTransform.isIdentity()
@ -255,7 +242,6 @@ class CanvasItem(QtCore.QObject):
def isMovable(self): def isMovable(self):
return self.opts['movable'] return self.opts['movable']
def selectBoxMoved(self): def selectBoxMoved(self):
"""The selection box has moved; get its transformation information and pass to the graphics item""" """The selection box has moved; get its transformation information and pass to the graphics item"""
self.userTransform = self.selectBox.getGlobalTransform(relativeTo=self.selectBoxBase) self.userTransform = self.selectBox.getGlobalTransform(relativeTo=self.selectBoxBase)
@ -291,7 +277,6 @@ class CanvasItem(QtCore.QObject):
self.selectBoxFromUser() self.selectBoxFromUser()
self.updateTransform() self.updateTransform()
def setTemporaryTransform(self, transform): def setTemporaryTransform(self, transform):
self.tempTransform = transform self.tempTransform = transform
self.updateTransform() self.updateTransform()
@ -302,21 +287,6 @@ class CanvasItem(QtCore.QObject):
self.resetTemporaryTransform() self.resetTemporaryTransform()
self.selectBoxFromUser() ## update the selection box to match the new userTransform self.selectBoxFromUser() ## update the selection box to match the new userTransform
#st = self.userTransform.saveState()
#self.userTransform = self.userTransform * self.tempTransform ## order is important!
#### matrix multiplication affects the scale factors, need to reset
#if st['scale'][0] < 0 or st['scale'][1] < 0:
#nst = self.userTransform.saveState()
#self.userTransform.setScale([-nst['scale'][0], -nst['scale'][1]])
#self.resetTemporaryTransform()
#self.selectBoxFromUser()
#self.selectBoxChangeFinished()
def resetTemporaryTransform(self): def resetTemporaryTransform(self):
self.tempTransform = SRTTransform() ## don't use Transform.reset()--this transform might be used elsewhere. self.tempTransform = SRTTransform() ## don't use Transform.reset()--this transform might be used elsewhere.
self.updateTransform() self.updateTransform()
@ -339,20 +309,13 @@ class CanvasItem(QtCore.QObject):
def displayTransform(self, transform): def displayTransform(self, transform):
"""Updates transform numbers in the ctrl widget.""" """Updates transform numbers in the ctrl widget."""
tr = transform.saveState() tr = transform.saveState()
self.transformGui.translateLabel.setText("Translate: (%f, %f)" %(tr['pos'][0], tr['pos'][1])) self.transformGui.translateLabel.setText("Translate: (%f, %f)" %(tr['pos'][0], tr['pos'][1]))
self.transformGui.rotateLabel.setText("Rotate: %f degrees" %tr['angle']) self.transformGui.rotateLabel.setText("Rotate: %f degrees" %tr['angle'])
self.transformGui.scaleLabel.setText("Scale: (%f, %f)" %(tr['scale'][0], tr['scale'][1])) self.transformGui.scaleLabel.setText("Scale: (%f, %f)" %(tr['scale'][0], tr['scale'][1]))
#self.transformGui.mirrorImageCheck.setChecked(False)
#if tr['scale'][0] < 0:
# self.transformGui.mirrorImageCheck.setChecked(True)
def resetUserTransform(self): def resetUserTransform(self):
#self.userRotate = 0
#self.userTranslate = pg.Point(0,0)
self.userTransform.reset() self.userTransform.reset()
self.updateTransform() self.updateTransform()
@ -368,8 +331,6 @@ class CanvasItem(QtCore.QObject):
def restoreTransform(self, tr): def restoreTransform(self, tr):
try: try:
#self.userTranslate = pg.Point(tr['trans'])
#self.userRotate = tr['rot']
self.userTransform = SRTTransform(tr) self.userTransform = SRTTransform(tr)
self.updateTransform() self.updateTransform()
@ -377,16 +338,11 @@ class CanvasItem(QtCore.QObject):
self.sigTransformChanged.emit(self) self.sigTransformChanged.emit(self)
self.sigTransformChangeFinished.emit(self) self.sigTransformChangeFinished.emit(self)
except: except:
#self.userTranslate = pg.Point([0,0])
#self.userRotate = 0
self.userTransform = SRTTransform() self.userTransform = SRTTransform()
debug.printExc("Failed to load transform:") debug.printExc("Failed to load transform:")
#print "set transform", self, self.userTranslate
def saveTransform(self): def saveTransform(self):
"""Return a dict containing the current user transform""" """Return a dict containing the current user transform"""
#print "save transform", self, self.userTranslate
#return {'trans': list(self.userTranslate), 'rot': self.userRotate}
return self.userTransform.saveState() return self.userTransform.saveState()
def selectBoxFromUser(self): def selectBoxFromUser(self):
@ -405,7 +361,6 @@ class CanvasItem(QtCore.QObject):
#self.selectBox.setPos([x2, y2]) #self.selectBox.setPos([x2, y2])
self.selectBox.blockSignals(False) self.selectBox.blockSignals(False)
def selectBoxToItem(self): def selectBoxToItem(self):
"""Move/scale the selection box so it fits the item's bounding rect. (assumes item is not rotated)""" """Move/scale the selection box so it fits the item's bounding rect. (assumes item is not rotated)"""
self.itemRect = self._graphicsItem.boundingRect() self.itemRect = self._graphicsItem.boundingRect()
@ -425,11 +380,6 @@ class CanvasItem(QtCore.QObject):
if z is not None: if z is not None:
self._graphicsItem.setZValue(z) self._graphicsItem.setZValue(z)
#def selectionChanged(self, canvas, items):
#self.selected = len(items) == 1 and (items[0] is self)
#self.showSelectBox()
def selectionChanged(self, sel, multi): def selectionChanged(self, sel, multi):
""" """
Inform the item that its selection state has changed. Inform the item that its selection state has changed.
@ -457,15 +407,11 @@ class CanvasItem(QtCore.QObject):
def hideSelectBox(self): def hideSelectBox(self):
self.selectBox.hide() self.selectBox.hide()
def selectBoxChanged(self): def selectBoxChanged(self):
self.selectBoxMoved() self.selectBoxMoved()
#self.updateTransform(self.selectBox)
#self.emit(QtCore.SIGNAL('transformChanged'), self)
self.sigTransformChanged.emit(self) self.sigTransformChanged.emit(self)
def selectBoxChangeFinished(self): def selectBoxChangeFinished(self):
#self.emit(QtCore.SIGNAL('transformChangeFinished'), self)
self.sigTransformChangeFinished.emit(self) self.sigTransformChangeFinished.emit(self)
def alphaPressed(self): def alphaPressed(self):