summaryrefslogtreecommitdiffstats
path: root/examples/datavisualization/scatter/scatterdatamodifier.cpp
diff options
context:
space:
mode:
authorTomi Korpipaa <tomi.korpipaa@qt.io>2023-02-14 09:31:41 +0200
committerTomi Korpipaa <tomi.korpipaa@qt.io>2023-02-27 13:07:40 +0200
commitcbaa2eaaf73ffa0d2b4ba999c993199fc22110ea (patch)
tree4e6e63c5976425861fd8a0feebdc9c2286898073 /examples/datavisualization/scatter/scatterdatamodifier.cpp
parent23bd5e3ca472cbe8b4a7b5a82a4b8fb9a98ca830 (diff)
Combine 2 more widget examples into graph gallery
Combine the 2 scatter graph examples into graph gallery example. Note: surface examples will be combined into graph gallery in other commits, to avoid making one gigantic commit. Pick-to: 6.5 Task-number: QTBUG-110698 Change-Id: I8c50d07a31a8b1ee84596f4e216e629d88c7846a Reviewed-by: Tomi Korpipää <tomi.korpipaa@qt.io>
Diffstat (limited to 'examples/datavisualization/scatter/scatterdatamodifier.cpp')
-rw-r--r--examples/datavisualization/scatter/scatterdatamodifier.cpp190
1 files changed, 0 insertions, 190 deletions
diff --git a/examples/datavisualization/scatter/scatterdatamodifier.cpp b/examples/datavisualization/scatter/scatterdatamodifier.cpp
deleted file mode 100644
index f2428d32..00000000
--- a/examples/datavisualization/scatter/scatterdatamodifier.cpp
+++ /dev/null
@@ -1,190 +0,0 @@
-// Copyright (C) 2016 The Qt Company Ltd.
-// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
-
-#include "scatterdatamodifier.h"
-#include <QtDataVisualization/qscatterdataproxy.h>
-#include <QtDataVisualization/qvalue3daxis.h>
-#include <QtDataVisualization/q3dscene.h>
-#include <QtDataVisualization/q3dcamera.h>
-#include <QtDataVisualization/qscatter3dseries.h>
-#include <QtDataVisualization/q3dtheme.h>
-#include <QtCore/qmath.h>
-#include <QtCore/qrandom.h>
-#include <QtWidgets/QComboBox>
-
-//#define RANDOM_SCATTER // Uncomment this to switch to random scatter
-
-const int numberOfItems = 3600;
-const float curveDivider = 3.0f;
-const int lowerNumberOfItems = 900;
-const float lowerCurveDivider = 0.75f;
-
-ScatterDataModifier::ScatterDataModifier(Q3DScatter *scatter)
- : m_graph(scatter),
- m_fontSize(40.0f),
- m_style(QAbstract3DSeries::MeshSphere),
- m_smooth(true),
- m_itemCount(lowerNumberOfItems),
- m_curveDivider(lowerCurveDivider)
-{
- //! [0]
- m_graph->activeTheme()->setType(Q3DTheme::ThemeEbony);
- QFont font = m_graph->activeTheme()->font();
- font.setPointSize(m_fontSize);
- m_graph->activeTheme()->setFont(font);
- m_graph->setShadowQuality(QAbstract3DGraph::ShadowQualitySoftLow);
- m_graph->scene()->activeCamera()->setCameraPreset(Q3DCamera::CameraPresetFront);
- //! [0]
-
- //! [2]
- QScatterDataProxy *proxy = new QScatterDataProxy;
- QScatter3DSeries *series = new QScatter3DSeries(proxy);
- series->setItemLabelFormat(QStringLiteral("@xTitle: @xLabel @yTitle: @yLabel @zTitle: @zLabel"));
- series->setMeshSmooth(m_smooth);
- m_graph->addSeries(series);
- //! [2]
-
- //! [3]
- addData();
- //! [3]
-}
-
-ScatterDataModifier::~ScatterDataModifier()
-{
- delete m_graph;
-}
-
-void ScatterDataModifier::addData()
-{
- // Configure the axes according to the data
- //! [4]
- m_graph->axisX()->setTitle("X");
- m_graph->axisY()->setTitle("Y");
- m_graph->axisZ()->setTitle("Z");
- //! [4]
-
- //! [5]
- QScatterDataArray *dataArray = new QScatterDataArray;
- dataArray->resize(m_itemCount);
- QScatterDataItem *ptrToDataArray = &dataArray->first();
- //! [5]
-
-#ifdef RANDOM_SCATTER
- for (int i = 0; i < m_itemCount; i++) {
- ptrToDataArray->setPosition(randVector());
- ptrToDataArray++;
- }
-#else
- //! [6]
- float limit = qSqrt(m_itemCount) / 2.0f;
- for (int i = -limit; i < limit; i++) {
- for (int j = -limit; j < limit; j++) {
- ptrToDataArray->setPosition(QVector3D(float(i) + 0.5f,
- qCos(qDegreesToRadians(float(i * j) / m_curveDivider)),
- float(j) + 0.5f));
- ptrToDataArray++;
- }
- }
- //! [6]
-#endif
-
- //! [7]
- m_graph->seriesList().at(0)->dataProxy()->resetArray(dataArray);
- //! [7]
-}
-
-//! [8]
-void ScatterDataModifier::changeStyle(int style)
-{
- QComboBox *comboBox = qobject_cast<QComboBox *>(sender());
- if (comboBox) {
- m_style = QAbstract3DSeries::Mesh(comboBox->itemData(style).toInt());
- if (m_graph->seriesList().size())
- m_graph->seriesList().at(0)->setMesh(m_style);
- }
-}
-
-void ScatterDataModifier::setSmoothDots(int smooth)
-{
- m_smooth = bool(smooth);
- QScatter3DSeries *series = m_graph->seriesList().at(0);
- series->setMeshSmooth(m_smooth);
-}
-
-void ScatterDataModifier::changeTheme(int theme)
-{
- Q3DTheme *currentTheme = m_graph->activeTheme();
- currentTheme->setType(Q3DTheme::Theme(theme));
- emit backgroundEnabledChanged(currentTheme->isBackgroundEnabled());
- emit gridEnabledChanged(currentTheme->isGridEnabled());
- emit fontChanged(currentTheme->font());
-}
-
-void ScatterDataModifier::changePresetCamera()
-{
- static int preset = Q3DCamera::CameraPresetFrontLow;
-
- m_graph->scene()->activeCamera()->setCameraPreset((Q3DCamera::CameraPreset)preset);
-
- if (++preset > Q3DCamera::CameraPresetDirectlyBelow)
- preset = Q3DCamera::CameraPresetFrontLow;
-}
-
-void ScatterDataModifier::changeLabelStyle()
-{
- m_graph->activeTheme()->setLabelBackgroundEnabled(!m_graph->activeTheme()->isLabelBackgroundEnabled());
-}
-
-void ScatterDataModifier::changeFont(const QFont &font)
-{
- QFont newFont = font;
- newFont.setPointSizeF(m_fontSize);
- m_graph->activeTheme()->setFont(newFont);
-}
-
-void ScatterDataModifier::shadowQualityUpdatedByVisual(QAbstract3DGraph::ShadowQuality sq)
-{
- int quality = int(sq);
- emit shadowQualityChanged(quality); // connected to a checkbox in main.cpp
-}
-
-void ScatterDataModifier::changeShadowQuality(int quality)
-{
- QAbstract3DGraph::ShadowQuality sq = QAbstract3DGraph::ShadowQuality(quality);
- m_graph->setShadowQuality(sq);
-}
-
-void ScatterDataModifier::setBackgroundEnabled(int enabled)
-{
- m_graph->activeTheme()->setBackgroundEnabled((bool)enabled);
-}
-
-void ScatterDataModifier::setGridEnabled(int enabled)
-{
- m_graph->activeTheme()->setGridEnabled((bool)enabled);
-}
-//! [8]
-
-void ScatterDataModifier::toggleItemCount()
-{
- if (m_itemCount == numberOfItems) {
- m_itemCount = lowerNumberOfItems;
- m_curveDivider = lowerCurveDivider;
- } else {
- m_itemCount = numberOfItems;
- m_curveDivider = curveDivider;
- }
- m_graph->seriesList().at(0)->dataProxy()->resetArray(0);
- addData();
-}
-
-QVector3D ScatterDataModifier::randVector()
-{
- return QVector3D(
- (float)(QRandomGenerator::global()->bounded(100)) / 2.0f -
- (float)(QRandomGenerator::global()->bounded(100)) / 2.0f,
- (float)(QRandomGenerator::global()->bounded(100)) / 100.0f -
- (float)(QRandomGenerator::global()->bounded(100)) / 100.0f,
- (float)(QRandomGenerator::global()->bounded(100)) / 2.0f -
- (float)(QRandomGenerator::global()->bounded(100)) / 2.0f);
-}