1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
#include <QFont>
#include <QFontDatabase>
#include <QString>
#include <QtTest>
#include <QCoreApplication>
#include <QtQuick/private/qquickfontmetrics_p.h>
#include <QFontMetricsF>
class tst_QuickFontMetrics : public QObject
{
Q_OBJECT
public:
tst_QuickFontMetrics();
private Q_SLOTS:
void properties();
void functions_data();
void functions();
};
tst_QuickFontMetrics::tst_QuickFontMetrics()
{
}
void tst_QuickFontMetrics::properties()
{
const QStringList families = QFontDatabase::families().mid(0, 10);
QQuickFontMetrics metrics;
for (const QString &family : families) {
QFont font(family);
QFontMetricsF expected(font);
QSignalSpy spy(&metrics, SIGNAL(fontChanged(QFont)));
metrics.setFont(font);
QCOMPARE(spy.size(), 1);
QCOMPARE(metrics.ascent(), expected.ascent());
QCOMPARE(metrics.descent(), expected.descent());
QCOMPARE(metrics.height(), expected.height());
QCOMPARE(metrics.leading(), expected.leading());
QCOMPARE(metrics.lineSpacing(), expected.lineSpacing());
QCOMPARE(metrics.minimumLeftBearing(), expected.minLeftBearing());
QCOMPARE(metrics.minimumRightBearing(), expected.minRightBearing());
QCOMPARE(metrics.maximumCharacterWidth(), expected.maxWidth());
QCOMPARE(metrics.xHeight(), expected.xHeight());
QCOMPARE(metrics.averageCharacterWidth(), expected.averageCharWidth());
QCOMPARE(metrics.underlinePosition(), expected.underlinePos());
QCOMPARE(metrics.overlinePosition(), expected.overlinePos());
QCOMPARE(metrics.strikeOutPosition(), expected.strikeOutPos());
QCOMPARE(metrics.lineWidth(), expected.lineWidth());
}
}
Q_DECLARE_METATYPE(Qt::TextElideMode)
void tst_QuickFontMetrics::functions_data()
{
QTest::addColumn<QString>("text");
QTest::addColumn<Qt::TextElideMode>("mode");
QTest::addColumn<qreal>("width");
QTest::addColumn<int>("flags");
QStringList strings;
strings << QString()
<< QString::fromLatin1("")
<< QString::fromLatin1("0")
<< QString::fromLatin1("@@@@@@@")
<< QString::fromLatin1("Hello");
QVector<Qt::TextElideMode> elideModes;
elideModes << Qt::ElideLeft << Qt::ElideMiddle << Qt::ElideRight << Qt::ElideNone;
for (int stringIndex = 0; stringIndex < strings.size(); ++stringIndex) {
const QString string = strings.at(stringIndex);
for (int elideModeIndex = 0; elideModeIndex < elideModes.size(); ++elideModeIndex) {
Qt::TextElideMode elideMode = static_cast<Qt::TextElideMode>(elideModes.at(elideModeIndex));
for (qreal width = 0; width < 100; width += 20) {
const QString tag = QString::fromLatin1("string=%1, mode=%2, width=%3").arg(string).arg(elideMode).arg(width);
QTest::newRow(qPrintable(tag)) << QString() << elideMode << width << 0;
}
}
}
}
void tst_QuickFontMetrics::functions()
{
QFETCH(QString, text);
QFETCH(Qt::TextElideMode, mode);
QFETCH(qreal, width);
QFETCH(int, flags);
QQuickFontMetrics metrics;
QFontMetricsF expected = QFontMetricsF(QFont());
QCOMPARE(metrics.elidedText(text, mode, width, flags), expected.elidedText(text, mode, width, flags));
QCOMPARE(metrics.advanceWidth(text), expected.horizontalAdvance(text));
QCOMPARE(metrics.boundingRect(text), expected.boundingRect(text));
QCOMPARE(metrics.tightBoundingRect(text), expected.tightBoundingRect(text));
}
QTEST_MAIN(tst_QuickFontMetrics)
#include "tst_quickfontmetrics.moc"
|