summaryrefslogtreecommitdiffstats
path: root/src/gui/painting/qpainter.cpp
diff options
context:
space:
mode:
authorEskil Abrahamsen Blomfeldt <eblomfel@trolltech.com>2009-05-19 14:48:16 (GMT)
committerEskil Abrahamsen Blomfeldt <eskil.abrahamsen-blomfeldt@nokia.com>2010-01-14 12:45:26 (GMT)
commit26372057d92564da9baf6d17c685fd1b22ff4b8a (patch)
tree000c726950e7251a706ff294a211c886cd8731ec /src/gui/painting/qpainter.cpp
parent5d0f93a3d6d3d99d86d181ee3cc559a6782be4ee (diff)
downloadQt-26372057d92564da9baf6d17c685fd1b22ff4b8a.zip
Qt-26372057d92564da9baf6d17c685fd1b22ff4b8a.tar.gz
Qt-26372057d92564da9baf6d17c685fd1b22ff4b8a.tar.bz2
Simplify QStaticText
Not much to gain by going directly to the QTextEngine, and the code is a lot simpler if we just use the QTextLayout instead.
Diffstat (limited to 'src/gui/painting/qpainter.cpp')
-rw-r--r--src/gui/painting/qpainter.cpp27
1 files changed, 2 insertions, 25 deletions
diff --git a/src/gui/painting/qpainter.cpp b/src/gui/painting/qpainter.cpp
index f5bd2c5..a890d63 100644
--- a/src/gui/painting/qpainter.cpp
+++ b/src/gui/painting/qpainter.cpp
@@ -5707,32 +5707,9 @@ void QPainter::drawText(const QPointF &p, const QString &str)
void QPainter::drawStaticText(const QPointF &p, const QStaticText &staticText)
{
const QStaticTextPrivate *staticText_d = QStaticTextPrivate::get(&staticText);
- const QTextEngine &engine = staticText_d->engine;
- const QVarLengthArray<int> &visualOrder = staticText_d->visualOrder;
+ QTextLayout *textLayout = staticText_d->textLayout;
- QFixed x = QFixed::fromReal(p.x());
- QFixed ox = x;
-
- int nItems = engine.layoutData->items.size();
- for (int i = 0; i < nItems; ++i) {
- int item = visualOrder[i];
- const QScriptItem &si = engine.layoutData->items.at(item);
- if (si.analysis.flags >= QScriptAnalysis::TabOrObject) {
- x += si.width;
- continue;
- }
- QFont f = engine.font(si);
- QTextItemInt gf(si, &f);
- gf.glyphs = engine.shapedGlyphs(&si);
- gf.chars = engine.layoutData->string.unicode() + si.position;
- gf.num_chars = engine.length(item);
- gf.width = si.width;
- gf.logClusters = engine.logClusters(&si);
-
- drawTextItem(QPointF(x.toReal(), p.y()), gf);
-
- x += si.width;
- }
+ textLayout->draw(this, p);
}
/*!