From: Barış Metin Date: Sat, 11 Sep 2010 15:21:46 +0000 (+0200) Subject: start select delegate. X-Git-Tag: sface-0.1-1~57 X-Git-Url: http://git.onelab.eu/?p=sface.git;a=commitdiff_plain;h=e0f5698d85a9079446e04780751acf62e6ee7e61 start select delegate. treeview animation --- diff --git a/sface/mainwindow.py b/sface/mainwindow.py index 46eb79e..f3115a5 100644 --- a/sface/mainwindow.py +++ b/sface/mainwindow.py @@ -98,7 +98,7 @@ class MainWindow(QWidget): self.screens.setCurrentWidget(self.pix) self.pix.setPixmap(pixmap) - timeLine = QTimeLine(800, self) + timeLine = QTimeLine(500, self) timeLine.setFrameRange(0, self.screens.height()); self.connect(timeLine, SIGNAL('frameChanged(int)'), self.animatePixmap) self.connect(timeLine, SIGNAL('finished()'), self.toNextScreen) diff --git a/sface/screens/mainscreen.py b/sface/screens/mainscreen.py index c3908e1..e68ca21 100644 --- a/sface/screens/mainscreen.py +++ b/sface/screens/mainscreen.py @@ -13,19 +13,33 @@ class NodeView(QTreeView): def __init__(self, parent): QTreeView.__init__(self, parent) + self.setAnimated(True) self.setItemsExpandable(True) self.setRootIsDecorated(True) self.setAlternatingRowColors(True) - self.setSizePolicy(QSizePolicy.Expanding, QSizePolicy.Expanding) self.setAttribute(Qt.WA_MacShowFocusRect, 0) + self.setSizePolicy(QSizePolicy.Expanding, QSizePolicy.Expanding) + +class SelectDelegate(QStyledItemDelegate): + pass -class ItemDelegate(QStyledItemDelegate): +class NodeNameDelegate(QStyledItemDelegate): def __init__(self, parent): QStyledItemDelegate.__init__(self) def paint(self, painter, option, index): data = "%s" % index.data().toString() +# model = index.model() +# select_index = model.index(index.row(), 2, index.parent()) +# select_data = select_index.data().toString() +# if select_data == "true": +# print select_data +# model.setData(select_index, QString("TEST"), Qt.DisplayRole) +# model.emit(SIGNAL('dataChanged(QModelIndex, QModelIndex)'), +# select_index, select_index) + + if data.startswith("*"): # already in the sliver data = " %s " % data[1:] @@ -182,6 +196,9 @@ class SliceWidget(QWidget): self.nodeView = NodeView(self) self.nodeModel = NodeModel(self) self.nodeView.setModel(self.nodeModel) + self.nodeNameDelegate = NodeNameDelegate(self) + self.selectDelegate = SelectDelegate(self) + refresh = QPushButton("Update Slice Data", self) refresh.setSizePolicy(QSizePolicy.Maximum, QSizePolicy.Maximum) @@ -245,11 +262,11 @@ class SliceWidget(QWidget): available_nodes = filter(lambda x:x not in sliver_nodes, all_nodes) for node in sliver_nodes: - nodeItem = TreeItem([QString(""), QString("*%s" % node), QString("Implement Checkbox")], networkItem) + nodeItem = TreeItem([QString(""), QString("*%s" % node), QString("true")], networkItem) networkItem.appendChild(nodeItem) for node in available_nodes: - nodeItem = TreeItem([QString(""), QString(node), QString("Implement Checkbox")], networkItem) + nodeItem = TreeItem([QString(""), QString(node), QString("false")], networkItem) networkItem.appendChild(nodeItem) self.nodeModel.rootItem.appendChild(networkItem) @@ -257,8 +274,8 @@ class SliceWidget(QWidget): self.nodeView.expandAll() self.nodeView.resizeColumnToContents(1) - self.delegate = ItemDelegate(self) - self.nodeView.setItemDelegateForColumn(1, self.delegate) + self.nodeView.setItemDelegateForColumn(1, self.nodeNameDelegate) + self.nodeView.setItemDelegateForColumn(2, self.selectDelegate) class MainScreen(SfaScreen):