diff options
-rw-r--r-- | stats/CMakeLists.txt | 2 | ||||
-rw-r--r-- | stats/statsaxis.cpp | 9 | ||||
-rw-r--r-- | stats/statsaxis.h | 2 | ||||
-rw-r--r-- | stats/statscolors.h | 1 | ||||
-rw-r--r-- | stats/statsgrid.cpp | 36 | ||||
-rw-r--r-- | stats/statsgrid.h | 22 | ||||
-rw-r--r-- | stats/statsview.cpp | 6 | ||||
-rw-r--r-- | stats/statsview.h | 2 | ||||
-rw-r--r-- | stats/zvalues.h | 1 |
9 files changed, 81 insertions, 0 deletions
diff --git a/stats/CMakeLists.txt b/stats/CMakeLists.txt index e0e2dc303..a084dd0b5 100644 --- a/stats/CMakeLists.txt +++ b/stats/CMakeLists.txt @@ -23,6 +23,8 @@ set(SUBSURFACE_STATS_SRCS statsaxis.cpp statscolors.h statscolors.cpp + statsgrid.h + statsgrid.cpp statsseries.h statsseries.cpp statsstate.h diff --git a/stats/statsaxis.cpp b/stats/statsaxis.cpp index 23923e7ea..3bdb8e427 100644 --- a/stats/statsaxis.cpp +++ b/stats/statsaxis.cpp @@ -135,6 +135,15 @@ void StatsAxis::addTick(double pos) ticks.emplace_back(pos, chart); } +std::vector<double> StatsAxis::ticksPositions() const +{ + std::vector<double> res; + res.reserve(ticks.size()); + for (const Tick &tick: ticks) + res.push_back(toScreen(tick.pos)); + return res; +} + // Map x (horizontal) or y (vertical) coordinate to or from screen coordinate double StatsAxis::toScreen(double pos) const { diff --git a/stats/statsaxis.h b/stats/statsaxis.h index c25ffe692..150deb087 100644 --- a/stats/statsaxis.h +++ b/stats/statsaxis.h @@ -30,6 +30,8 @@ public: // Map x (horizontal) or y (vertical) coordinate to or from screen coordinate double toScreen(double) const; double toValue(double) const; + + std::vector<double> ticksPositions() const; // Positions in screen coordinates protected: StatsAxis(QtCharts::QChart *chart, const QString &title, bool horizontal, bool labelsBetweenTicks); QtCharts::QChart *chart; diff --git a/stats/statscolors.h b/stats/statscolors.h index 926e2e489..e9775e2a6 100644 --- a/stats/statscolors.h +++ b/stats/statscolors.h @@ -12,6 +12,7 @@ inline const QColor highlightedBorderColor(0xaa, 0xaa, 0x22); inline const QColor darkLabelColor(Qt::black); inline const QColor lightLabelColor(Qt::white); inline const QColor axisColor(Qt::black); +inline const QColor gridColor(0xcc, 0xcc, 0xcc); QColor binColor(int bin, int numBins); QColor labelColor(int bin, size_t numBins); diff --git a/stats/statsgrid.cpp b/stats/statsgrid.cpp new file mode 100644 index 000000000..fe99b1762 --- /dev/null +++ b/stats/statsgrid.cpp @@ -0,0 +1,36 @@ +// SPDX-License-Identifier: GPL-2.0 +#include "statsgrid.h" +#include "statsaxis.h" +#include "statscolors.h" +#include "zvalues.h" + +#include <QChart> +#include <QGraphicsLineItem> + +static const double gridWidth = 1.0; +static const Qt::PenStyle gridStyle = Qt::SolidLine; + +StatsGrid::StatsGrid(QtCharts::QChart *chart, const StatsAxis &xAxis, const StatsAxis &yAxis) + : chart(chart), xAxis(xAxis), yAxis(yAxis) +{ +} + +void StatsGrid::updatePositions() +{ + std::vector<double> xtics = xAxis.ticksPositions(); + std::vector<double> ytics = yAxis.ticksPositions(); + lines.clear(); + if (xtics.empty() || ytics.empty()) + return; + + for (double x: xtics) { + lines.emplace_back(new QGraphicsLineItem(x, ytics.front(), x, ytics.back(), chart)); + lines.back()->setPen(QPen(gridColor, gridWidth, gridStyle)); + lines.back()->setZValue(ZValues::grid); + } + for (double y: ytics) { + lines.emplace_back(new QGraphicsLineItem(xtics.front(), y, xtics.back(), y, chart)); + lines.back()->setPen(QPen(gridColor, gridWidth, gridStyle)); + lines.back()->setZValue(ZValues::grid); + } +} diff --git a/stats/statsgrid.h b/stats/statsgrid.h new file mode 100644 index 000000000..0fdb2a188 --- /dev/null +++ b/stats/statsgrid.h @@ -0,0 +1,22 @@ +// SPDX-License-Identifier: GPL-2.0 +// The background grid of a chart + +#include <memory> +#include <vector> +#include <QVector> +#include <QGraphicsLineItem> + +class StatsAxis; +namespace QtCharts { + class QChart; +}; + +class StatsGrid { +public: + StatsGrid(QtCharts::QChart *chart, const StatsAxis &xAxis, const StatsAxis &yAxis); + void updatePositions(); +private: + QtCharts::QChart *chart; + const StatsAxis &xAxis, &yAxis; + std::vector<std::unique_ptr<QGraphicsLineItem>> lines; +}; diff --git a/stats/statsview.cpp b/stats/statsview.cpp index 394620d13..d6da093b3 100644 --- a/stats/statsview.cpp +++ b/stats/statsview.cpp @@ -6,6 +6,7 @@ #include "pieseries.h" #include "scatterseries.h" #include "statsaxis.h" +#include "statsgrid.h" #include "statsstate.h" #include "statstranslations.h" #include "statsvariables.h" @@ -118,6 +119,8 @@ void StatsView::plotAreaChanged(const QRectF &r) xAxis->setPos(QPointF(left, bottom)); } + if (grid) + grid->updatePositions(); for (auto &series: series) series->updatePositions(); for (QuartileMarker &marker: quartileMarkers) @@ -195,6 +198,8 @@ void StatsView::setAxes(StatsAxis *x, StatsAxis *y) { xAxis = x; yAxis = y; + if (x && y) + grid = std::make_unique<StatsGrid>(chart, *x, *y); } void StatsView::reset() @@ -208,6 +213,7 @@ void StatsView::reset() quartileMarkers.clear(); lineMarkers.clear(); chart->removeAllSeries(); + grid.reset(); axes.clear(); title.reset(); } diff --git a/stats/statsview.h b/stats/statsview.h index 5df05c15b..92dbedf03 100644 --- a/stats/statsview.h +++ b/stats/statsview.h @@ -24,6 +24,7 @@ class CategoryAxis; class CountAxis; class HistogramAxis; class StatsAxis; +class StatsGrid; class Legend; enum class ChartSubType : int; @@ -121,6 +122,7 @@ private: QtCharts::QChart *chart; QFont titleFont; std::vector<std::unique_ptr<StatsAxis>> axes; + std::unique_ptr<StatsGrid> grid; std::vector<std::unique_ptr<StatsSeries>> series; std::unique_ptr<Legend> legend; std::vector<QuartileMarker> quartileMarkers; diff --git a/stats/zvalues.h b/stats/zvalues.h index 1b6dc5d22..118c488c0 100644 --- a/stats/zvalues.h +++ b/stats/zvalues.h @@ -6,6 +6,7 @@ #ifndef ZVALUES_H struct ZValues { + static constexpr double grid = -1.0; static constexpr double series = 0.0; static constexpr double axes = 1.0; static constexpr double seriesLabels = 2.0; |