aboutsummaryrefslogtreecommitdiffstats
path: root/examples/charts/modeldata.py
diff options
context:
space:
mode:
authorCristian Maureira-Fredes <Cristian.Maureira-Fredes@qt.io>2021-02-05 10:07:19 +0100
committerCristian Maureira-Fredes <cristian.maureira-fredes@qt.io>2021-02-09 07:43:07 +0000
commit33743aeb2be37d166bcc3291a98dd22026871cef (patch)
treecd45b08ef2a8c80e5e250e1050a41d8ece6fa199 /examples/charts/modeldata.py
parentad01b159e02067ba46d6433412cb1e690553e946 (diff)
examples: directory structure
When generating the gallery automatically, the structure of the examples was not the same for all the modules. This reorganization was made under the following assumption: An example requires: - its own directory, - a '.pyproject' file, - one or more '.py' files, - extra files (likes images, .rc, .ui, etc) Even for cases when subdirectories are made to depict categories, like 'widgets/state-machine/...', one directory is required per example. There should not be '.pyproject' files for categories, except for the general 'examples.pyproject' to open all of them. Task-number: PYSIDE-1490 Pick-to: 6.0 Change-Id: Ie690773c816a248016dbebaad90fbb1d1c2aeea5 Reviewed-by: Cristian Maureira-Fredes <cristian.maureira-fredes@qt.io>
Diffstat (limited to 'examples/charts/modeldata.py')
-rw-r--r--examples/charts/modeldata.py183
1 files changed, 0 insertions, 183 deletions
diff --git a/examples/charts/modeldata.py b/examples/charts/modeldata.py
deleted file mode 100644
index 1d10190f4..000000000
--- a/examples/charts/modeldata.py
+++ /dev/null
@@ -1,183 +0,0 @@
-
-#############################################################################
-##
-## Copyright (C) 2021 The Qt Company Ltd.
-## Contact: http://www.qt.io/licensing/
-##
-## This file is part of the Qt for Python examples of the Qt Toolkit.
-##
-## $QT_BEGIN_LICENSE:BSD$
-## You may use this file under the terms of the BSD license as follows:
-##
-## "Redistribution and use in source and binary forms, with or without
-## modification, are permitted provided that the following conditions are
-## met:
-## * Redistributions of source code must retain the above copyright
-## notice, this list of conditions and the following disclaimer.
-## * Redistributions in binary form must reproduce the above copyright
-## notice, this list of conditions and the following disclaimer in
-## the documentation and/or other materials provided with the
-## distribution.
-## * Neither the name of The Qt Company Ltd nor the names of its
-## contributors may be used to endorse or promote products derived
-## from this software without specific prior written permission.
-##
-##
-## THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-## "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-## LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-## A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-## OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-## SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-## LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-## DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-## THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-## (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-## OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
-##
-## $QT_END_LICENSE$
-##
-#############################################################################
-
-"""PySide6 port of the Model Data example from Qt v5.x"""
-
-import sys
-from random import randrange
-
-from PySide6.QtCore import QAbstractTableModel, QModelIndex, QRect, Qt
-from PySide6.QtGui import QColor, QPainter
-from PySide6.QtWidgets import (QApplication, QGridLayout, QHeaderView,
- QTableView, QWidget)
-from PySide6.QtCharts import QChart, QChartView, QLineSeries, QVXYModelMapper
-
-
-class CustomTableModel(QAbstractTableModel):
- def __init__(self):
- QAbstractTableModel.__init__(self)
- self.input_data = []
- self.mapping = {}
- self.column_count = 4
- self.row_count = 15
-
- for i in range(self.row_count):
- data_vec = [0]*self.column_count
- for k in range(len(data_vec)):
- if k % 2 == 0:
- data_vec[k] = i * 50 + randrange(30)
- else:
- data_vec[k] = randrange(100)
- self.input_data.append(data_vec)
-
- def rowCount(self, parent=QModelIndex()):
- return len(self.input_data)
-
- def columnCount(self, parent=QModelIndex()):
- return self.column_count
-
- def headerData(self, section, orientation, role):
- if role != Qt.DisplayRole:
- return None
-
- if orientation == Qt.Horizontal:
- if section % 2 == 0:
- return "x"
- else:
- return "y"
- else:
- return "{}".format(section + 1)
-
- def data(self, index, role=Qt.DisplayRole):
- if role == Qt.DisplayRole:
- return self.input_data[index.row()][index.column()]
- elif role == Qt.EditRole:
- return self.input_data[index.row()][index.column()]
- elif role == Qt.BackgroundRole:
- for color, rect in self.mapping.items():
- if rect.contains(index.column(), index.row()):
- return QColor(color)
- # cell not mapped return white color
- return QColor(Qt.white)
- return None
-
- def setData(self, index, value, role=Qt.EditRole):
- if index.isValid() and role == Qt.EditRole:
- self.input_data[index.row()][index.column()] = float(value)
- self.dataChanged.emit(index, index)
- return True
- return False
-
- def flags(self, index):
- return Qt.ItemIsEnabled | Qt.ItemIsEditable | Qt.ItemIsSelectable
-
- def add_mapping(self, color, area):
- self.mapping[color] = area
-
- def clear_mapping(self):
- self.mapping = {}
-
-
-
-class TableWidget(QWidget):
- def __init__(self):
- QWidget.__init__(self)
-
- self.model = CustomTableModel()
-
- self.table_view = QTableView()
- self.table_view.setModel(self.model)
- self.table_view.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch)
- self.table_view.verticalHeader().setSectionResizeMode(QHeaderView.Stretch)
-
- self.chart = QChart()
- self.chart.setAnimationOptions(QChart.AllAnimations)
-
- self.series = QLineSeries()
- self.series.setName("Line 1")
- self.mapper = QVXYModelMapper(self)
- self.mapper.setXColumn(0)
- self.mapper.setYColumn(1)
- self.mapper.setSeries(self.series)
- self.mapper.setModel(self.model)
- self.chart.addSeries(self.series)
-
- # for storing color hex from the series
- seriesColorHex = "#000000"
-
- # get the color of the series and use it for showing the mapped area
- seriesColorHex = "{}".format(self.series.pen().color().name())
- self.model.add_mapping(seriesColorHex, QRect(0, 0, 2, self.model.rowCount()))
-
- # series 2
- self.series = QLineSeries()
- self.series.setName("Line 2")
-
- self.mapper = QVXYModelMapper(self)
- self.mapper.setXColumn(2)
- self.mapper.setYColumn(3)
- self.mapper.setSeries(self.series)
- self.mapper.setModel(self.model)
- self.chart.addSeries(self.series)
-
- # get the color of the series and use it for showing the mapped area
- seriesColorHex = "{}".format(self.series.pen().color().name())
- self.model.add_mapping(seriesColorHex, QRect(2, 0, 2, self.model.rowCount()))
-
- self.chart.createDefaultAxes()
- self.chart_view = QChartView(self.chart)
- self.chart_view.setRenderHint(QPainter.Antialiasing)
- self.chart_view.setMinimumSize(640, 480)
-
- # create main layout
- self.main_layout = QGridLayout()
- self.main_layout.addWidget(self.table_view, 1, 0)
- self.main_layout.addWidget(self.chart_view, 1, 1)
- self.main_layout.setColumnStretch(1, 1)
- self.main_layout.setColumnStretch(0, 0)
- self.setLayout(self.main_layout)
-
-
-if __name__ == "__main__":
- app = QApplication(sys.argv)
- w = TableWidget()
- w.show()
- sys.exit(app.exec_())