/**************************************************************************** ** ** Copyright (C) 2014 Digia Plc ** All rights reserved. ** For any questions to Digia, please use contact form at http://qt.digia.com ** ** This file is part of the QtDataVisualization module. ** ** Licensees holding valid Qt Enterprise licenses may use this file in ** accordance with the Qt Enterprise License Agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and Digia. ** ** If you have questions regarding the use of this file, please use ** contact form at http://qt.digia.com ** ****************************************************************************/ #include "graphmodifier.h" #include #include #include #include #include #include #include #include using namespace QtDataVisualization; //#define JITTER_PLANE //#define WONKY_PLANE GraphModifier::GraphModifier(Q3DSurface *graph) : m_graph(graph), m_series1(new QSurface3DSeries), m_series2(new QSurface3DSeries), m_series3(new QSurface3DSeries), m_series4(new QSurface3DSeries), m_gridSliderX(0), m_gridSliderZ(0), m_axisRangeSliderX(0), m_axisRangeSliderZ(0), m_axisMinSliderX(0), m_axisMinSliderZ(0), m_xCount(24), m_zCount(24), m_activeSample(0), m_fontSize(40), m_rangeX(16.0), m_rangeZ(16.0), m_minX(-8.0), m_minZ(-8.0), m_addRowCounter(m_zCount), m_insertTestZPos(0), m_insertTestIndexPos(1), m_planeArray(0), m_theSeries(new QSurface3DSeries), m_drawMode(QSurface3DSeries::DrawSurfaceAndWireframe), m_drawMode2(QSurface3DSeries::DrawSurfaceAndWireframe), m_drawMode3(QSurface3DSeries::DrawSurfaceAndWireframe), m_drawMode4(QSurface3DSeries::DrawSurfaceAndWireframe) { m_graph->setAxisX(new QValue3DAxis); m_graph->setAxisY(new QValue3DAxis); m_graph->setAxisZ(new QValue3DAxis); #ifdef MULTI_SERIES m_limitX = float(m_xCount) / 2.0f; m_limitZ = float(m_zCount) / 2.0f; m_graph->axisX()->setRange(-m_limitX, m_limitX); m_graph->axisY()->setRange(-1.0f, 4.5f); m_graph->axisZ()->setRange(-m_limitZ, m_limitZ); #else m_graph->axisX()->setRange(m_minX, m_minX + m_rangeX); m_graph->axisZ()->setRange(m_minZ, m_minZ + m_rangeZ); m_graph->addSeries(m_theSeries); #endif for (int i = 0; i < 4; i++) { m_multiseries[i] = new QSurface3DSeries; m_multiseries[i]->setItemLabelFormat(QStringLiteral("@seriesName: (@xLabel, @zLabel): @yLabel")); } fillSeries(); changeStyle(); m_theSeries->setItemLabelFormat(QStringLiteral("@seriesName: (@xLabel, @zLabel): @yLabel")); connect(&m_timer, &QTimer::timeout, this, &GraphModifier::timeout); connect(m_theSeries, &QSurface3DSeries::selectedPointChanged, this, &GraphModifier::selectedPointChanged); QObject::connect(m_graph, &Q3DSurface::axisXChanged, this, &GraphModifier::handleAxisXChanged); QObject::connect(m_graph, &Q3DSurface::axisYChanged, this, &GraphModifier::handleAxisYChanged); QObject::connect(m_graph, &Q3DSurface::axisZChanged, this, &GraphModifier::handleAxisZChanged); } GraphModifier::~GraphModifier() { delete m_graph; } void GraphModifier::fillSeries() { int full = m_limitX * m_limitZ; QSurfaceDataArray *dataArray1 = new QSurfaceDataArray; dataArray1->reserve(m_zCount); QSurfaceDataArray *dataArray2 = new QSurfaceDataArray; dataArray2->reserve(m_zCount); QSurfaceDataArray *dataArray3 = new QSurfaceDataArray; dataArray3->reserve(m_zCount); QSurfaceDataArray *dataArray4 = new QSurfaceDataArray; dataArray4->reserve(m_zCount); for (int i = 0; i < m_zCount; i++) { QSurfaceDataRow *newRow1 = new QSurfaceDataRow(m_xCount); QSurfaceDataRow *newRow2 = new QSurfaceDataRow(m_xCount); QSurfaceDataRow *newRow3 = new QSurfaceDataRow(m_xCount); QSurfaceDataRow *newRow4 = new QSurfaceDataRow(m_xCount); float z = float(i) - m_limitZ + 0.5f; for (int j = 0; j < m_xCount; j++) { float x = float(j) - m_limitX + 0.5f; float angle = (z * x) / float(full) * 1.57f; (*newRow1)[j].setPosition(QVector3D(x, qSin(angle), z)); angle *= 1.3f; (*newRow2)[j].setPosition(QVector3D(x, qSin(angle) + 1.1f, z)); angle *= 1.3f; (*newRow3)[j].setPosition(QVector3D(x, qSin(angle) + 2.2f, z)); angle *= 1.3f; (*newRow4)[j].setPosition(QVector3D(x, qSin(angle) + 3.3f, z)); } *dataArray1 << newRow1; *dataArray2 << newRow2; *dataArray3 << newRow3; *dataArray4 << newRow4; } m_multiseries[0]->dataProxy()->resetArray(dataArray1); m_multiseries[1]->dataProxy()->resetArray(dataArray2); m_multiseries[2]->dataProxy()->resetArray(dataArray3); m_multiseries[3]->dataProxy()->resetArray(dataArray4); } void GraphModifier::toggleSeries1(bool enabled) { qDebug() << __FUNCTION__ << " enabled = " << enabled; if (enabled) { m_graph->addSeries(m_multiseries[0]); } else { m_graph->removeSeries(m_multiseries[0]); } } void GraphModifier::toggleSeries2(bool enabled) { qDebug() << __FUNCTION__ << " enabled = " << enabled; if (enabled) { m_graph->addSeries(m_multiseries[1]); } else { m_graph->removeSeries(m_multiseries[1]); } } void GraphModifier::toggleSeries3(bool enabled) { qDebug() << __FUNCTION__ << " enabled = " << enabled; if (enabled) { m_graph->addSeries(m_multiseries[2]); } else { m_graph->removeSeries(m_multiseries[2]); } } void GraphModifier::toggleSeries4(bool enabled) { qDebug() << __FUNCTION__ << " enabled = " << enabled; if (enabled) { m_graph->addSeries(m_multiseries[3]); } else { m_graph->removeSeries(m_multiseries[3]); } } void GraphModifier::toggleSmooth(bool enabled) { qDebug() << "GraphModifier::toggleSmooth " << enabled; m_theSeries->setFlatShadingEnabled(enabled); #ifdef MULTI_SERIES m_multiseries[0]->setFlatShadingEnabled(enabled); #endif } void GraphModifier::toggleSurfaceGrid(bool enable) { qDebug() << "GraphModifier::toggleSurfaceGrid" << enable; if (enable) m_drawMode |= QSurface3DSeries::DrawWireframe; else m_drawMode &= ~QSurface3DSeries::DrawWireframe; m_theSeries->setDrawMode(m_drawMode); #ifdef MULTI_SERIES m_multiseries[0]->setDrawMode(m_drawMode); #endif } void GraphModifier::toggleSurface(bool enable) { qDebug() << "GraphModifier::toggleSurface" << enable; if (enable) m_drawMode |= QSurface3DSeries::DrawSurface; else m_drawMode &= ~QSurface3DSeries::DrawSurface; m_theSeries->setDrawMode(m_drawMode); #ifdef MULTI_SERIES m_multiseries[0]->setDrawMode(m_drawMode); #endif } void GraphModifier::toggleSeriesVisible(bool enable) { m_theSeries->setVisible(enable); #ifdef MULTI_SERIES m_multiseries[0]->setVisible(enable); #endif } void GraphModifier::toggleSmoothS2(bool enabled) { qDebug() << __FUNCTION__ << enabled; m_multiseries[1]->setFlatShadingEnabled(enabled); } void GraphModifier::toggleSurfaceGridS2(bool enable) { qDebug() << __FUNCTION__ << enable; if (enable) m_drawMode2 |= QSurface3DSeries::DrawWireframe; else m_drawMode2 &= ~QSurface3DSeries::DrawWireframe; m_multiseries[1]->setDrawMode(m_drawMode2); } void GraphModifier::toggleSurfaceS2(bool enable) { qDebug() << __FUNCTION__ << enable; if (enable) m_drawMode2 |= QSurface3DSeries::DrawSurface; else m_drawMode2 &= ~QSurface3DSeries::DrawSurface; m_multiseries[1]->setDrawMode(m_drawMode2); } void GraphModifier::toggleSeries2Visible(bool enable) { qDebug() << __FUNCTION__ << enable; m_multiseries[1]->setVisible(enable); } void GraphModifier::toggleSmoothS3(bool enabled) { qDebug() << __FUNCTION__ << enabled; m_multiseries[2]->setFlatShadingEnabled(enabled); } void GraphModifier::toggleSurfaceGridS3(bool enable) { qDebug() << __FUNCTION__ << enable; if (enable) m_drawMode3 |= QSurface3DSeries::DrawWireframe; else m_drawMode3 &= ~QSurface3DSeries::DrawWireframe; m_multiseries[2]->setDrawMode(m_drawMode3); } void GraphModifier::toggleSurfaceS3(bool enable) { qDebug() << __FUNCTION__ << enable; if (enable) m_drawMode3 |= QSurface3DSeries::DrawSurface; else m_drawMode3 &= ~QSurface3DSeries::DrawSurface; m_multiseries[2]->setDrawMode(m_drawMode3); } void GraphModifier::toggleSeries3Visible(bool enable) { qDebug() << __FUNCTION__ << enable; m_multiseries[2]->setVisible(enable); } void GraphModifier::toggleSmoothS4(bool enabled) { qDebug() << __FUNCTION__ << enabled; m_multiseries[3]->setFlatShadingEnabled(enabled); } void GraphModifier::toggleSurfaceGridS4(bool enable) { qDebug() << __FUNCTION__ << enable; if (enable) m_drawMode4 |= QSurface3DSeries::DrawWireframe; else m_drawMode4 &= ~QSurface3DSeries::DrawWireframe; m_multiseries[3]->setDrawMode(m_drawMode4); } void GraphModifier::toggleSurfaceS4(bool enable) { qDebug() << __FUNCTION__ << enable; if (enable) m_drawMode4 |= QSurface3DSeries::DrawSurface; else m_drawMode4 &= ~QSurface3DSeries::DrawSurface; m_multiseries[3]->setDrawMode(m_drawMode4); } void GraphModifier::toggleSeries4Visible(bool enable) { qDebug() << __FUNCTION__ << enable; m_multiseries[3]->setVisible(enable); } void GraphModifier::toggleSqrtSin(bool enable) { if (enable) { qDebug() << "Create Sqrt&Sin surface, (" << m_xCount << ", " << m_zCount << ")"; float minX = -10.0f; float maxX = 10.0f; float minZ = -10.0f; float maxZ = 10.0f; float stepX = (maxX - minX) / float(m_xCount - 1); float stepZ = (maxZ - minZ) / float(m_zCount - 1); QSurfaceDataArray *dataArray = new QSurfaceDataArray; dataArray->reserve(m_zCount); for (float i = 0; i < m_zCount; i++) { QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); // Keep values within range bounds, since just adding step can cause minor drift due // to the rounding errors. float z = qMin(maxZ, (i * stepZ + minZ)); for (float j = 0; j < m_xCount; j++) { float x = qMin(maxX, (j * stepX + minX)); float R = qSqrt(x * x + z * z) + 0.01f; float y = (qSin(R) / R + 0.24f) * 1.61f + 1.0f; (*newRow)[j].setPosition(QVector3D(x, y, z)); } *dataArray << newRow; } m_graph->axisY()->setRange(1.0, 3.0); m_graph->axisX()->setLabelFormat("%.2f"); m_graph->axisZ()->setLabelFormat("%.2f"); m_theSeries->setName("Sqrt & Sin"); resetArrayAndSliders(dataArray, minZ, maxZ, minX, maxX); m_activeSample = GraphModifier::SqrtSin; } else { qDebug() << "Remove surface"; } } void GraphModifier::togglePlane(bool enable) { qDebug() << "GraphModifier::togglePlane " << enable; if (enable) { m_planeArray = new QSurfaceDataArray; #ifdef JITTER_PLANE m_timer.start(0); #endif m_graph->axisY()->setRange(0.0, 1.0); m_graph->axisX()->setLabelFormat("%.2f"); m_graph->axisZ()->setLabelFormat("%.2f"); m_planeArray->reserve(m_zCount); float minX = -10.0f; float maxX = 20.0f; float minZ = -10.0f; float maxZ = 10.0f; float stepX = (maxX - minX) / float(m_xCount - 1); float stepZ = (maxZ - minZ) / float(m_zCount - 1); #ifdef WONKY_PLANE float halfZ = m_zCount / 2; float wonkyFactor = 0.01f; float maxStepX = 0.0f; float add = 0.0f; for (float i = 0; i < m_zCount; i++) { QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); if (i < halfZ) { stepX += wonkyFactor; maxStepX = stepX; } else { stepX -= wonkyFactor; } add = 0.0f; for (float j = 0; j < m_xCount; j++) { (*newRow)[j].setPosition(QVector3D(j * stepX + minX, -0.04f, i * stepZ + minZ + add)); add += 0.5f; } *m_planeArray << newRow; } m_theSeries->setName("Wonky Plane"); resetArrayAndSliders(m_planeArray, minZ, maxZ + add, minX, m_xCount * maxStepX + minX); #else for (float i = 0; i < m_zCount; i++) { QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); // Keep values within range bounds, since just adding step can cause minor drift due // to the rounding errors. float zVal; if (i == (m_zCount - 1)) zVal = maxZ; else zVal = i * stepZ + minZ; float j = 0; for (; j < m_xCount - 1; j++) (*newRow)[j].setPosition(QVector3D(j * stepX + minX, -0.04f, zVal)); (*newRow)[j].setPosition(QVector3D(maxX, -0.04f, zVal)); *m_planeArray << newRow; } m_theSeries->setName("Plane"); resetArrayAndSliders(m_planeArray, minZ, maxZ, minX, maxX); #endif m_activeSample = GraphModifier::Plane; } #ifdef JITTER_PLANE else { m_timer.stop(); } #endif } void GraphModifier::setHeightMapData(bool enable) { if (enable) { // Do the height map the hard way. // Easier alternative would be to use the QHeightMapSurfaceDataProxy. QImage image(":/maps/map"); QSurfaceDataArray *dataArray = new QSurfaceDataArray; uchar *bits = image.bits(); int p = image.width() * 4 * (image.height() - 1); dataArray->reserve(image.height()); float minX = 34.0; float maxX = 40.0; float minZ = 18.0; float maxZ = 24.0; float xMul = (maxX - minX) / float(image.width() - 1); float zMul = (maxZ - minZ) / float(image.height() - 1); for (int i = 0; i < image.height(); i++, p -= image.width() * 4) { QSurfaceDataRow *newRow = new QSurfaceDataRow(image.width()); for (int j = 0; j < image.width(); j++) { (*newRow)[j].setPosition(QVector3D((float(j) * xMul) + minX, (float(bits[p + (j * 4)]) + 1.0f) / 1.0f, (float(i) * zMul) + minZ)); } *dataArray << newRow; } m_graph->axisY()->setAutoAdjustRange(true); m_graph->axisX()->setLabelFormat("%.1f N"); m_graph->axisZ()->setLabelFormat("%.1f E"); m_theSeries->setName("Height Map"); resetArrayAndSliders(dataArray, minZ, maxZ, minX, maxX); m_activeSample = GraphModifier::Map; } } void GraphModifier::toggleGridSliderLock(bool enable) { m_gridSlidersLocked = enable; if (m_gridSlidersLocked) { m_gridSliderZ->setEnabled(false); m_gridSliderZ->setValue(m_gridSliderX->value()); } else { m_gridSliderZ->setEnabled(true); } } void GraphModifier::adjustXCount(int count) { m_xCount = count; if (m_gridSlidersLocked) m_gridSliderZ->setValue(count); updateSamples(); qDebug() << "X count =" << count; } void GraphModifier::adjustZCount(int count) { m_zCount = count; updateSamples(); qDebug() << "Z count =" << count; } void GraphModifier::adjustXRange(int range) { m_rangeX = range; m_graph->axisX()->setRange(m_minX, m_minX + m_rangeX); qDebug() << "X Range =" << range; } void GraphModifier::adjustZRange(int range) { m_rangeZ = range; m_graph->axisZ()->setRange(m_minZ, m_minZ + m_rangeZ); qDebug() << "Z Range =" << range; } void GraphModifier::adjustXMin(int min) { m_minX = min; m_graph->axisX()->setRange(m_minX, m_minX + m_rangeX); qDebug() << "X Minimum =" << min; } void GraphModifier::adjustZMin(int min) { m_minZ = min; m_graph->axisZ()->setRange(m_minZ, m_minZ + m_rangeZ); qDebug() << "Z Minimum =" << min; } void GraphModifier::gradientPressed() { QLinearGradient gradient; gradient.setColorAt(0.0, Qt::black); gradient.setColorAt(0.33, Qt::blue); gradient.setColorAt(0.67, Qt::red); gradient.setColorAt(1.0, Qt::yellow); // m_graph->seriesList().at(0)->setBaseGradient(gradient); // m_graph->seriesList().at(0)->setSingleHighlightColor(Qt::red); // m_graph->seriesList().at(0)->setColorStyle(Q3DTheme::ColorStyleRangeGradient); QList gradients; gradients << gradient; m_graph->activeTheme()->setBaseGradients(gradients); m_graph->activeTheme()->setColorStyle(Q3DTheme::ColorStyleRangeGradient); } void GraphModifier::changeFont(const QFont &font) { QFont newFont = font; newFont.setPointSizeF(m_fontSize); m_graph->activeTheme()->setFont(newFont); } void GraphModifier::changeStyle() { m_graph->activeTheme()->setLabelBackgroundEnabled(!m_graph->activeTheme()->isLabelBackgroundEnabled()); } void GraphModifier::selectButtonClicked() { QSurfaceDataProxy *proxy = m_theSeries->dataProxy(); int row = rand() % proxy->rowCount(); int col = rand() % proxy->columnCount(); m_theSeries->setSelectedPoint(QPoint(row, col)); } void GraphModifier::selectedPointChanged(const QPoint &point) { QString labelText = QStringLiteral("Selected row: %1, column: %2").arg(point.x()).arg(point.y()); m_selectionInfoLabel->setText(labelText); } void GraphModifier::changeTheme(int theme) { m_graph->activeTheme()->setType(Q3DTheme::Theme(theme)); } void GraphModifier::flipViews() { m_graph->scene()->setSecondarySubviewOnTop(!m_graph->scene()->isSecondarySubviewOnTop()); } void GraphModifier::timeout() { int rows = m_planeArray->size(); int columns = m_planeArray->at(0)->size(); // Induce minor random jitter to the existing plane array for (int i = 0; i < rows; i++) { for (int j = 0; j < columns; j++) { (*m_planeArray->at(i))[j].setX(m_planeArray->at(i)->at(j).x() * ((float((rand() % 10) + 5.0f) / 10000.0f) + 0.999f)); (*m_planeArray->at(i))[j].setY(m_planeArray->at(i)->at(j).y() * ((float((rand() % 10) + 5.0f) / 1000.0f) + 0.99f) + 0.0001f); (*m_planeArray->at(i))[j].setZ(m_planeArray->at(i)->at(j).z() * ((float((rand() % 10) + 5.0f) / 10000.0f) + 0.999f)); } } // Reset same array to make it redraw m_theSeries->dataProxy()->resetArray(m_planeArray); } void GraphModifier::handleAxisXChanged(QValue3DAxis *axis) { qDebug() << __FUNCTION__ << axis << axis->orientation() << (axis == m_graph->axisX()); } void GraphModifier::handleAxisYChanged(QValue3DAxis *axis) { qDebug() << __FUNCTION__ << axis << axis->orientation() << (axis == m_graph->axisY()); } void GraphModifier::handleAxisZChanged(QValue3DAxis *axis) { qDebug() << __FUNCTION__ << axis << axis->orientation() << (axis == m_graph->axisZ()); } void GraphModifier::resetArrayAndSliders(QSurfaceDataArray *array, float minZ, float maxZ, float minX, float maxX) { m_axisMinSliderX->setValue(minX); m_axisMinSliderZ->setValue(minZ); m_axisRangeSliderX->setValue(maxX - minX); m_axisRangeSliderZ->setValue(maxZ - minZ); m_theSeries->dataProxy()->resetArray(array); } void GraphModifier::changeShadowQuality(int quality) { QAbstract3DGraph::ShadowQuality sq = QAbstract3DGraph::ShadowQuality(quality); m_graph->setShadowQuality(sq); } void GraphModifier::changeSelectionMode(int mode) { QComboBox *comboBox = qobject_cast(sender()); if (comboBox) { int flags = comboBox->itemData(mode).toInt(); m_graph->setSelectionMode(QAbstract3DGraph::SelectionFlags(flags)); } } void GraphModifier::changeRow() { if (m_activeSample == GraphModifier::SqrtSin) { qDebug() << "Generating new values to a row at random pos"; float minX = -10.0f; float maxX = 10.0f; float minZ = -10.0f; float maxZ = 10.0f; float stepX = (maxX - minX) / float(m_xCount - 1); float stepZ = (maxZ - minZ) / float(m_zCount - 1); float i = float(rand() % m_zCount); QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); float z = qMin(maxZ, (i * stepZ + minZ)); for (float j = 0; j < m_xCount; j++) { float x = qMin(maxX, (j * stepX + minX)); float R = qSqrt(x * x + z * z) + 0.01f; float y = (qSin(R) / R + 0.24f) * 1.61f + 1.2f; (*newRow)[j].setPosition(QVector3D(x, y, z)); } m_theSeries->dataProxy()->setRow(int(i), newRow); } else { #ifdef MULTI_SERIES static int changeRowSeries = 0; qDebug() << "Generating new values to a row at random pos for series " << changeRowSeries; int row = rand() % m_zCount; QSurfaceDataRow *newRow = createMultiRow(row, changeRowSeries); m_multiseries[changeRowSeries]->dataProxy()->setRow(row, newRow); changeRowSeries++; if (changeRowSeries > 3) changeRowSeries = 0; #else qDebug() << "Change row function active only for SqrtSin"; #endif } } QSurfaceDataRow *GraphModifier::createMultiRow(int row, int series) { int full = m_limitX * m_limitZ; float i = float(row); QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); float z = float(i) - m_limitZ + 0.5f; for (int j = 0; j < m_xCount; j++) { float x = float(j) - m_limitX + 0.5f; float angle = (z * x) / float(full) * 1.57f; float y = qSin(angle * float(qPow(1.3f, series))) + 0.2f + 1.1f *series; (*newRow)[j].setPosition(QVector3D(x, y, z)); } return newRow; } void GraphModifier::changeRows() { if (m_activeSample == GraphModifier::SqrtSin) { qDebug() << "Generating new values to 3 rows from random pos"; float minX = -10.0f; float maxX = 10.0f; float minZ = -10.0f; float maxZ = 10.0f; float stepX = (maxX - minX) / float(m_xCount - 1); float stepZ = (maxZ - minZ) / float(m_zCount - 1); float start = float(rand() % (m_zCount - 3)); QSurfaceDataArray dataArray; for (float i = start; i < (start + 3.0f); i++) { QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); float z = qMin(maxZ, (i * stepZ + minZ)); for (float j = 0; j < m_xCount; j++) { float x = qMin(maxX, (j * stepX + minX)); float R = qSqrt(x * x + z * z) + 0.01f; float y = (qSin(R) / R + 0.24f) * 1.61f + 1.2f; (*newRow)[j].setPosition(QVector3D(x, y, z)); } dataArray.append(newRow); } m_theSeries->dataProxy()->setRows(int(start), dataArray); } else { #ifdef MULTI_SERIES static int changeRowSeries = 0; qDebug() << "Generating new values for 3 rows at random pos for series " << changeRowSeries; int row = rand() % (m_zCount - 3); QSurfaceDataArray dataArray; for (int i = 0; i < 3; i++) { QSurfaceDataRow *newRow = createMultiRow(row + i, changeRowSeries); dataArray.append(newRow); } m_multiseries[changeRowSeries]->dataProxy()->setRows(row, dataArray); changeRowSeries++; if (changeRowSeries > 3) changeRowSeries = 0; #else qDebug() << "Change row function active only for SqrtSin"; #endif } } void GraphModifier::changeItem() { if (m_activeSample == GraphModifier::SqrtSin) { qDebug() << "Generating new values for an item at random pos"; float minX = -10.0f; float maxX = 10.0f; float minZ = -10.0f; float maxZ = 10.0f; float stepX = (maxX - minX) / float(m_xCount - 1); float stepZ = (maxZ - minZ) / float(m_zCount - 1); float i = float(rand() % m_zCount); float j = float(rand() % m_xCount); float x = qMin(maxX, (j * stepX + minX)); float z = qMin(maxZ, (i * stepZ + minZ)); float R = qSqrt(x * x + z * z) + 0.01f; float y = (qSin(R) / R + 0.24f) * 1.61f + 1.2f; QSurfaceDataItem newItem(QVector3D(x, y, z)); m_theSeries->dataProxy()->setItem(int(i), int(j), newItem); } else { #ifdef MULTI_SERIES static int changeItemSeries = 0; int full = m_limitX * m_limitZ; float i = float(rand() % m_zCount); float j = float(rand() % m_xCount); float x = float(j) - m_limitX + 0.5f; float z = float(i) - m_limitZ + 0.5f; float angle = (z * x) / float(full) * 1.57f; float y = qSin(angle * float(qPow(1.3f, changeItemSeries))) + 0.2f + 1.1f *changeItemSeries; QSurfaceDataItem newItem(QVector3D(x, y, z)); m_multiseries[changeItemSeries]->dataProxy()->setItem(int(i), int(j), newItem); changeItemSeries++; if (changeItemSeries > 3) changeItemSeries = 0; #else qDebug() << "Change item function active only for SqrtSin"; #endif } } void GraphModifier::changeMultipleRows() { for (int i = 0; i < 30; i++) changeRow(); } void GraphModifier::changeMultipleItem() { for (int i = 0; i < 30; i++) changeItem(); } void GraphModifier::addRow() { if (m_activeSample == GraphModifier::SqrtSin) { qDebug() << "Adding a new row"; float minX = -10.0f; float maxX = 10.0f; float minZ = -10.0f; float maxZ = 10.0f; float stepX = (maxX - minX) / float(m_xCount - 1); float stepZ = (maxZ - minZ) / float(m_zCount - 1); QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); float z = float(m_addRowCounter) * stepZ + minZ; for (float j = 0; j < m_xCount; j++) { float x = qMin(maxX, (j * stepX + minX)); float R = qSqrt(x * x + z * z) + 0.01f; float y = (qSin(R) / R + 0.24f) * 1.61f + 1.0f; (*newRow)[j].setPosition(QVector3D(x, y, z)); } m_addRowCounter++; m_theSeries->dataProxy()->addRow(newRow); } else { #ifdef MULTI_SERIES qDebug() << "Adding a row into series 3"; int full = m_limitX * m_limitZ; QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); for (int j = 0; j < m_xCount; j++) { float angle = float((float(m_addRowCounter) - m_limitZ + 0.5f) * (float(j) - m_limitX + 0.5f)) / float(full) * 1.57f; (*newRow)[j].setPosition(QVector3D(float(j) - m_limitX + 0.5f, qSin(angle * 1.3f * 1.3f) + 2.2f, float(m_addRowCounter) - m_limitZ + 0.5f)); } m_addRowCounter++; m_multiseries[2]->dataProxy()->addRow(newRow); #else qDebug() << "Add row function active only for SqrtSin"; #endif } } void GraphModifier::addRows() { if (m_activeSample == GraphModifier::SqrtSin) { qDebug() << "Adding few new row"; float minX = -10.0f; float maxX = 10.0f; float minZ = -10.0f; float maxZ = 10.0f; float stepX = (maxX - minX) / float(m_xCount - 1); float stepZ = (maxZ - minZ) / float(m_zCount - 1); QSurfaceDataArray dataArray; for (int i = 0; i < 3; i++) { QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); float z = m_addRowCounter * stepZ + minZ; for (float j = 0; j < m_xCount; j++) { float x = qMin(maxX, (j * stepX + minX)); float R = qSqrt(x * x + z * z) + 0.01f; float y = (qSin(R) / R + 0.24f) * 1.61f + 1.0f; (*newRow)[j].setPosition(QVector3D(x, y, z)); } dataArray.append(newRow); m_addRowCounter++; } m_theSeries->dataProxy()->addRows(dataArray); } else { #ifdef MULTI_SERIES qDebug() << "Adding 3 rows into series 3"; int full = m_limitX * m_limitZ; QSurfaceDataArray dataArray; for (int i = 0; i < 3; i++) { QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); for (int j = 0; j < m_xCount; j++) { float angle = float((float(m_addRowCounter) - m_limitZ + 0.5f) * (float(j) - m_limitX + 0.5f)) / float(full) * 1.57f; (*newRow)[j].setPosition(QVector3D(float(j) - m_limitX + 0.5f, qSin(angle * 1.3f * 1.3f) + 2.2f, float(m_addRowCounter) - m_limitZ + 0.5f)); } dataArray.append(newRow); m_addRowCounter++; } m_multiseries[2]->dataProxy()->addRows(dataArray); #else qDebug() << "Add rows function active only for SqrtSin"; #endif } } void GraphModifier::insertRow() { if (m_activeSample == GraphModifier::SqrtSin) { qDebug() << "Inserting a row"; float minX = -10.0f; float maxX = 10.0f; float minZ = -10.0f; float maxZ = 10.0f; float stepX = (maxX - minX) / float(m_xCount - 1); float stepZ = (maxZ - minZ) / float(m_zCount - 1); QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); float z = qMin(maxZ, (float(m_insertTestZPos) * stepZ + minZ + (stepZ / 2.0f))); for (float j = 0; j < m_xCount; j++) { float x = qMin(maxX, (j * stepX + minX)); float R = qSqrt(x * x + z * z) + 0.01f; float y = (qSin(R) / R + 0.24f) * 1.61f + 1.3f; (*newRow)[j].setPosition(QVector3D(x, y, z)); } m_insertTestZPos++; m_theSeries->dataProxy()->insertRow(m_insertTestIndexPos, newRow); m_insertTestIndexPos += 2; } else { #ifdef MULTI_SERIES qDebug() << "Inserting a row into series 3"; int full = m_limitX * m_limitZ; QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); for (int j = 0; j < m_xCount; j++) { float angle = float((float(m_insertTestZPos) - m_limitZ) * (float(j) - m_limitX)) / float(full) * 1.57f; (*newRow)[j].setPosition(QVector3D(float(j) - m_limitX + 0.5f, qSin(angle) + 2.4f, float(m_insertTestZPos) - m_limitZ + 1.0f)); } m_insertTestZPos++; m_multiseries[2]->dataProxy()->insertRow(m_insertTestIndexPos, newRow); m_insertTestIndexPos += 2; #else qDebug() << "Insert row function active only for SqrtSin"; #endif } } void GraphModifier::insertRows() { if (m_activeSample == GraphModifier::SqrtSin) { qDebug() << "Inserting 3 rows"; float minX = -10.0f; float maxX = 10.0f; float minZ = -10.0f; float maxZ = 10.0f; float stepX = (maxX - minX) / float(m_xCount - 1); float stepZ = (maxZ - minZ) / float(m_zCount - 1); QSurfaceDataArray dataArray; for (int i = 0; i < 3; i++) { QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); float z = qMin(maxZ, (float(m_insertTestZPos) * stepZ + minZ + i * (stepZ / 4.0f))); for (float j = 0; j < m_xCount; j++) { float x = qMin(maxX, (j * stepX + minX)); float R = qSqrt(x * x + z * z) + 0.01f; float y = (qSin(R) / R + 0.24f) * 1.61f + 1.3f; (*newRow)[j].setPosition(QVector3D(x, y, z)); } dataArray.append(newRow); } m_insertTestZPos++; m_theSeries->dataProxy()->insertRows(m_insertTestIndexPos, dataArray); m_insertTestIndexPos += 4; } else { #ifdef MULTI_SERIES qDebug() << "Inserting 3 rows into series 3"; int full = m_limitX * m_limitZ; QSurfaceDataArray dataArray; float zAdd = 0.25f; for (int i = 0; i < 3; i++) { QSurfaceDataRow *newRow = new QSurfaceDataRow(m_xCount); for (int j = 0; j < m_xCount; j++) { float angle = float((float(m_insertTestZPos) - m_limitZ) * (float(j) - m_limitX)) / float(full) * 1.57f; (*newRow)[j].setPosition(QVector3D(float(j) - m_limitX + 0.5f, qSin(angle) + 2.4f, float(m_insertTestZPos) - m_limitZ + 0.5f + zAdd)); } zAdd += 0.25f; dataArray.append(newRow); } m_insertTestZPos++; m_multiseries[2]->dataProxy()->insertRows(m_insertTestIndexPos, dataArray); m_insertTestIndexPos += 4; #else qDebug() << "Insert rows function active only for SqrtSin"; #endif } } void GraphModifier::removeRow() { qDebug() << "Remove an arbitrary row"; if (m_zCount < 1) return; int row = rand() % m_zCount; #ifdef MULTI_SERIES int series = rand() % 4; m_multiseries[series]->dataProxy()->removeRows(row, 1); #else m_theSeries->dataProxy()->removeRows(row, 1); #endif m_zCount--; } void GraphModifier::changeMesh() { static int model = 0; switch (model) { case 0: m_graph->seriesList().at(0)->setMesh(QAbstract3DSeries::MeshCylinder); m_graph->seriesList().at(0)->setMeshSmooth(false); break; case 1: m_graph->seriesList().at(0)->setMesh(QAbstract3DSeries::MeshCylinder); m_graph->seriesList().at(0)->setMeshSmooth(true); break; case 2: m_graph->seriesList().at(0)->setMesh(QAbstract3DSeries::MeshCone); m_graph->seriesList().at(0)->setMeshSmooth(false); break; case 3: m_graph->seriesList().at(0)->setMesh(QAbstract3DSeries::MeshCone); m_graph->seriesList().at(0)->setMeshSmooth(true); break; case 4: m_graph->seriesList().at(0)->setMesh(QAbstract3DSeries::MeshBar); m_graph->seriesList().at(0)->setMeshSmooth(false); break; case 5: m_graph->seriesList().at(0)->setMesh(QAbstract3DSeries::MeshBar); m_graph->seriesList().at(0)->setMeshSmooth(true); break; case 6: m_graph->seriesList().at(0)->setMesh(QAbstract3DSeries::MeshPyramid); m_graph->seriesList().at(0)->setMeshSmooth(false); break; case 7: m_graph->seriesList().at(0)->setMesh(QAbstract3DSeries::MeshPyramid); m_graph->seriesList().at(0)->setMeshSmooth(true); break; case 8: m_graph->seriesList().at(0)->setMesh(QAbstract3DSeries::MeshBevelBar); m_graph->seriesList().at(0)->setMeshSmooth(false); break; case 9: m_graph->seriesList().at(0)->setMesh(QAbstract3DSeries::MeshBevelBar); m_graph->seriesList().at(0)->setMeshSmooth(true); break; } model++; if (model > 9) model = 0; } void GraphModifier::updateSamples() { switch (m_activeSample) { case SqrtSin: toggleSqrtSin(true); break; case Plane: togglePlane(true); break; default: break; } }