From b45ba34be250e938c6b07617e121d789ed52ca1d Mon Sep 17 00:00:00 2001 From: jenli669 Date: Sat, 13 Jul 2019 11:07:30 +0200 Subject: [PATCH] refactor(widget): replace fontMetrics.width() when using Qt 5.13 --- src/widget/tool/croppinglabel.cpp | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/src/widget/tool/croppinglabel.cpp b/src/widget/tool/croppinglabel.cpp index 0b12840a3..d43643617 100644 --- a/src/widget/tool/croppinglabel.cpp +++ b/src/widget/tool/croppinglabel.cpp @@ -36,8 +36,7 @@ CroppingLabel::CroppingLabel(QWidget* parent) public: explicit LineEdit(QWidget* parent = nullptr) : QLineEdit(parent) - { - } + {} protected: void keyPressEvent(QKeyEvent* event) override @@ -106,7 +105,11 @@ QSize CroppingLabel::sizeHint() const QSize CroppingLabel::minimumSizeHint() const { +#if (QT_VERSION >= QT_VERSION_CHECK(5, 11, 0)) + return QSize(fontMetrics().horizontalAdvance("..."), QLabel::minimumSizeHint().height()); +#else return QSize(fontMetrics().width("..."), QLabel::minimumSizeHint().height()); +#endif } void CroppingLabel::mouseReleaseEvent(QMouseEvent* e) @@ -171,7 +174,11 @@ void CroppingLabel::minimizeMaximumWidth() { // This function chooses the smallest possible maximum width. // Text width + padding. Without padding, we'll have elipses. +#if (QT_VERSION >= QT_VERSION_CHECK(5, 11, 0)) + setMaximumWidth(fontMetrics().horizontalAdvance(origText) + fontMetrics().horizontalAdvance("...")); +#else setMaximumWidth(fontMetrics().width(origText) + fontMetrics().width("...")); +#endif } void CroppingLabel::editingFinished()