diff options
author | Eskil Abrahamsen Blomfeldt <eblomfel@trolltech.com> | 2009-05-19 14:48:16 (GMT) |
---|---|---|
committer | Eskil Abrahamsen Blomfeldt <eskil.abrahamsen-blomfeldt@nokia.com> | 2010-01-14 12:45:26 (GMT) |
commit | 26372057d92564da9baf6d17c685fd1b22ff4b8a (patch) | |
tree | 000c726950e7251a706ff294a211c886cd8731ec /src/gui/painting/qpainter.cpp | |
parent | 5d0f93a3d6d3d99d86d181ee3cc559a6782be4ee (diff) | |
download | Qt-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.cpp | 27 |
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); } /*! |