dwrite: Store font style provided in LOGFONT data.
This commit is contained in:
parent
56d71b04b7
commit
09ba9bdb0a
|
@ -27,4 +27,4 @@ static inline BOOL heap_free(void *mem)
|
||||||
}
|
}
|
||||||
|
|
||||||
extern HRESULT create_gdiinterop(IDWriteGdiInterop**) DECLSPEC_HIDDEN;
|
extern HRESULT create_gdiinterop(IDWriteGdiInterop**) DECLSPEC_HIDDEN;
|
||||||
extern HRESULT create_font(IDWriteFont**) DECLSPEC_HIDDEN;
|
extern HRESULT create_font_from_logfont(const LOGFONTW*, IDWriteFont**) DECLSPEC_HIDDEN;
|
||||||
|
|
|
@ -30,6 +30,8 @@ WINE_DEFAULT_DEBUG_CHANNEL(dwrite);
|
||||||
struct dwrite_font {
|
struct dwrite_font {
|
||||||
IDWriteFont IDWriteFont_iface;
|
IDWriteFont IDWriteFont_iface;
|
||||||
LONG ref;
|
LONG ref;
|
||||||
|
|
||||||
|
DWRITE_FONT_STYLE style;
|
||||||
};
|
};
|
||||||
|
|
||||||
static inline struct dwrite_font *impl_from_IDWriteFont(IDWriteFont *iface)
|
static inline struct dwrite_font *impl_from_IDWriteFont(IDWriteFont *iface)
|
||||||
|
@ -86,7 +88,7 @@ static DWRITE_FONT_WEIGHT WINAPI dwritefont_GetWeight(IDWriteFont *iface)
|
||||||
{
|
{
|
||||||
struct dwrite_font *This = impl_from_IDWriteFont(iface);
|
struct dwrite_font *This = impl_from_IDWriteFont(iface);
|
||||||
FIXME("(%p): stub\n", This);
|
FIXME("(%p): stub\n", This);
|
||||||
return DWRITE_FONT_WEIGHT_NORMAL;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static DWRITE_FONT_STRETCH WINAPI dwritefont_GetStretch(IDWriteFont *iface)
|
static DWRITE_FONT_STRETCH WINAPI dwritefont_GetStretch(IDWriteFont *iface)
|
||||||
|
@ -99,8 +101,8 @@ static DWRITE_FONT_STRETCH WINAPI dwritefont_GetStretch(IDWriteFont *iface)
|
||||||
static DWRITE_FONT_STYLE WINAPI dwritefont_GetStyle(IDWriteFont *iface)
|
static DWRITE_FONT_STYLE WINAPI dwritefont_GetStyle(IDWriteFont *iface)
|
||||||
{
|
{
|
||||||
struct dwrite_font *This = impl_from_IDWriteFont(iface);
|
struct dwrite_font *This = impl_from_IDWriteFont(iface);
|
||||||
FIXME("(%p): stub\n", This);
|
TRACE("(%p)\n", This);
|
||||||
return DWRITE_FONT_STYLE_NORMAL;
|
return This->style;
|
||||||
}
|
}
|
||||||
|
|
||||||
static BOOL WINAPI dwritefont_IsSymbolFont(IDWriteFont *iface)
|
static BOOL WINAPI dwritefont_IsSymbolFont(IDWriteFont *iface)
|
||||||
|
@ -169,15 +171,20 @@ static const IDWriteFontVtbl dwritefontvtbl = {
|
||||||
dwritefont_CreateFontFace
|
dwritefont_CreateFontFace
|
||||||
};
|
};
|
||||||
|
|
||||||
HRESULT create_font(IDWriteFont **font)
|
HRESULT create_font_from_logfont(const LOGFONTW *logfont, IDWriteFont **font)
|
||||||
{
|
{
|
||||||
struct dwrite_font *This;
|
struct dwrite_font *This;
|
||||||
|
|
||||||
|
*font = NULL;
|
||||||
|
|
||||||
This = heap_alloc(sizeof(struct dwrite_font));
|
This = heap_alloc(sizeof(struct dwrite_font));
|
||||||
if (!This) return E_OUTOFMEMORY;
|
if (!This) return E_OUTOFMEMORY;
|
||||||
|
|
||||||
This->IDWriteFont_iface.lpVtbl = &dwritefontvtbl;
|
This->IDWriteFont_iface.lpVtbl = &dwritefontvtbl;
|
||||||
This->ref = 1;
|
This->ref = 1;
|
||||||
|
|
||||||
|
This->style = logfont->lfItalic ? DWRITE_FONT_STYLE_ITALIC : DWRITE_FONT_STYLE_NORMAL;
|
||||||
|
|
||||||
*font = &This->IDWriteFont_iface;
|
*font = &This->IDWriteFont_iface;
|
||||||
|
|
||||||
return S_OK;
|
return S_OK;
|
||||||
|
|
|
@ -57,11 +57,11 @@ static ULONG WINAPI gdiinterop_Release(IDWriteGdiInterop *iface)
|
||||||
static HRESULT WINAPI gdiinterop_CreateFontFromLOGFONT(IDWriteGdiInterop *iface,
|
static HRESULT WINAPI gdiinterop_CreateFontFromLOGFONT(IDWriteGdiInterop *iface,
|
||||||
LOGFONTW const *logfont, IDWriteFont **font)
|
LOGFONTW const *logfont, IDWriteFont **font)
|
||||||
{
|
{
|
||||||
FIXME("(%p %p): stub\n", logfont, font);
|
TRACE("(%p %p)\n", logfont, font);
|
||||||
|
|
||||||
if (!logfont) return E_INVALIDARG;
|
if (!logfont) return E_INVALIDARG;
|
||||||
|
|
||||||
return create_font(font);
|
return create_font_from_logfont(logfont, font);
|
||||||
}
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI gdiinterop_ConvertFontToLOGFONT(IDWriteGdiInterop *iface,
|
static HRESULT WINAPI gdiinterop_ConvertFontToLOGFONT(IDWriteGdiInterop *iface,
|
||||||
|
|
|
@ -30,18 +30,35 @@
|
||||||
#define EXPECT_HR(hr,hr_exp) \
|
#define EXPECT_HR(hr,hr_exp) \
|
||||||
ok(hr == hr_exp, "got 0x%08x, expected 0x%08x\n", hr, hr_exp)
|
ok(hr == hr_exp, "got 0x%08x, expected 0x%08x\n", hr, hr_exp)
|
||||||
|
|
||||||
IDWriteFactory *factory;
|
static IDWriteFactory *factory;
|
||||||
|
|
||||||
static void test_CreateFontFromLOGFONT(void)
|
static void test_CreateFontFromLOGFONT(void)
|
||||||
{
|
{
|
||||||
static const WCHAR arialW[] = {'A','r','i','a','l',0};
|
static const WCHAR arialW[] = {'A','r','i','a','l',0};
|
||||||
|
static const WCHAR blahW[] = {'B','l','a','h','!',0};
|
||||||
IDWriteGdiInterop *interop;
|
IDWriteGdiInterop *interop;
|
||||||
DWRITE_FONT_WEIGHT weight;
|
DWRITE_FONT_WEIGHT weight;
|
||||||
DWRITE_FONT_STYLE style;
|
DWRITE_FONT_STYLE style;
|
||||||
IDWriteFont *font;
|
IDWriteFont *font;
|
||||||
LOGFONTW logfont;
|
LOGFONTW logfont;
|
||||||
|
LONG weights[][2] = {
|
||||||
|
{FW_NORMAL, DWRITE_FONT_WEIGHT_NORMAL},
|
||||||
|
{FW_BOLD, DWRITE_FONT_WEIGHT_BOLD},
|
||||||
|
{ 0, DWRITE_FONT_WEIGHT_NORMAL},
|
||||||
|
{ 50, DWRITE_FONT_WEIGHT_NORMAL},
|
||||||
|
{150, DWRITE_FONT_WEIGHT_NORMAL},
|
||||||
|
{250, DWRITE_FONT_WEIGHT_NORMAL},
|
||||||
|
{350, DWRITE_FONT_WEIGHT_NORMAL},
|
||||||
|
{450, DWRITE_FONT_WEIGHT_NORMAL},
|
||||||
|
{650, DWRITE_FONT_WEIGHT_BOLD},
|
||||||
|
{750, DWRITE_FONT_WEIGHT_BOLD},
|
||||||
|
{850, DWRITE_FONT_WEIGHT_BOLD},
|
||||||
|
{950, DWRITE_FONT_WEIGHT_BOLD},
|
||||||
|
{960, DWRITE_FONT_WEIGHT_BOLD},
|
||||||
|
};
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
BOOL ret;
|
BOOL ret;
|
||||||
|
int i;
|
||||||
|
|
||||||
hr = IDWriteFactory_GetGdiInterop(factory, &interop);
|
hr = IDWriteFactory_GetGdiInterop(factory, &interop);
|
||||||
EXPECT_HR(hr, S_OK);
|
EXPECT_HR(hr, S_OK);
|
||||||
|
@ -65,10 +82,10 @@ if (0)
|
||||||
|
|
||||||
/* now check properties */
|
/* now check properties */
|
||||||
weight = IDWriteFont_GetWeight(font);
|
weight = IDWriteFont_GetWeight(font);
|
||||||
|
todo_wine
|
||||||
ok(weight == DWRITE_FONT_WEIGHT_NORMAL, "got %d\n", weight);
|
ok(weight == DWRITE_FONT_WEIGHT_NORMAL, "got %d\n", weight);
|
||||||
|
|
||||||
style = IDWriteFont_GetStyle(font);
|
style = IDWriteFont_GetStyle(font);
|
||||||
todo_wine
|
|
||||||
ok(style == DWRITE_FONT_STYLE_ITALIC, "got %d\n", style);
|
ok(style == DWRITE_FONT_STYLE_ITALIC, "got %d\n", style);
|
||||||
|
|
||||||
ret = IDWriteFont_IsSymbolFont(font);
|
ret = IDWriteFont_IsSymbolFont(font);
|
||||||
|
@ -76,6 +93,61 @@ todo_wine
|
||||||
|
|
||||||
IDWriteFont_Release(font);
|
IDWriteFont_Release(font);
|
||||||
|
|
||||||
|
/* weight values */
|
||||||
|
for (i = 0; i < sizeof(weights)/(2*sizeof(LONG)); i++)
|
||||||
|
{
|
||||||
|
memset(&logfont, 0, sizeof(logfont));
|
||||||
|
logfont.lfHeight = 12;
|
||||||
|
logfont.lfWidth = 12;
|
||||||
|
logfont.lfWeight = weights[i][0];
|
||||||
|
lstrcpyW(logfont.lfFaceName, arialW);
|
||||||
|
|
||||||
|
hr = IDWriteGdiInterop_CreateFontFromLOGFONT(interop, &logfont, &font);
|
||||||
|
EXPECT_HR(hr, S_OK);
|
||||||
|
|
||||||
|
weight = IDWriteFont_GetWeight(font);
|
||||||
|
todo_wine
|
||||||
|
ok(weight == weights[i][1],
|
||||||
|
"%d: got %d, expected %d\n", i, weight, weights[i][1]);
|
||||||
|
IDWriteFont_Release(font);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* weight not from enum */
|
||||||
|
memset(&logfont, 0, sizeof(logfont));
|
||||||
|
logfont.lfHeight = 12;
|
||||||
|
logfont.lfWidth = 12;
|
||||||
|
logfont.lfWeight = 550;
|
||||||
|
lstrcpyW(logfont.lfFaceName, arialW);
|
||||||
|
|
||||||
|
hr = IDWriteGdiInterop_CreateFontFromLOGFONT(interop, &logfont, &font);
|
||||||
|
EXPECT_HR(hr, S_OK);
|
||||||
|
|
||||||
|
weight = IDWriteFont_GetWeight(font);
|
||||||
|
todo_wine
|
||||||
|
ok(weight == DWRITE_FONT_WEIGHT_NORMAL || broken(weight == DWRITE_FONT_WEIGHT_BOLD) /* win7 w/o SP */,
|
||||||
|
"got %d\n", weight);
|
||||||
|
IDWriteFont_Release(font);
|
||||||
|
|
||||||
|
/* empty or nonexistent face name */
|
||||||
|
memset(&logfont, 0, sizeof(logfont));
|
||||||
|
logfont.lfHeight = 12;
|
||||||
|
logfont.lfWidth = 12;
|
||||||
|
logfont.lfWeight = FW_NORMAL;
|
||||||
|
lstrcpyW(logfont.lfFaceName, blahW);
|
||||||
|
|
||||||
|
hr = IDWriteGdiInterop_CreateFontFromLOGFONT(interop, &logfont, &font);
|
||||||
|
todo_wine
|
||||||
|
EXPECT_HR(hr, DWRITE_E_NOFONT);
|
||||||
|
|
||||||
|
memset(&logfont, 0, sizeof(logfont));
|
||||||
|
logfont.lfHeight = 12;
|
||||||
|
logfont.lfWidth = 12;
|
||||||
|
logfont.lfWeight = FW_NORMAL;
|
||||||
|
|
||||||
|
hr = IDWriteGdiInterop_CreateFontFromLOGFONT(interop, &logfont, &font);
|
||||||
|
todo_wine
|
||||||
|
EXPECT_HR(hr, DWRITE_E_NOFONT);
|
||||||
|
|
||||||
IDWriteGdiInterop_Release(interop);
|
IDWriteGdiInterop_Release(interop);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1394,3 +1394,17 @@ interface IDWriteFactory : IUnknown
|
||||||
}
|
}
|
||||||
|
|
||||||
cpp_quote("HRESULT WINAPI DWriteCreateFactory(DWRITE_FACTORY_TYPE,REFIID,IUnknown**);")
|
cpp_quote("HRESULT WINAPI DWriteCreateFactory(DWRITE_FACTORY_TYPE,REFIID,IUnknown**);")
|
||||||
|
|
||||||
|
/* error codes */
|
||||||
|
cpp_quote("#define FACILITY_DWRITE 0x898")
|
||||||
|
cpp_quote("#define DWRITE_ERR_BASE 0x5000")
|
||||||
|
cpp_quote("#define MAKE_DWRITE_HR(severity, code) MAKE_HRESULT(severity, FACILITY_DWRITE, (DWRITE_ERR_BASE + code))")
|
||||||
|
cpp_quote("#define MAKE_DWRITE_HR_ERR(code) MAKE_DWRITE_HR(SEVERITY_ERROR, code)")
|
||||||
|
|
||||||
|
cpp_quote("#define DWRITE_E_FILEFORMAT MAKE_DWRITE_HR_ERR(0x0)")
|
||||||
|
cpp_quote("#define DWRITE_E_UNEXPECTED MAKE_DWRITE_HR_ERR(0x1)")
|
||||||
|
cpp_quote("#define DWRITE_E_NOFONT MAKE_DWRITE_HR_ERR(0x2)")
|
||||||
|
cpp_quote("#define DWRITE_E_FILENOTFOUND MAKE_DWRITE_HR_ERR(0x3)")
|
||||||
|
cpp_quote("#define DWRITE_E_FILEACCESS MAKE_DWRITE_HR_ERR(0x4)")
|
||||||
|
cpp_quote("#define DWRITE_E_FONTCOLLECTIONOBSOLETE MAKE_DWRITE_HR_ERR(0x5)")
|
||||||
|
cpp_quote("#define DWRITE_E_ALREADYREGISTERED MAKE_DWRITE_HR_ERR(0x6)")
|
||||||
|
|
Loading…
Reference in New Issue