2011-04-27 10:05:43 +00:00
|
|
|
/****************************************************************************
|
|
|
|
**
|
2016-01-15 12:36:27 +00:00
|
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
|
|
** Contact: https://www.qt.io/licensing/
|
2011-04-27 10:05:43 +00:00
|
|
|
**
|
|
|
|
** This file is part of the test suite of the Qt Toolkit.
|
|
|
|
**
|
2016-01-15 12:36:27 +00:00
|
|
|
** $QT_BEGIN_LICENSE:GPL-EXCEPT$
|
2012-09-19 12:28:29 +00:00
|
|
|
** Commercial License Usage
|
|
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
|
|
** accordance with the commercial license agreement provided with the
|
|
|
|
** Software or, alternatively, in accordance with the terms contained in
|
2015-01-28 08:44:43 +00:00
|
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
2016-01-15 12:36:27 +00:00
|
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
2012-09-19 12:28:29 +00:00
|
|
|
**
|
2016-01-15 12:36:27 +00:00
|
|
|
** GNU General Public License Usage
|
|
|
|
** Alternatively, this file may be used under the terms of the GNU
|
|
|
|
** General Public License version 3 as published by the Free Software
|
|
|
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
|
|
|
** included in the packaging of this file. Please review the following
|
|
|
|
** information to ensure the GNU General Public License requirements will
|
|
|
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
2011-04-27 10:05:43 +00:00
|
|
|
**
|
|
|
|
** $QT_END_LICENSE$
|
|
|
|
**
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <QtTest/QtTest>
|
2012-03-10 02:09:17 +00:00
|
|
|
#include <QtGui/QGuiApplication>
|
2011-04-27 10:05:43 +00:00
|
|
|
#include <QtGui/QPainter>
|
|
|
|
#include <QtGui/QImage>
|
|
|
|
|
|
|
|
#include <qstatictext.h>
|
|
|
|
#include <qpaintengine.h>
|
|
|
|
|
2016-03-10 12:15:50 +00:00
|
|
|
#ifdef QT_BUILD_INTERNAL
|
2011-04-27 10:05:43 +00:00
|
|
|
#include <private/qstatictext_p.h>
|
2016-03-10 12:15:50 +00:00
|
|
|
#endif
|
2011-04-27 10:05:43 +00:00
|
|
|
|
|
|
|
// #define DEBUG_SAVE_IMAGE
|
|
|
|
|
2015-12-03 15:59:30 +00:00
|
|
|
static inline QImage blankSquare()
|
|
|
|
{
|
|
|
|
// a "blank" square; we compare against in our testfunctions to verify
|
|
|
|
// that we have actually painted something
|
|
|
|
QPixmap pm(1000, 1000);
|
|
|
|
pm.fill(Qt::white);
|
|
|
|
return pm.toImage();
|
|
|
|
}
|
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
class tst_QStaticText: public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
2011-08-31 11:24:37 +00:00
|
|
|
public:
|
2015-12-03 15:59:30 +00:00
|
|
|
tst_QStaticText() : m_whiteSquare(blankSquare()) {}
|
2011-04-27 10:05:43 +00:00
|
|
|
|
|
|
|
private slots:
|
|
|
|
void constructionAndDestruction();
|
|
|
|
void drawToPoint_data();
|
|
|
|
void drawToPoint();
|
|
|
|
void drawToRect_data();
|
|
|
|
void drawToRect();
|
|
|
|
void setFont();
|
|
|
|
void setTextWidth();
|
|
|
|
void prepareToCorrectData();
|
|
|
|
void prepareToWrongData();
|
|
|
|
|
|
|
|
void copyConstructor();
|
|
|
|
|
|
|
|
void translatedPainter();
|
|
|
|
void rotatedPainter();
|
|
|
|
void scaledPainter();
|
|
|
|
void projectedPainter();
|
|
|
|
#if 0
|
|
|
|
void rotatedScaledAndTranslatedPainter_data();
|
|
|
|
void rotatedScaledAndTranslatedPainter();
|
|
|
|
#endif
|
|
|
|
void transformationChanged();
|
|
|
|
|
|
|
|
void plainTextVsRichText();
|
|
|
|
|
2014-02-07 15:52:00 +00:00
|
|
|
void setPenPlainText_data();
|
2011-04-27 10:05:43 +00:00
|
|
|
void setPenPlainText();
|
|
|
|
void setPenRichText();
|
|
|
|
void richTextOverridesPen();
|
|
|
|
|
|
|
|
void drawStruckOutText();
|
|
|
|
void drawOverlinedText();
|
|
|
|
void drawUnderlinedText();
|
|
|
|
|
|
|
|
void unprintableCharacter_qtbug12614();
|
2011-06-28 15:07:13 +00:00
|
|
|
|
2016-03-10 12:15:50 +00:00
|
|
|
#ifdef QT_BUILD_INTERNAL
|
2011-06-28 15:07:13 +00:00
|
|
|
void underlinedColor_qtbug20159();
|
|
|
|
void textDocumentColor();
|
2016-03-10 12:15:50 +00:00
|
|
|
#endif
|
2011-08-17 23:40:55 +00:00
|
|
|
|
2016-10-04 10:41:47 +00:00
|
|
|
void multiLine();
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
private:
|
2011-08-31 11:24:37 +00:00
|
|
|
bool supportsTransformations() const;
|
|
|
|
|
2015-12-03 15:59:30 +00:00
|
|
|
const QImage m_whiteSquare;
|
2011-04-27 10:05:43 +00:00
|
|
|
};
|
|
|
|
|
2014-02-07 15:52:00 +00:00
|
|
|
Q_DECLARE_METATYPE(QImage::Format);
|
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
void tst_QStaticText::constructionAndDestruction()
|
|
|
|
{
|
|
|
|
QStaticText text("My text");
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::copyConstructor()
|
|
|
|
{
|
|
|
|
QStaticText text(QLatin1String("My text"));
|
|
|
|
|
|
|
|
QTextOption textOption(Qt::AlignRight);
|
|
|
|
text.setTextOption(textOption);
|
|
|
|
|
|
|
|
text.setPerformanceHint(QStaticText::AggressiveCaching);
|
|
|
|
text.setTextWidth(123.456);
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
|
|
|
|
QStaticText copiedText(text);
|
|
|
|
copiedText.setText(QLatin1String("Other text"));
|
|
|
|
|
|
|
|
QCOMPARE(copiedText.textOption().alignment(), Qt::AlignRight);
|
|
|
|
QCOMPARE(copiedText.performanceHint(), QStaticText::AggressiveCaching);
|
|
|
|
QCOMPARE(copiedText.textWidth(), 123.456);
|
|
|
|
QCOMPARE(copiedText.textFormat(), Qt::PlainText);
|
|
|
|
|
|
|
|
QStaticText otherCopiedText(copiedText);
|
|
|
|
otherCopiedText.setTextWidth(789);
|
|
|
|
|
|
|
|
QCOMPARE(otherCopiedText.text(), QString::fromLatin1("Other text"));
|
|
|
|
}
|
|
|
|
|
|
|
|
Q_DECLARE_METATYPE(QStaticText::PerformanceHint)
|
|
|
|
void tst_QStaticText::drawToPoint_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<QStaticText::PerformanceHint>("performanceHint");
|
|
|
|
|
|
|
|
QTest::newRow("Moderate caching") << QStaticText::ModerateCaching;
|
|
|
|
QTest::newRow("Aggressive caching") << QStaticText::AggressiveCaching;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::drawToPoint()
|
|
|
|
{
|
|
|
|
QFETCH(QStaticText::PerformanceHint, performanceHint);
|
|
|
|
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.drawText(11, 12, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
QStaticText text("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
text.setPerformanceHint(performanceHint);
|
|
|
|
p.drawStaticText(QPointF(11, 12 - QFontMetricsF(p.font()).ascent()), text);
|
|
|
|
}
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
2011-04-27 10:05:43 +00:00
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::drawToRect_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<QStaticText::PerformanceHint>("performanceHint");
|
|
|
|
|
|
|
|
QTest::newRow("Moderate caching") << QStaticText::ModerateCaching;
|
|
|
|
QTest::newRow("Aggressive caching") << QStaticText::AggressiveCaching;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::drawToRect()
|
|
|
|
{
|
|
|
|
QFETCH(QStaticText::PerformanceHint, performanceHint);
|
|
|
|
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.drawText(QRectF(11, 12, 10, 500), "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
QStaticText text("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.setTextWidth(10),
|
|
|
|
p.setClipRect(QRectF(11, 12, 10, 500));
|
|
|
|
text.setPerformanceHint(performanceHint);
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
p.drawStaticText(QPointF(11, 12), text);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(DEBUG_SAVE_IMAGE)
|
|
|
|
imageDrawText.save("drawToRect_imageDrawText.png");
|
|
|
|
imageDrawStaticText.save("drawToRect_imageDrawStaticText.png");
|
|
|
|
#endif
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
2013-03-14 23:42:15 +00:00
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
2011-04-27 10:05:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::prepareToCorrectData()
|
|
|
|
{
|
|
|
|
QTransform transform;
|
|
|
|
transform.scale(2.0, 2.0);
|
Support adding application fonts with QFontconfigDatabase
QFontDatabaseQPA should be able to reinitialize database and
reregister all the fonts when an application font is added, because
it will trigger db->invalidate().
Add cloneWithSize support to QFontEngineBox so that even no usable
font is found in QFontDatabase, QRawFont::setPixelSize can still
work (without making the result rawfont invalid).
Register application fonts with QFontconfigDatabase, the code is
adapted from QFontDatabaseX11.
Reenable QRawFont tests for QPA, these usages are now supported in
QPA.
Fix QStaticText tests, raster in QPA does support transformations.
Translate the text before ZAxix rotation so that it will be visible
in canvas.
Add back fixedPitch support to QPA, and fix QFontDatabase tests.
Fix QGlyphRun tests, ignore non-existence glyphs in alphaMap
locking.
Fix QFontMetrics tests.
Task-number: QTBUG-21415, QTBUG-20754, QTBUG-20977,
QTBUG-20976, QTBUG-20760, QTBUG-20759
Change-Id: I24aea7d6ec6b2ac6342134d1f2591327c23a692b
Reviewed-on: http://codereview.qt-project.org/5384
Reviewed-by: Qt Sanity Bot <qt_sanity_bot@ovi.com>
Reviewed-by: Eskil Abrahamsen Blomfeldt <eskil.abrahamsen-blomfeldt@nokia.com>
2011-09-22 12:23:29 +00:00
|
|
|
transform.translate(100, 10);
|
2011-04-27 10:05:43 +00:00
|
|
|
transform.rotate(90, Qt::ZAxis);
|
|
|
|
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.setTransform(transform);
|
|
|
|
p.drawText(11, 12, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
p.setTransform(transform);
|
|
|
|
QStaticText text("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.prepare(transform, p.font());
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
p.drawStaticText(QPointF(11, 12 - QFontMetricsF(p.font()).ascent()), text);
|
|
|
|
}
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
#if defined(DEBUG_SAVE_IMAGE)
|
|
|
|
imageDrawText.save("prepareToCorrectData_imageDrawText.png");
|
|
|
|
imageDrawStaticText.save("prepareToCorrectData_imageDrawStaticText.png");
|
|
|
|
#endif
|
|
|
|
|
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
if (!supportsTransformations())
|
|
|
|
QEXPECT_FAIL("", "Graphics system does not support transformed text on this platform", Abort);
|
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::prepareToWrongData()
|
|
|
|
{
|
|
|
|
QTransform transform;
|
|
|
|
transform.scale(2.0, 2.0);
|
|
|
|
transform.rotate(90, Qt::ZAxis);
|
|
|
|
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.drawText(11, 12, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
QStaticText text("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.prepare(transform, p.font());
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
p.drawStaticText(QPointF(11, 12 - QFontMetricsF(p.font()).ascent()), text);
|
|
|
|
}
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
2011-04-27 10:05:43 +00:00
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void tst_QStaticText::setFont()
|
|
|
|
{
|
2012-03-10 02:09:17 +00:00
|
|
|
QFont font = QGuiApplication::font();
|
2011-04-27 10:05:43 +00:00
|
|
|
font.setBold(true);
|
|
|
|
font.setPointSize(28);
|
|
|
|
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.drawText(QRectF(0, 0, 1000, 1000), 0, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
|
|
|
|
p.setFont(font);
|
|
|
|
p.drawText(QRectF(11, 120, 1000, 1000), 0, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
|
|
|
|
QStaticText text;
|
|
|
|
text.setText("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
|
|
|
|
p.drawStaticText(0, 0, text);
|
|
|
|
|
|
|
|
p.setFont(font);
|
|
|
|
p.drawStaticText(11, 120, text);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(DEBUG_SAVE_IMAGE)
|
|
|
|
imageDrawText.save("setFont_imageDrawText.png");
|
|
|
|
imageDrawStaticText.save("setFont_imageDrawStaticText.png");
|
|
|
|
#endif
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
2011-04-27 10:05:43 +00:00
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::setTextWidth()
|
|
|
|
{
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.drawText(QRectF(11, 12, 10, 500), "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
QStaticText text("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.setTextWidth(10);
|
|
|
|
p.setClipRect(QRectF(11, 12, 10, 500));
|
|
|
|
p.drawStaticText(QPointF(11, 12), text);
|
|
|
|
}
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
2011-04-27 10:05:43 +00:00
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::translatedPainter()
|
|
|
|
{
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.translate(100, 200);
|
|
|
|
|
|
|
|
p.drawText(11, 12, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
p.translate(100, 200);
|
|
|
|
|
|
|
|
QStaticText text("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
|
|
|
|
p.drawStaticText(QPointF(11, 12 - QFontMetricsF(p.font()).ascent()), text);
|
|
|
|
}
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
2011-04-27 10:05:43 +00:00
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool tst_QStaticText::supportsTransformations() const
|
|
|
|
{
|
|
|
|
QPixmap pm(10, 10);
|
|
|
|
QPainter p(&pm);
|
2011-10-25 09:28:47 +00:00
|
|
|
return p.paintEngine()->type() != QPaintEngine::OpenGL;
|
2011-04-27 10:05:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::rotatedPainter()
|
|
|
|
{
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.rotate(30.0);
|
|
|
|
p.drawText(QRectF(0, 0, 1000, 100), 0, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QStaticText text("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
p.rotate(30.0);
|
|
|
|
p.drawStaticText(QPoint(0, 0), text);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(DEBUG_SAVE_IMAGE)
|
|
|
|
imageDrawText.save("rotatedPainter_imageDrawText.png");
|
|
|
|
imageDrawStaticText.save("rotatedPainter_imageDrawStaticText.png");
|
|
|
|
#endif
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
if (!supportsTransformations())
|
|
|
|
QEXPECT_FAIL("", "Graphics system does not support transformed text on this platform", Abort);
|
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::scaledPainter()
|
|
|
|
{
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.scale(2.0, 0.2);
|
|
|
|
|
|
|
|
p.drawText(11, 12, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
p.scale(2.0, 0.2);
|
|
|
|
|
|
|
|
QStaticText text("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
|
|
|
|
p.drawStaticText(QPointF(11, 12 - QFontMetricsF(p.font()).ascent()), text);
|
|
|
|
}
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
if (!supportsTransformations())
|
|
|
|
QEXPECT_FAIL("", "Graphics system does not support transformed text on this platform", Abort);
|
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::projectedPainter()
|
|
|
|
{
|
|
|
|
QTransform transform;
|
|
|
|
transform.rotate(90, Qt::XAxis);
|
|
|
|
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.setTransform(transform);
|
|
|
|
|
|
|
|
p.drawText(11, 12, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
p.setTransform(transform);
|
|
|
|
|
|
|
|
QStaticText text("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
|
|
|
|
p.drawStaticText(QPointF(11, 12 - QFontMetricsF(p.font()).ascent()), text);
|
|
|
|
}
|
|
|
|
|
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
void tst_QStaticText::rotatedScaledAndTranslatedPainter_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<qreal>("offset");
|
|
|
|
|
|
|
|
for (int i=0; i<100; ++i) {
|
|
|
|
qreal offset = 300 + i / 100.;
|
|
|
|
QTest::newRow(QByteArray::number(offset).constData()) << offset;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::rotatedScaledAndTranslatedPainter()
|
|
|
|
{
|
|
|
|
QFETCH(qreal, offset);
|
|
|
|
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.translate(offset, 0);
|
|
|
|
p.rotate(45.0);
|
|
|
|
p.scale(2.0, 2.0);
|
|
|
|
p.translate(100, 200);
|
|
|
|
|
|
|
|
p.drawText(11, 12, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
p.translate(offset, 0);
|
|
|
|
p.rotate(45.0);
|
|
|
|
p.scale(2.0, 2.0);
|
|
|
|
p.translate(100, 200);
|
|
|
|
|
|
|
|
QStaticText text("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
|
|
|
|
p.drawStaticText(QPointF(11, 12 - QFontMetricsF(p.font()).ascent()), text);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(DEBUG_SAVE_IMAGE)
|
|
|
|
imageDrawText.save("rotatedScaledAndPainter_imageDrawText.png");
|
|
|
|
imageDrawStaticText.save("rotatedScaledAndPainter_imageDrawStaticText.png");
|
|
|
|
#endif
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
if (!supportsTransformations())
|
|
|
|
QEXPECT_FAIL("", "Graphics system does not support transformed text on this platform", Abort);
|
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void tst_QStaticText::transformationChanged()
|
|
|
|
{
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.rotate(33.0);
|
|
|
|
p.scale(0.5, 0.7);
|
|
|
|
|
|
|
|
p.drawText(QRectF(0, 0, 1000, 1000), 0, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
|
|
|
|
p.scale(2.0, 2.5);
|
|
|
|
p.drawText(QRectF(0, 0, 1000, 1000), 0, "Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
p.rotate(33.0);
|
|
|
|
p.scale(0.5, 0.7);
|
|
|
|
|
|
|
|
QStaticText text("Lorem ipsum dolor sit amet, consectetur adipiscing elit.");
|
|
|
|
text.setTextFormat(Qt::PlainText);
|
|
|
|
|
|
|
|
p.drawStaticText(QPointF(0, 0), text);
|
|
|
|
|
|
|
|
p.scale(2.0, 2.5);
|
|
|
|
p.drawStaticText(QPointF(0, 0), text);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(DEBUG_SAVE_IMAGE)
|
|
|
|
imageDrawText.save("transformationChanged_imageDrawText.png");
|
|
|
|
imageDrawStaticText.save("transformationChanged_imageDrawStaticText.png");
|
|
|
|
#endif
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
if (!supportsTransformations())
|
|
|
|
QEXPECT_FAIL("", "Graphics system does not support transformed text on this platform", Abort);
|
|
|
|
QCOMPARE(imageDrawStaticText, imageDrawText);
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::plainTextVsRichText()
|
|
|
|
{
|
|
|
|
QPixmap imagePlainText(1000, 1000);
|
|
|
|
imagePlainText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imagePlainText);
|
|
|
|
|
|
|
|
QStaticText staticText;
|
|
|
|
staticText.setText("FOObar");
|
|
|
|
staticText.setTextFormat(Qt::PlainText);
|
|
|
|
|
|
|
|
p.drawStaticText(10, 10, staticText);
|
|
|
|
}
|
|
|
|
|
|
|
|
QPixmap imageRichText(1000, 1000);
|
|
|
|
imageRichText.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&imageRichText);
|
|
|
|
|
|
|
|
QStaticText staticText;
|
|
|
|
staticText.setText("<html><body>FOObar</body></html>");
|
|
|
|
staticText.setTextFormat(Qt::RichText);
|
|
|
|
|
|
|
|
p.drawStaticText(10, 10, staticText);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(DEBUG_SAVE_IMAGE)
|
|
|
|
imagePlainText.save("plainTextVsRichText_imagePlainText.png");
|
|
|
|
imageRichText.save("plainTextVsRichText_imageRichText.png");
|
|
|
|
#endif
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imagePlainText.toImage() != m_whiteSquare);
|
2011-04-27 10:05:43 +00:00
|
|
|
QCOMPARE(imagePlainText, imageRichText);
|
|
|
|
}
|
|
|
|
|
2016-03-10 08:44:03 +00:00
|
|
|
static bool checkPixels(const QImage &image,
|
|
|
|
Qt::GlobalColor expectedColor1, Qt::GlobalColor expectedColor2,
|
|
|
|
QByteArray *errorMessage)
|
|
|
|
{
|
|
|
|
const QRgb expectedRgb1 = QColor(expectedColor1).rgba();
|
|
|
|
const QRgb expectedRgb2 = QColor(expectedColor2).rgba();
|
|
|
|
|
|
|
|
for (int x = 0, w = image.width(); x < w; ++x) {
|
|
|
|
for (int y = 0, h = image.height(); y < h; ++y) {
|
|
|
|
const QRgb pixel = image.pixel(x, y);
|
|
|
|
if (pixel != expectedRgb1 && pixel != expectedRgb2) {
|
|
|
|
QString message;
|
|
|
|
QDebug(&message) << "Color mismatch in image" << image
|
|
|
|
<< "at" << x << ',' << y << ':' << showbase << hex << pixel
|
|
|
|
<< "(expected: " << expectedRgb1 << ',' << expectedRgb2 << ')';
|
|
|
|
*errorMessage = message.toLocal8Bit();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2014-02-07 15:52:00 +00:00
|
|
|
void tst_QStaticText::setPenPlainText_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<QImage::Format>("format");
|
|
|
|
|
|
|
|
QTest::newRow("argb32pm") << QImage::Format_ARGB32_Premultiplied;
|
|
|
|
QTest::newRow("rgb32") << QImage::Format_RGB32;
|
|
|
|
QTest::newRow("rgba8888pm") << QImage::Format_RGBA8888_Premultiplied;
|
|
|
|
QTest::newRow("rgbx8888") << QImage::Format_RGBX8888;
|
|
|
|
}
|
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
void tst_QStaticText::setPenPlainText()
|
|
|
|
{
|
2014-02-07 15:52:00 +00:00
|
|
|
QFETCH(QImage::Format, format);
|
|
|
|
|
2012-03-10 02:09:17 +00:00
|
|
|
QFont font = QGuiApplication::font();
|
2011-04-27 10:05:43 +00:00
|
|
|
font.setStyleStrategy(QFont::NoAntialias);
|
|
|
|
|
|
|
|
QFontMetricsF fm(font);
|
2017-08-02 09:39:01 +00:00
|
|
|
QImage image(qCeil(fm.horizontalAdvance("XXXXX")), qCeil(fm.height()), format);
|
2011-04-27 10:05:43 +00:00
|
|
|
image.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&image);
|
|
|
|
p.setFont(font);
|
2014-02-07 15:52:00 +00:00
|
|
|
p.setPen(Qt::yellow);
|
2011-04-27 10:05:43 +00:00
|
|
|
|
|
|
|
QStaticText staticText("XXXXX");
|
|
|
|
staticText.setTextFormat(Qt::PlainText);
|
2011-06-03 14:08:54 +00:00
|
|
|
p.drawStaticText(0, 0, staticText);
|
2011-04-27 10:05:43 +00:00
|
|
|
}
|
|
|
|
|
2016-03-10 08:44:03 +00:00
|
|
|
QByteArray errorMessage;
|
|
|
|
QVERIFY2(checkPixels(image, Qt::yellow, Qt::white, &errorMessage),
|
|
|
|
errorMessage.constData());
|
2011-04-27 10:05:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::setPenRichText()
|
|
|
|
{
|
2012-03-10 02:09:17 +00:00
|
|
|
QFont font = QGuiApplication::font();
|
2011-04-27 10:05:43 +00:00
|
|
|
font.setStyleStrategy(QFont::NoAntialias);
|
|
|
|
|
|
|
|
QFontMetricsF fm(font);
|
2017-08-02 09:39:01 +00:00
|
|
|
QPixmap image(qCeil(fm.horizontalAdvance("XXXXX")), qCeil(fm.height()));
|
2011-04-27 10:05:43 +00:00
|
|
|
image.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&image);
|
|
|
|
p.setFont(font);
|
|
|
|
p.setPen(Qt::green);
|
|
|
|
|
|
|
|
QStaticText staticText;
|
|
|
|
staticText.setText("<html><body>XXXXX</body></html>");
|
|
|
|
staticText.setTextFormat(Qt::RichText);
|
|
|
|
p.drawStaticText(0, 0, staticText);
|
|
|
|
}
|
|
|
|
|
2016-03-10 08:44:03 +00:00
|
|
|
QByteArray errorMessage;
|
|
|
|
QVERIFY2(checkPixels(image.toImage(), Qt::green, Qt::white, &errorMessage),
|
|
|
|
errorMessage.constData());
|
2011-04-27 10:05:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::richTextOverridesPen()
|
|
|
|
{
|
2012-03-10 02:09:17 +00:00
|
|
|
QFont font = QGuiApplication::font();
|
2011-04-27 10:05:43 +00:00
|
|
|
font.setStyleStrategy(QFont::NoAntialias);
|
|
|
|
|
|
|
|
QFontMetricsF fm(font);
|
2017-08-02 09:39:01 +00:00
|
|
|
QPixmap image(qCeil(fm.horizontalAdvance("XXXXX")), qCeil(fm.height()));
|
2011-04-27 10:05:43 +00:00
|
|
|
image.fill(Qt::white);
|
|
|
|
{
|
|
|
|
QPainter p(&image);
|
|
|
|
p.setFont(font);
|
|
|
|
p.setPen(Qt::green);
|
|
|
|
|
|
|
|
QStaticText staticText;
|
|
|
|
staticText.setText("<html><body><font color=\"#ff0000\">XXXXX</font></body></html>");
|
|
|
|
staticText.setTextFormat(Qt::RichText);
|
|
|
|
p.drawStaticText(0, 0, staticText);
|
|
|
|
}
|
|
|
|
|
2016-03-10 08:44:03 +00:00
|
|
|
QByteArray errorMessage;
|
|
|
|
QVERIFY2(checkPixels(image.toImage(), Qt::red, Qt::white, &errorMessage),
|
|
|
|
errorMessage.constData());
|
2011-04-27 10:05:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::drawStruckOutText()
|
|
|
|
{
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
|
|
|
|
QString s = QString::fromLatin1("Foobar");
|
|
|
|
|
|
|
|
QFont font;
|
|
|
|
font.setStrikeOut(true);
|
Accept error margin in QGlyphRun/QStaticText test for decorations
When calculating the width of a text for drawing decorations on top,
we use the effective advance of the whole text after it has been
through the shaper.
However, in the case of QStaticText and QGlyphRun, there is shortcut:
Since we only have the glyph indexes and position of each glyph,
we use the position + advance of the right-most glyph to find the
right-most edge of the decoration. For this, however, we use the
advance of the glyph *out of context* of the rest of the string,
because the whole idea is to avoid doing the shaping of the string
with every draw call. In some rare cases, the advance of the
right-most character, in the context of the string, is different
from the advance of the standalone glyph.
Now, one way of fixing this would be to store the width of the
text in QStaticText and QGlyphRun, but since it is a very rare
artifact which is barely visible, I have opted to just work around
it in the test instead, the workaround being to force integer
metrics so that we don't get the small 0.2 pixel error.
Task-number: QTBUG-55217
Change-Id: I8d16d52f2ef27275cabb7d3865aeeaa31617ba3d
Reviewed-by: Lars Knoll <lars.knoll@qt.io>
2017-02-02 11:29:44 +00:00
|
|
|
font.setStyleStrategy(QFont::ForceIntegerMetrics);
|
2011-04-27 10:05:43 +00:00
|
|
|
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.setFont(font);
|
|
|
|
p.drawText(QPointF(50, 50), s);
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
QStaticText text = QStaticText(s);
|
|
|
|
p.setFont(font);
|
|
|
|
p.drawStaticText(QPointF(50, 50 - QFontMetricsF(p.font()).ascent()), text);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(DEBUG_SAVE_IMAGE)
|
|
|
|
imageDrawText.save("drawStruckOutText_imageDrawText.png");
|
|
|
|
imageDrawStaticText.save("drawStruckOutText_imageDrawStaticText.png");
|
|
|
|
#endif
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
2011-04-27 10:05:43 +00:00
|
|
|
QCOMPARE(imageDrawText, imageDrawStaticText);
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::drawOverlinedText()
|
|
|
|
{
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
|
|
|
|
QString s = QString::fromLatin1("Foobar");
|
|
|
|
|
|
|
|
QFont font;
|
|
|
|
font.setOverline(true);
|
Accept error margin in QGlyphRun/QStaticText test for decorations
When calculating the width of a text for drawing decorations on top,
we use the effective advance of the whole text after it has been
through the shaper.
However, in the case of QStaticText and QGlyphRun, there is shortcut:
Since we only have the glyph indexes and position of each glyph,
we use the position + advance of the right-most glyph to find the
right-most edge of the decoration. For this, however, we use the
advance of the glyph *out of context* of the rest of the string,
because the whole idea is to avoid doing the shaping of the string
with every draw call. In some rare cases, the advance of the
right-most character, in the context of the string, is different
from the advance of the standalone glyph.
Now, one way of fixing this would be to store the width of the
text in QStaticText and QGlyphRun, but since it is a very rare
artifact which is barely visible, I have opted to just work around
it in the test instead, the workaround being to force integer
metrics so that we don't get the small 0.2 pixel error.
Task-number: QTBUG-55217
Change-Id: I8d16d52f2ef27275cabb7d3865aeeaa31617ba3d
Reviewed-by: Lars Knoll <lars.knoll@qt.io>
2017-02-02 11:29:44 +00:00
|
|
|
font.setStyleStrategy(QFont::ForceIntegerMetrics);
|
2011-04-27 10:05:43 +00:00
|
|
|
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.setFont(font);
|
|
|
|
p.drawText(QPointF(50, 50), s);
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
QStaticText text = QStaticText(s);
|
|
|
|
p.setFont(font);
|
|
|
|
p.drawStaticText(QPointF(50, 50 - QFontMetricsF(p.font()).ascent()), text);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(DEBUG_SAVE_IMAGE)
|
|
|
|
imageDrawText.save("drawOverlinedText_imageDrawText.png");
|
|
|
|
imageDrawStaticText.save("drawOverlinedText_imageDrawStaticText.png");
|
|
|
|
#endif
|
|
|
|
|
2011-08-17 23:40:55 +00:00
|
|
|
QVERIFY(imageDrawText.toImage() != m_whiteSquare);
|
2011-04-27 10:05:43 +00:00
|
|
|
QCOMPARE(imageDrawText, imageDrawStaticText);
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::drawUnderlinedText()
|
|
|
|
{
|
|
|
|
QPixmap imageDrawText(1000, 1000);
|
|
|
|
QPixmap imageDrawStaticText(1000, 1000);
|
|
|
|
|
|
|
|
imageDrawText.fill(Qt::white);
|
|
|
|
imageDrawStaticText.fill(Qt::white);
|
|
|
|
|
|
|
|
QString s = QString::fromLatin1("Foobar");
|
|
|
|
|
|
|
|
QFont font;
|
|
|
|
font.setUnderline(true);
|
Accept error margin in QGlyphRun/QStaticText test for decorations
When calculating the width of a text for drawing decorations on top,
we use the effective advance of the whole text after it has been
through the shaper.
However, in the case of QStaticText and QGlyphRun, there is shortcut:
Since we only have the glyph indexes and position of each glyph,
we use the position + advance of the right-most glyph to find the
right-most edge of the decoration. For this, however, we use the
advance of the glyph *out of context* of the rest of the string,
because the whole idea is to avoid doing the shaping of the string
with every draw call. In some rare cases, the advance of the
right-most character, in the context of the string, is different
from the advance of the standalone glyph.
Now, one way of fixing this would be to store the width of the
text in QStaticText and QGlyphRun, but since it is a very rare
artifact which is barely visible, I have opted to just work around
it in the test instead, the workaround being to force integer
metrics so that we don't get the small 0.2 pixel error.
Task-number: QTBUG-55217
Change-Id: I8d16d52f2ef27275cabb7d3865aeeaa31617ba3d
Reviewed-by: Lars Knoll <lars.knoll@qt.io>
2017-02-02 11:29:44 +00:00
|
|
|
font.setStyleStrategy(QFont::ForceIntegerMetrics);
|
2011-04-27 10:05:43 +00:00
|
|
|
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawText);
|
|
|
|
p.setFont(font);
|
|
|
|
p.drawText(QPointF(50, 50), s);
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
QPainter p(&imageDrawStaticText);
|
|
|
|
QStaticText text = QStaticText(s);
|
|
|
|
p.setFont(font);
|
|
|
|
p.drawStaticText(QPointF(50, 50 - QFontMetricsF(p.font()).ascent()), text);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(DEBUG_SAVE_IMAGE)
|
|
|
|
imageDrawText.save("drawUnderlinedText_imageDrawText.png");
|
|
|
|
imageDrawStaticText.save("drawUnderlinedText_imageDrawStaticText.png");
|
|
|
|
#endif
|
|
|
|
|
|
|
|
QCOMPARE(imageDrawText, imageDrawStaticText);
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::unprintableCharacter_qtbug12614()
|
|
|
|
{
|
|
|
|
QString s(QChar(0x200B)); // U+200B, ZERO WIDTH SPACE
|
|
|
|
|
|
|
|
QStaticText staticText(s);
|
|
|
|
|
|
|
|
QVERIFY(staticText.size().isValid()); // Force layout. Should not crash.
|
|
|
|
}
|
|
|
|
|
2016-03-10 12:15:50 +00:00
|
|
|
#ifdef QT_BUILD_INTERNAL
|
2011-06-28 15:07:13 +00:00
|
|
|
void tst_QStaticText::underlinedColor_qtbug20159()
|
|
|
|
{
|
|
|
|
QString multiScriptText;
|
|
|
|
multiScriptText += QChar(0x0410); // Cyrillic 'A'
|
|
|
|
multiScriptText += QLatin1Char('A');
|
|
|
|
|
|
|
|
QStaticText staticText(multiScriptText);
|
|
|
|
|
|
|
|
QFont font;
|
|
|
|
font.setUnderline(true);
|
|
|
|
|
|
|
|
staticText.prepare(QTransform(), font);
|
|
|
|
|
|
|
|
QStaticTextPrivate *d = QStaticTextPrivate::get(&staticText);
|
|
|
|
QCOMPARE(d->itemCount, 2);
|
|
|
|
|
|
|
|
// The pen should not be marked as dirty when drawing the underline
|
|
|
|
QVERIFY(!d->items[0].color.isValid());
|
|
|
|
QVERIFY(!d->items[1].color.isValid());
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_QStaticText::textDocumentColor()
|
|
|
|
{
|
|
|
|
QStaticText staticText("A<font color=\"red\">B</font>");
|
|
|
|
staticText.setTextFormat(Qt::RichText);
|
|
|
|
staticText.prepare();
|
|
|
|
|
|
|
|
QStaticTextPrivate *d = QStaticTextPrivate::get(&staticText);
|
|
|
|
QCOMPARE(d->itemCount, 2);
|
|
|
|
|
|
|
|
// The pen should not be marked as dirty when drawing the underline
|
|
|
|
QVERIFY(!d->items[0].color.isValid());
|
|
|
|
QVERIFY(d->items[1].color.isValid());
|
|
|
|
|
|
|
|
QCOMPARE(d->items[1].color, QColor(Qt::red));
|
|
|
|
}
|
2016-03-10 12:15:50 +00:00
|
|
|
#endif
|
2011-06-28 15:07:13 +00:00
|
|
|
|
2016-10-04 10:41:47 +00:00
|
|
|
class TestPaintEngine: public QPaintEngine
|
|
|
|
{
|
|
|
|
public:
|
2017-09-18 08:36:49 +00:00
|
|
|
void drawTextItem(const QPointF &p, const QTextItem &) override
|
2016-10-04 10:41:47 +00:00
|
|
|
{
|
|
|
|
differentVerticalPositions.insert(qRound(p.y()));
|
|
|
|
}
|
|
|
|
|
2017-09-18 08:36:49 +00:00
|
|
|
void updateState(const QPaintEngineState &) override {}
|
2016-10-04 10:41:47 +00:00
|
|
|
|
2017-09-18 08:36:49 +00:00
|
|
|
void drawPolygon(const QPointF *, int , PolygonDrawMode ) override {}
|
2016-10-04 10:41:47 +00:00
|
|
|
|
2017-09-18 08:36:49 +00:00
|
|
|
bool begin(QPaintDevice *) override { return true; }
|
|
|
|
bool end() override { return true; }
|
|
|
|
void drawPixmap(const QRectF &, const QPixmap &, const QRectF &) override {}
|
|
|
|
Type type() const override
|
2016-10-04 10:41:47 +00:00
|
|
|
{
|
|
|
|
return User;
|
|
|
|
}
|
|
|
|
|
|
|
|
QSet<int> differentVerticalPositions;
|
|
|
|
};
|
|
|
|
|
|
|
|
class TestPixmap: public QPixmap
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
TestPixmap(int w, int h) : QPixmap(w, h), testPaintEngine(new TestPaintEngine) {}
|
|
|
|
~TestPixmap() { delete testPaintEngine; }
|
|
|
|
|
|
|
|
QPaintEngine *paintEngine() const
|
|
|
|
{
|
|
|
|
return testPaintEngine;
|
|
|
|
}
|
|
|
|
|
|
|
|
TestPaintEngine *testPaintEngine;
|
|
|
|
};
|
|
|
|
|
|
|
|
void tst_QStaticText::multiLine()
|
|
|
|
{
|
|
|
|
TestPixmap pixmap(100, 100);
|
|
|
|
|
|
|
|
TestPaintEngine *paintEngine = pixmap.testPaintEngine;
|
|
|
|
|
|
|
|
{
|
|
|
|
QPainter p(&pixmap);
|
|
|
|
QStaticText text;
|
|
|
|
text.setText(QLatin1String("line 1") + QChar(QChar::LineSeparator) + QLatin1String("line 2"));
|
|
|
|
p.drawStaticText(0, 0, text);
|
|
|
|
}
|
|
|
|
|
|
|
|
QCOMPARE(paintEngine->differentVerticalPositions.size(), 2);
|
|
|
|
}
|
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
QTEST_MAIN(tst_QStaticText)
|
|
|
|
#include "tst_qstatictext.moc"
|