Skip to content

Commit d20d171

Browse files
committed
Merge #16701: qt: Replace functions deprecated in Qt 5.13
c6dd32d qt: Replace obsolete functions of QDesktopWidget (Hennadii Stepanov) 1260ecd qt: Add TextWidth() wrapper (Hennadii Stepanov) Pull request description: The following functions are obsolete in Qt 5.13: - [`QFontMetrics::width()`](https://doc.qt.io/qt-5/qfontmetrics-obsolete.html#width) - [`QDesktopWidget::availableGeometry()`](https://doc.qt.io/qt-5/qdesktopwidget-obsolete.html#availableGeometry) - [`QDesktopWidget::screenGeometry()`](https://doc.qt.io/qt-5/qdesktopwidget-obsolete.html#screenGeometry) This PR replaces them and does not change behavior. Here are some excerpts from the master build log: ``` qt/bitcoingui.cpp: In constructor ‘BitcoinGUI::BitcoinGUI(interfaces::Node&, const PlatformStyle*, const NetworkStyle*, QWidget*)’: qt/bitcoingui.cpp:84:57: warning: ‘const QRect QDesktopWidget::availableGeometry(int) const’ is deprecated: Use QGuiApplication::screens() [-Wdeprecated-declarations] move(QApplication::desktop()->availableGeometry().center() - frameGeometry().center()); ^ In file included from /home/hebasto/Qt/5.13.0/gcc_64/include/QtWidgets/QDesktopWidget:1:0, from qt/bitcoingui.cpp:43: /home/hebasto/Qt/5.13.0/gcc_64/include/QtWidgets/qdesktopwidget.h:88:67: note: declared here QT_DEPRECATED_X("Use QGuiApplication::screens()") const QRect availableGeometry(int screen = -1) const; ^~~~~~~~~~~~~~~~~ ``` ``` qt/bitcoingui.cpp:1410:74: warning: ‘int QFontMetrics::width(const QString&, int) const’ is deprecated: Use QFontMetrics::horizontalAdvance [-Wdeprecated-declarations] max_width = qMax(max_width, fm.width(BitcoinUnits::longName(unit))); ^ In file included from /home/hebasto/Qt/5.13.0/gcc_64/include/QtWidgets/qwidget.h:50:0, from /home/hebasto/Qt/5.13.0/gcc_64/include/QtWidgets/qdialog.h:44, from /home/hebasto/Qt/5.13.0/gcc_64/include/QtWidgets/QDialog:1, from ./qt/optionsdialog.h:8, from ./qt/bitcoingui.h:12, from qt/bitcoingui.cpp:5: /home/hebasto/Qt/5.13.0/gcc_64/include/QtGui/qfontmetrics.h:108:9: note: declared here int width(const QString &, int len = -1) const; ^~~~~ ``` ``` qt/splashscreen.cpp: In constructor ‘SplashScreen::SplashScreen(interfaces::Node&, Qt::WindowFlags, const NetworkStyle*)’: qt/splashscreen.cpp:127:50: warning: ‘const QRect QDesktopWidget::screenGeometry(int) const’ is deprecated: Use QGuiApplication::screens() [-Wdeprecated-declarations] move(QApplication::desktop()->screenGeometry().center() - r.center()); ^ In file included from /home/hebasto/Qt/5.13.0/gcc_64/include/QtWidgets/QDesktopWidget:1:0, from qt/splashscreen.cpp:24: /home/hebasto/Qt/5.13.0/gcc_64/include/QtWidgets/qdesktopwidget.h:79:67: note: declared here QT_DEPRECATED_X("Use QGuiApplication::screens()") const QRect screenGeometry(int screen = -1) const; ^~~~~~~~~~~~~~ ``` ACKs for top commit: jonasschnelli: utACK c6dd32d Tree-SHA512: deb7bcbf86e1dcc6508bd91288772c2fe8811db79fa2011de37d0469cdd094fbf7fd8c4512c607bed0bd08dc2968e893c0bbc190732c43c69ed1085259df766c
2 parents dcfd85a + c6dd32d commit d20d171

File tree

7 files changed

+34
-17
lines changed

7 files changed

+34
-17
lines changed

src/qt/bitcoinamountfield.cpp

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,7 @@
66

77
#include <qt/bitcoinunits.h>
88
#include <qt/guiconstants.h>
9+
#include <qt/guiutil.h>
910
#include <qt/qvaluecombobox.h>
1011

1112
#include <QApplication>
@@ -121,7 +122,7 @@ class AmountSpinBox: public QAbstractSpinBox
121122

122123
const QFontMetrics fm(fontMetrics());
123124
int h = lineEdit()->minimumSizeHint().height();
124-
int w = fm.width(BitcoinUnits::format(BitcoinUnits::BTC, BitcoinUnits::maxMoney(), false, BitcoinUnits::separatorAlways));
125+
int w = GUIUtil::TextWidth(fm, BitcoinUnits::format(BitcoinUnits::BTC, BitcoinUnits::maxMoney(), false, BitcoinUnits::separatorAlways));
125126
w += 2; // cursor blinking space
126127

127128
QStyleOptionSpinBox opt;

src/qt/bitcoingui.cpp

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -40,14 +40,14 @@
4040
#include <QApplication>
4141
#include <QComboBox>
4242
#include <QDateTime>
43-
#include <QDesktopWidget>
4443
#include <QDragEnterEvent>
4544
#include <QListWidget>
4645
#include <QMenu>
4746
#include <QMenuBar>
4847
#include <QMessageBox>
4948
#include <QMimeData>
5049
#include <QProgressDialog>
50+
#include <QScreen>
5151
#include <QSettings>
5252
#include <QShortcut>
5353
#include <QStackedWidget>
@@ -81,7 +81,7 @@ BitcoinGUI::BitcoinGUI(interfaces::Node& node, const PlatformStyle *_platformSty
8181
QSettings settings;
8282
if (!restoreGeometry(settings.value("MainWindowGeometry").toByteArray())) {
8383
// Restore failed (perhaps missing setting), center the window
84-
move(QApplication::desktop()->availableGeometry().center() - frameGeometry().center());
84+
move(QGuiApplication::primaryScreen()->availableGeometry().center() - frameGeometry().center());
8585
}
8686

8787
#ifdef ENABLE_WALLET
@@ -1407,7 +1407,7 @@ UnitDisplayStatusBarControl::UnitDisplayStatusBarControl(const PlatformStyle *pl
14071407
const QFontMetrics fm(font());
14081408
for (const BitcoinUnits::Unit unit : units)
14091409
{
1410-
max_width = qMax(max_width, fm.width(BitcoinUnits::longName(unit)));
1410+
max_width = qMax(max_width, GUIUtil::TextWidth(fm, BitcoinUnits::longName(unit)));
14111411
}
14121412
setMinimumSize(max_width, 0);
14131413
setAlignment(Qt::AlignRight | Qt::AlignVCenter);

src/qt/guiutil.cpp

Lines changed: 10 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -39,7 +39,6 @@
3939
#include <QClipboard>
4040
#include <QDateTime>
4141
#include <QDesktopServices>
42-
#include <QDesktopWidget>
4342
#include <QDoubleValidator>
4443
#include <QFileDialog>
4544
#include <QFont>
@@ -916,7 +915,7 @@ qreal calculateIdealFontSize(int width, const QString& text, QFont font, qreal m
916915
while(font_size >= minPointSize) {
917916
font.setPointSizeF(font_size);
918917
QFontMetrics fm(font);
919-
if (fm.width(text) < width) {
918+
if (TextWidth(fm, text) < width) {
920919
break;
921920
}
922921
font_size -= 0.5;
@@ -956,4 +955,13 @@ void PolishProgressDialog(QProgressDialog* dialog)
956955
#endif
957956
}
958957

958+
int TextWidth(const QFontMetrics& fm, const QString& text)
959+
{
960+
#if (QT_VERSION >= QT_VERSION_CHECK(5, 11, 0))
961+
return fm.horizontalAdvance(text);
962+
#else
963+
return fm.width(text);
964+
#endif
965+
}
966+
959967
} // namespace GUIUtil

src/qt/guiutil.h

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -257,6 +257,14 @@ namespace GUIUtil
257257

258258
// Fix known bugs in QProgressDialog class.
259259
void PolishProgressDialog(QProgressDialog* dialog);
260+
261+
/**
262+
* Returns the distance in pixels appropriate for drawing a subsequent character after text.
263+
*
264+
* In Qt 5.12 and before the QFontMetrics::width() is used and it is deprecated since Qt 13.0.
265+
* In Qt 5.11 the QFontMetrics::horizontalAdvance() was introduced.
266+
*/
267+
int TextWidth(const QFontMetrics& fm, const QString& text);
260268
} // namespace GUIUtil
261269

262270
#endif // BITCOIN_QT_GUIUTIL_H

src/qt/rpcconsole.cpp

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -28,11 +28,11 @@
2828
#include <wallet/wallet.h>
2929
#endif
3030

31-
#include <QDesktopWidget>
3231
#include <QKeyEvent>
3332
#include <QMenu>
3433
#include <QMessageBox>
3534
#include <QScrollBar>
35+
#include <QScreen>
3636
#include <QSettings>
3737
#include <QSignalMapper>
3838
#include <QTime>
@@ -451,7 +451,7 @@ RPCConsole::RPCConsole(interfaces::Node& node, const PlatformStyle *_platformSty
451451
QSettings settings;
452452
if (!restoreGeometry(settings.value("RPCConsoleWindowGeometry").toByteArray())) {
453453
// Restore failed (perhaps missing setting), center the window
454-
move(QApplication::desktop()->availableGeometry().center() - frameGeometry().center());
454+
move(QGuiApplication::primaryScreen()->availableGeometry().center() - frameGeometry().center());
455455
}
456456

457457
QChar nonbreaking_hyphen(8209);

src/qt/sendcoinsdialog.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -704,7 +704,7 @@ void SendCoinsDialog::updateSmartFeeLabel()
704704
int lightness = ui->fallbackFeeWarningLabel->palette().color(QPalette::WindowText).lightness();
705705
QColor warning_colour(255 - (lightness / 5), 176 - (lightness / 3), 48 - (lightness / 14));
706706
ui->fallbackFeeWarningLabel->setStyleSheet("QLabel { color: " + warning_colour.name() + "; }");
707-
ui->fallbackFeeWarningLabel->setIndent(QFontMetrics(ui->fallbackFeeWarningLabel->font()).width("x"));
707+
ui->fallbackFeeWarningLabel->setIndent(GUIUtil::TextWidth(QFontMetrics(ui->fallbackFeeWarningLabel->font()), "x"));
708708
}
709709
else
710710
{

src/qt/splashscreen.cpp

Lines changed: 8 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -8,22 +8,22 @@
88

99
#include <qt/splashscreen.h>
1010

11-
#include <qt/networkstyle.h>
12-
1311
#include <clientversion.h>
1412
#include <interfaces/handler.h>
1513
#include <interfaces/node.h>
1614
#include <interfaces/wallet.h>
15+
#include <qt/guiutil.h>
16+
#include <qt/networkstyle.h>
1717
#include <ui_interface.h>
1818
#include <util/system.h>
1919
#include <util/translation.h>
2020
#include <version.h>
2121

2222
#include <QApplication>
2323
#include <QCloseEvent>
24-
#include <QDesktopWidget>
2524
#include <QPainter>
2625
#include <QRadialGradient>
26+
#include <QScreen>
2727

2828

2929
SplashScreen::SplashScreen(interfaces::Node& node, Qt::WindowFlags f, const NetworkStyle *networkStyle) :
@@ -75,21 +75,21 @@ SplashScreen::SplashScreen(interfaces::Node& node, Qt::WindowFlags f, const Netw
7575
// check font size and drawing with
7676
pixPaint.setFont(QFont(font, 33*fontFactor));
7777
QFontMetrics fm = pixPaint.fontMetrics();
78-
int titleTextWidth = fm.width(titleText);
78+
int titleTextWidth = GUIUtil::TextWidth(fm, titleText);
7979
if (titleTextWidth > 176) {
8080
fontFactor = fontFactor * 176 / titleTextWidth;
8181
}
8282

8383
pixPaint.setFont(QFont(font, 33*fontFactor));
8484
fm = pixPaint.fontMetrics();
85-
titleTextWidth = fm.width(titleText);
85+
titleTextWidth = GUIUtil::TextWidth(fm, titleText);
8686
pixPaint.drawText(pixmap.width()/devicePixelRatio-titleTextWidth-paddingRight,paddingTop,titleText);
8787

8888
pixPaint.setFont(QFont(font, 15*fontFactor));
8989

9090
// if the version string is too long, reduce size
9191
fm = pixPaint.fontMetrics();
92-
int versionTextWidth = fm.width(versionText);
92+
int versionTextWidth = GUIUtil::TextWidth(fm, versionText);
9393
if(versionTextWidth > titleTextWidth+paddingRight-10) {
9494
pixPaint.setFont(QFont(font, 10*fontFactor));
9595
titleVersionVSpace -= 5;
@@ -111,7 +111,7 @@ SplashScreen::SplashScreen(interfaces::Node& node, Qt::WindowFlags f, const Netw
111111
boldFont.setWeight(QFont::Bold);
112112
pixPaint.setFont(boldFont);
113113
fm = pixPaint.fontMetrics();
114-
int titleAddTextWidth = fm.width(titleAddText);
114+
int titleAddTextWidth = GUIUtil::TextWidth(fm, titleAddText);
115115
pixPaint.drawText(pixmap.width()/devicePixelRatio-titleAddTextWidth-10,15,titleAddText);
116116
}
117117

@@ -124,7 +124,7 @@ SplashScreen::SplashScreen(interfaces::Node& node, Qt::WindowFlags f, const Netw
124124
QRect r(QPoint(), QSize(pixmap.size().width()/devicePixelRatio,pixmap.size().height()/devicePixelRatio));
125125
resize(r.size());
126126
setFixedSize(r.size());
127-
move(QApplication::desktop()->screenGeometry().center() - r.center());
127+
move(QGuiApplication::primaryScreen()->geometry().center() - r.center());
128128

129129
subscribeToCoreSignals();
130130
installEventFilter(this);

0 commit comments

Comments
 (0)