diff options
| author | Cristian Maureira-Fredes <Cristian.Maureira-Fredes@qt.io> | 2021-02-05 10:07:19 +0100 |
|---|---|---|
| committer | Cristian Maureira-Fredes <cristian.maureira-fredes@qt.io> | 2021-02-09 07:43:07 +0000 |
| commit | 33743aeb2be37d166bcc3291a98dd22026871cef (patch) | |
| tree | cd45b08ef2a8c80e5e250e1050a41d8ece6fa199 /examples/charts/modeldata.py | |
| parent | ad01b159e02067ba46d6433412cb1e690553e946 (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.py | 183 |
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_()) |
