chartview.cpp
88 lines
| 3.1 KiB
| text/x-c
|
CppLexer
Miikka Heikkinen
|
r2854 | /**************************************************************************** | ||
Jani Honkonen
|
r830 | ** | ||
Miikka Heikkinen
|
r2854 | ** Copyright (C) 2016 The Qt Company Ltd. | ||
** Contact: https://www.qt.io/licensing/ | ||||
Jani Honkonen
|
r830 | ** | ||
Miikka Heikkinen
|
r2854 | ** This file is part of the Qt Charts module of the Qt Toolkit. | ||
Jani Honkonen
|
r830 | ** | ||
Miikka Heikkinen
|
r2854 | ** $QT_BEGIN_LICENSE:GPL$ | ||
Titta Heikkala
|
r2845 | ** Commercial License Usage | ||
** Licensees holding valid commercial Qt licenses may use this file in | ||||
** accordance with the commercial license agreement provided with the | ||||
** Software or, alternatively, in accordance with the terms contained in | ||||
** a written agreement between you and The Qt Company. For licensing terms | ||||
Miikka Heikkinen
|
r2854 | ** and conditions see https://www.qt.io/terms-conditions. For further | ||
** information use the contact form at https://www.qt.io/contact-us. | ||||
** | ||||
** GNU General Public License Usage | ||||
** Alternatively, this file may be used under the terms of the GNU | ||||
** General Public License version 3 or (at your option) any later version | ||||
** approved by the KDE Free Qt Foundation. The licenses are as published by | ||||
** the Free Software Foundation and appearing in the file LICENSE.GPL3 | ||||
** included in the packaging of this file. Please review the following | ||||
** information to ensure the GNU General Public License requirements will | ||||
** be met: https://www.gnu.org/licenses/gpl-3.0.html. | ||||
Jani Honkonen
|
r830 | ** | ||
Titta Heikkala
|
r2845 | ** $QT_END_LICENSE$ | ||
** | ||||
Miikka Heikkinen
|
r2854 | ****************************************************************************/ | ||
Jani Honkonen
|
r830 | |||
Tero Ahola
|
r1026 | #include "chartview.h" | ||
Titta Heikkala
|
r2714 | #include <QtCore/QtMath> | ||
#include <QtCore/QDebug> | ||||
Tero Ahola
|
r394 | |||
Titta Heikkala
|
r2712 | QT_CHARTS_USE_NAMESPACE | ||
Tero Ahola
|
r394 | |||
Tero Ahola
|
r1026 | ChartView::ChartView(QWidget *parent) | ||
: QChartView(new QChart(), parent), | ||||
m_scatter(0), | ||||
m_scatter2(0) | ||||
Tero Ahola
|
r394 | { | ||
Tero Ahola
|
r1026 | setRenderHint(QPainter::Antialiasing); | ||
chart()->setTitle("Click to interact with scatter points"); | ||||
Tero Ahola
|
r394 | |||
m_scatter = new QScatterSeries(); | ||||
Tero Ahola
|
r1226 | m_scatter->setName("scatter1"); | ||
Jani Honkonen
|
r2098 | for (qreal x(0.5); x <= 4.0; x += 0.5) { | ||
for (qreal y(0.5); y <= 4.0; y += 0.5) { | ||||
Tero Ahola
|
r394 | *m_scatter << QPointF(x, y); | ||
} | ||||
} | ||||
Tero Ahola
|
r1026 | m_scatter2 = new QScatterSeries(); | ||
Tero Ahola
|
r1226 | m_scatter2->setName("scatter2"); | ||
Tero Ahola
|
r394 | |||
Tero Ahola
|
r1026 | chart()->addSeries(m_scatter2); | ||
chart()->addSeries(m_scatter); | ||||
Marek Rosa
|
r1620 | chart()->createDefaultAxes(); | ||
Tero Ahola
|
r1026 | chart()->axisX()->setRange(0, 4.5); | ||
chart()->axisY()->setRange(0, 4.5); | ||||
Tero Ahola
|
r394 | |||
Michal Klocek
|
r967 | connect(m_scatter, SIGNAL(clicked(QPointF)), this, SLOT(handleClickedPoint(QPointF))); | ||
Tero Ahola
|
r394 | } | ||
Tero Ahola
|
r1026 | ChartView::~ChartView() | ||
Tero Ahola
|
r394 | { | ||
} | ||||
Jani Honkonen
|
r2102 | void ChartView::handleClickedPoint(const QPointF &point) | ||
Tero Ahola
|
r394 | { | ||
Tero Ahola
|
r1410 | QPointF clickedPoint = point; | ||
// Find the closest point from series 1 | ||||
Tero Ahola
|
r1412 | QPointF closest(INT_MAX, INT_MAX); | ||
qreal distance(INT_MAX); | ||||
Jani Honkonen
|
r2100 | foreach (QPointF currentPoint, m_scatter->points()) { | ||
Titta Heikkala
|
r2613 | qreal currentDistance = qSqrt((currentPoint.x() - clickedPoint.x()) | ||
* (currentPoint.x() - clickedPoint.x()) | ||||
+ (currentPoint.y() - clickedPoint.y()) | ||||
* (currentPoint.y() - clickedPoint.y())); | ||||
Tero Ahola
|
r1410 | if (currentDistance < distance) { | ||
distance = currentDistance; | ||||
closest = currentPoint; | ||||
} | ||||
} | ||||
// Remove the closes point from series 1 and append it to series 2 | ||||
m_scatter->remove(closest); | ||||
m_scatter2->append(closest); | ||||
Tero Ahola
|
r394 | } | ||