diff options
| author | Felix (xq) Queißner <git@mq32.de> | 2020-06-12 03:25:00 +0200 |
|---|---|---|
| committer | Felix (xq) Queißner <git@mq32.de> | 2020-06-12 03:25:00 +0200 |
| commit | c71a08e2b44521590a3f48e6cd6b15394890b48f (patch) | |
| tree | c7528b48c3a35166a91f0bb92f96acae5d009eee /src/elidelabel.cpp | |
| parent | 0c57280c4eec7ddce569f89cb35de917d8b4d08e (diff) | |
| download | kristall-c71a08e2b44521590a3f48e6cd6b15394890b48f.tar.gz | |
Fixes two overflow bugs in labels. No weird scaling based on links anymore.
Diffstat (limited to 'src/elidelabel.cpp')
| -rw-r--r-- | src/elidelabel.cpp | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/src/elidelabel.cpp b/src/elidelabel.cpp new file mode 100644 index 0000000..8830f69 --- /dev/null +++ b/src/elidelabel.cpp @@ -0,0 +1,55 @@ +#include "elidelabel.hpp" + +#include <QPainter> + +ElideLabel::ElideLabel(QWidget* parent) + : QLabel(parent) +{ + m_elideMode = Qt::ElideNone; +} + +ElideLabel::ElideLabel(const QString &text, QWidget* parent) : QLabel(text, parent) +{ + m_elideMode = Qt::ElideNone; +} + +ElideLabel::~ElideLabel() +{ +} + +void ElideLabel::setElideMode(Qt::TextElideMode mode) +{ + m_elideMode = mode; +} + +Qt::TextElideMode ElideLabel::elideMode() const +{ + return m_elideMode; +} + +void ElideLabel::paintEvent(QPaintEvent * event) +{ + if (m_elideMode == Qt::ElideNone) + { + QLabel::paintEvent(event); + } + else + { + QFrame::paintEvent(event); + QPainter painter(this); + QRect r = contentsRect(); + painter.drawText(r, alignment(), fontMetrics().elidedText(text(), m_elideMode, r.width())); + } +} + +QSize ElideLabel::minimumSizeHint() const +{ + if (m_elideMode != Qt::ElideNone) + { + const QFontMetrics& fm = fontMetrics(); + QSize size(fm.width("..."), fm.height()); + return size; + } + + return QLabel::minimumSizeHint(); +} |
