Mercurial > minori
diff include/gui/widgets/graph.h @ 259:0362f3c4534c
widgets/graph: improve drawing code
author | Paper <paper@paper.us.eu.org> |
---|---|
date | Mon, 01 Apr 2024 18:11:15 -0400 |
parents | 862d0d8619f6 |
children | 3ec7804abf17 |
line wrap: on
line diff
--- a/include/gui/widgets/graph.h Mon Apr 01 02:43:44 2024 -0400 +++ b/include/gui/widgets/graph.h Mon Apr 01 18:11:15 2024 -0400 @@ -30,12 +30,15 @@ }; protected: + static constexpr int HORIZ_SPACING = 5; + static constexpr int VERT_SPACING = 3; + std::unordered_map<T, unsigned long> map = {}; QSize minimumSizeHint() const override { QFontMetrics metric(font()); /* wtf?... */ - return QSize(100, (metric.height() * map.size()) + (2 * map.size())); + return QSize(100, (metric.height() * map.size()) + (VERT_SPACING * map.size())); } /* helper functions */ @@ -61,37 +64,66 @@ return ret; } + inline unsigned long GetValueWidth() { + unsigned long ret = 0; + QFontMetrics metric(font()); + + for (const auto& item : map) { + unsigned long width = metric.horizontalAdvance(QString::number(item.second), -1); + if (width > ret) + ret = width; + } + + return ret; + } + void paintEvent(QPaintEvent* event) override { - static constexpr int HORIZ_SPACING = 5; - static constexpr int VERT_SPACING = 2; - /* these are retrieved from the QPaintEvent */ const QRect rect = event->rect(); - const int width = event->rect().width(); + const int width = rect.width(); const int x = rect.x(); int y = rect.y(); /* these are calculated from font metrics and such */ const int total = GetTotal(); const int text_width = GetTextWidth(); + const int value_width = GetValueWidth(); const int each_height = QFontMetrics(font()).height(); /* now we do the actual painting */ QPainter painter(this); for (const auto& [key, value] : map) { + int offset = 0; + painter.drawText(QRect(x, y, text_width, each_height), Qt::AlignVCenter | Qt::AlignRight, QString::number(key)); + offset += text_width + HORIZ_SPACING; + /* only draw this if we actually have any data */ if (total) { + painter.save(); + + QPen pen(painter.pen()); + pen.setStyle(Qt::NoPen); + painter.setPen(pen); + QPainterPath path; - path.addRect(x + text_width + HORIZ_SPACING, y, - (static_cast<double>(value) / total) * (width - text_width - HORIZ_SPACING), each_height); - painter.fillPath(path, Qt::darkBlue); + path.addRect(x + offset, y, + (static_cast<double>(value) / total) * (width - offset - HORIZ_SPACING - value_width), each_height); + painter.fillPath(path, Qt::darkGreen); painter.drawPath(path); + + offset += (static_cast<double>(value) / total) * (width - offset - HORIZ_SPACING - value_width); + + painter.restore(); } + offset += HORIZ_SPACING; + + painter.drawText(QRect(x + offset, y, value_width, each_height), Qt::AlignVCenter | Qt::AlignLeft, QString::number(value)); + y += each_height + VERT_SPACING; } }