Remove DirectWrite warning when loading bitmap fonts
We use DirectWrite to determine whether a font is a color font or not, so all fonts go through DirectWrite initially. However, the load call will fail for bitmap fonts, causing us to output lots of pointless warnings each time such a font was in use. Instead, we only output this warning if we actually plan to load the font through DirectWrite later. If the load fails, we can assume it is not a color font and do not need to output any warning for this. [ChangeLog][Windows][Text] Removed confusing DirectWrite warning when loading bitmap fonts. Task-number: QTBUG-57180 Change-Id: Iaac8117745ef05a1dff23b346dbe0c6dbfb315f7 Reviewed-by: Friedemann Kleint <Friedemann.Kleint@qt.io>
This commit is contained in:
parent
a3f575484a
commit
c4a524f3a1
@ -1930,13 +1930,13 @@ QFontEngine *QWindowsFontDatabase::createEngine(const QFontDef &request, const Q
|
|||||||
} else {
|
} else {
|
||||||
HGDIOBJ oldFont = SelectObject(data->hdc, hfont);
|
HGDIOBJ oldFont = SelectObject(data->hdc, hfont);
|
||||||
|
|
||||||
|
const QFont::HintingPreference hintingPreference =
|
||||||
|
static_cast<QFont::HintingPreference>(request.hintingPreference);
|
||||||
|
bool useDw = useDirectWrite(hintingPreference, fam);
|
||||||
|
|
||||||
IDWriteFontFace *directWriteFontFace = NULL;
|
IDWriteFontFace *directWriteFontFace = NULL;
|
||||||
HRESULT hr = data->directWriteGdiInterop->CreateFontFaceFromHdc(data->hdc, &directWriteFontFace);
|
HRESULT hr = data->directWriteGdiInterop->CreateFontFaceFromHdc(data->hdc, &directWriteFontFace);
|
||||||
if (FAILED(hr)) {
|
if (SUCCEEDED(hr)) {
|
||||||
const QString errorString = qt_error_string(int(hr));
|
|
||||||
qWarning().noquote().nospace() << "DirectWrite: CreateFontFaceFromHDC() failed ("
|
|
||||||
<< errorString << ") for " << request << ' ' << lf << " dpi=" << dpi;
|
|
||||||
} else {
|
|
||||||
bool isColorFont = false;
|
bool isColorFont = false;
|
||||||
#if defined(QT_USE_DIRECTWRITE2)
|
#if defined(QT_USE_DIRECTWRITE2)
|
||||||
IDWriteFontFace2 *directWriteFontFace2 = nullptr;
|
IDWriteFontFace2 *directWriteFontFace2 = nullptr;
|
||||||
@ -1946,9 +1946,7 @@ QFontEngine *QWindowsFontDatabase::createEngine(const QFontDef &request, const Q
|
|||||||
isColorFont = directWriteFontFace2->GetPaletteEntryCount() > 0;
|
isColorFont = directWriteFontFace2->GetPaletteEntryCount() > 0;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
const QFont::HintingPreference hintingPreference =
|
useDw = useDw || useDirectWrite(hintingPreference, fam, isColorFont);
|
||||||
static_cast<QFont::HintingPreference>(request.hintingPreference);
|
|
||||||
const bool useDw = useDirectWrite(hintingPreference, fam, isColorFont);
|
|
||||||
qCDebug(lcQpaFonts) << __FUNCTION__ << request.family << request.pointSize
|
qCDebug(lcQpaFonts) << __FUNCTION__ << request.family << request.pointSize
|
||||||
<< "pt" << "hintingPreference=" << hintingPreference << "color=" << isColorFont
|
<< "pt" << "hintingPreference=" << hintingPreference << "color=" << isColorFont
|
||||||
<< dpi << "dpi" << "useDirectWrite=" << useDw;
|
<< dpi << "dpi" << "useDirectWrite=" << useDw;
|
||||||
@ -1970,6 +1968,10 @@ QFontEngine *QWindowsFontDatabase::createEngine(const QFontDef &request, const Q
|
|||||||
} else {
|
} else {
|
||||||
directWriteFontFace->Release();
|
directWriteFontFace->Release();
|
||||||
}
|
}
|
||||||
|
} else if (useDw) {
|
||||||
|
const QString errorString = qt_error_string(int(hr));
|
||||||
|
qWarning().noquote().nospace() << "DirectWrite: CreateFontFaceFromHDC() failed ("
|
||||||
|
<< errorString << ") for " << request << ' ' << lf << " dpi=" << dpi;
|
||||||
}
|
}
|
||||||
|
|
||||||
SelectObject(data->hdc, oldFont);
|
SelectObject(data->hdc, oldFont);
|
||||||
|
Loading…
Reference in New Issue
Block a user