From eefa8d8ae61a35e94c9d18eafbea64dc6ff4ba8a Mon Sep 17 00:00:00 2001 From: krepa098 Date: Thu, 14 Aug 2014 11:42:03 +0200 Subject: [PATCH] only show tooltip if required --- widget/croppinglabel.cpp | 24 ++++++++++++++++-------- widget/croppinglabel.h | 5 ++--- 2 files changed, 18 insertions(+), 11 deletions(-) diff --git a/widget/croppinglabel.cpp b/widget/croppinglabel.cpp index ef0f54383..656eb2b70 100644 --- a/widget/croppinglabel.cpp +++ b/widget/croppinglabel.cpp @@ -16,24 +16,21 @@ #include "croppinglabel.h" -CroppingLabel::CroppingLabel(QWidget *parent) +CroppingLabel::CroppingLabel(QWidget* parent) : QLabel(parent) { setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Preferred); } -void CroppingLabel::setText(const QString &text) +void CroppingLabel::setText(const QString& text) { origText = text; - setToolTip(text); - - QLabel::setText(fontMetrics().elidedText(text, Qt::ElideRight, width())); + setElidedText(); } -void CroppingLabel::resizeEvent(QResizeEvent *ev) +void CroppingLabel::resizeEvent(QResizeEvent* ev) { - setText(origText); - + setElidedText(); QLabel::resizeEvent(ev); } @@ -46,3 +43,14 @@ QSize CroppingLabel::minimumSizeHint() const { return QSize(fontMetrics().width("..."), QLabel::minimumSizeHint().height()); } + +void CroppingLabel::setElidedText() +{ + QString elidedText = fontMetrics().elidedText(origText, Qt::ElideRight, width()); + if (elidedText != origText) + setToolTip(origText); + else + setToolTip(QString()); + + QLabel::setText(elidedText); +} diff --git a/widget/croppinglabel.h b/widget/croppinglabel.h index 7ed99704a..decc5ad19 100644 --- a/widget/croppinglabel.h +++ b/widget/croppinglabel.h @@ -30,9 +30,8 @@ public: virtual QSize sizeHint() const; virtual QSize minimumSizeHint() const; -signals: - -public slots: +protected: + void setElidedText(); private: QString origText;