Skip to content

Commit

Permalink
PDF font embedding fails on Mac 64-bit due to unimplemented methods i…
Browse files Browse the repository at this point in the history
…n QCoreTextFontEngine

Fix bugs generating PDF on Cocoa

Provide real implementations of:
	properties(), faceId() and getUnscaledGlyph

Task-number: QTBUG-10094

ariya#10373
  • Loading branch information
astefanutti committed Aug 6, 2015
1 parent c718f83 commit a4d8e84
Show file tree
Hide file tree
Showing 2 changed files with 65 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -700,7 +700,12 @@ static void qcoretextfontengine_scaleMetrics(glyph_metrics_t &br, const QTransfo

QFontEngine::FaceId QCoreTextFontEngine::faceId() const
{
return QFontEngine::FaceId();
FaceId result;
result.index = 0;
QCFString name = CTFontCopyName(ctfont, kCTFontUniqueNameKey);
result.filename = QCFString::toQString(name).toUtf8();

return result;
}

bool QCoreTextFontEngine::canRender(const QChar *string, int len) const
Expand All @@ -714,9 +719,26 @@ static void qcoretextfontengine_scaleMetrics(glyph_metrics_t &br, const QTransfo
return ct_getSfntTable((void *)&ctfont, tag, buffer, length);
}

void QCoreTextFontEngine::getUnscaledGlyph(glyph_t, QPainterPath *, glyph_metrics_t *)
void QCoreTextFontEngine::getUnscaledGlyph(glyph_t glyph, QPainterPath *path, glyph_metrics_t *metric)
{
// ###
CGAffineTransform cgMatrix = CGAffineTransformIdentity;

qreal emSquare = CTFontGetUnitsPerEm(ctfont);
qreal scale = emSquare / CTFontGetSize(ctfont);
cgMatrix = CGAffineTransformScale(cgMatrix, scale, -scale);

QCFType<CGPathRef> cgpath = CTFontCreatePathForGlyph(ctfont, (CGGlyph) glyph, &cgMatrix);
ConvertPathInfo info(path, QPointF(0,0));
CGPathApply(cgpath, &info, convertCGPathToQPainterPath);

*metric = boundingBox(glyph);
// scale the metrics too
metric->width = QFixed::fromReal(metric->width.toReal() * scale);
metric->height = QFixed::fromReal(metric->height.toReal() * scale);
metric->x = QFixed::fromReal(metric->x.toReal() * scale);
metric->y = QFixed::fromReal(metric->y.toReal() * scale);
metric->xoff = QFixed::fromReal(metric->xoff.toReal() * scale);
metric->yoff = QFixed::fromReal(metric->yoff.toReal() * scale);
}

QFixed QCoreTextFontEngine::emSquareSize() const
Expand Down Expand Up @@ -744,4 +766,43 @@ static void qcoretextfontengine_scaleMetrics(glyph_metrics_t &br, const QTransfo
return false;
}

QFontEngine::Properties QCoreTextFontEngine::properties() const
{
Properties result;

QCFString psName, copyright;
psName = CTFontCopyPostScriptName(ctfont);
copyright = CTFontCopyName(ctfont, kCTFontCopyrightNameKey);
result.postscriptName = QCFString::toQString(psName).toUtf8();
result.copyright = QCFString::toQString(copyright).toUtf8();

qreal emSquare = CTFontGetUnitsPerEm(ctfont);
qreal scale = emSquare / CTFontGetSize(ctfont);

CGRect cgRect = CTFontGetBoundingBox(ctfont);
result.boundingBox = QRectF(cgRect.origin.x * scale,
-CTFontGetAscent(ctfont) * scale,
cgRect.size.width * scale,
cgRect.size.height * scale);

result.emSquare = emSquareSize();
result.ascent = QFixed::fromReal(CTFontGetAscent(ctfont) * scale);
result.descent = QFixed::fromReal(CTFontGetDescent(ctfont) * scale);
result.leading = QFixed::fromReal(CTFontGetLeading(ctfont) * scale);
result.italicAngle = QFixed::fromReal(CTFontGetSlantAngle(ctfont));
result.capHeight = QFixed::fromReal(CTFontGetCapHeight(ctfont) * scale);
result.lineWidth = QFixed::fromReal(CTFontGetUnderlineThickness(ctfont) * scale);

if (fontDef.styleStrategy & QFont::ForceIntegerMetrics) {
result.ascent = result.ascent.round();
result.descent = result.descent.round();
result.leading = result.leading.round();
result.italicAngle = result.italicAngle.round();
result.capHeight = result.capHeight.round();
result.lineWidth = result.lineWidth.round();
}

return result;
}

QT_END_NAMESPACE
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,7 @@ class QCoreTextFontEngine : public QFontEngine
bool supportsTransformation(const QTransform &transform) const;

virtual QFontEngine *cloneWithSize(qreal pixelSize) const;
virtual QFontEngine::Properties properties() const;
virtual int glyphMargin(QFontEngine::GlyphFormat format) { Q_UNUSED(format); return 0; }

static bool supportsColorGlyphs()
Expand Down

0 comments on commit a4d8e84

Please sign in to comment.