REG: Fix crash when mixing projected/unprojected text painting
Due to a refactoring done in Qt 5.1, we would try to do projected text painting using the glyph cache in the raster engine (the logic to avoid this was removed when refactoring). If you only did the projected text drawing, then you would get unprojected text with projected glyph positions and it would look wrong. What's worse: If you first drew unprojected text with the same font engine, so that the font engine already had a glyph cache stored, we would hit an assert in qtransform_equals_no_translate which assumes cached drawing is never used for projected painters. This puts back the logic that we never cache projected text in the glyph cache. Task-number: QTBUG-32193 Change-Id: I1f919961c4cf498a9c4a0b1ceb0df1937ed0d067 Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@digia.com>
This commit is contained in:
parent
568f82fba3
commit
b5520af6a9
@ -3327,6 +3327,10 @@ bool QRasterPaintEngine::requiresPretransformedGlyphPositions(QFontEngine *fontE
|
|||||||
|
|
||||||
bool QRasterPaintEngine::shouldDrawCachedGlyphs(QFontEngine *fontEngine, const QTransform &m) const
|
bool QRasterPaintEngine::shouldDrawCachedGlyphs(QFontEngine *fontEngine, const QTransform &m) const
|
||||||
{
|
{
|
||||||
|
// The raster engine does not support projected cached glyph drawing
|
||||||
|
if (m.type() >= QTransform::TxProject)
|
||||||
|
return false;
|
||||||
|
|
||||||
// The font engine might not support filling the glyph cache
|
// The font engine might not support filling the glyph cache
|
||||||
// with the given transform applied, in which case we need to
|
// with the given transform applied, in which case we need to
|
||||||
// fall back to the QPainterPath code-path.
|
// fall back to the QPainterPath code-path.
|
||||||
|
Loading…
Reference in New Issue
Block a user