mirror of
https://github.com/reactos/reactos.git
synced 2025-01-01 03:54:02 +00:00
Win32/Gdi32:
- Implement NtGdiHfontCreate, removed NtGdiCreateFont and NtGdiCreateFontIndirect from service. Changed name to NtGdiGetOutlineTextMetricsInternalW. - Updated TEXTOBJ structure changing LOGFONTW to ENUMLOGFONTEXDVW. - Update FontGetObject plus the rest of text.c in win32k. - Added CreateFontIndirectExA/W to psdk/wingdi.h, it was missing. Tested with Qemu. svn path=/trunk/; revision=26530
This commit is contained in:
parent
9e76cf5867
commit
3b4b572193
8 changed files with 218 additions and 82 deletions
|
@ -277,9 +277,20 @@ HFONT
|
|||
STDCALL
|
||||
CreateFontIndirectExA(const ENUMLOGFONTEXDVA *elfexd)
|
||||
{
|
||||
UNIMPLEMENTED;
|
||||
SetLastError(ERROR_CALL_NOT_IMPLEMENTED);
|
||||
return 0;
|
||||
if (elfexd)
|
||||
{
|
||||
ENUMLOGFONTEXDVW Logfont;
|
||||
|
||||
EnumLogFontExW2A( (LPENUMLOGFONTEXA) elfexd,
|
||||
&Logfont.elfEnumLogfontEx );
|
||||
|
||||
RtlCopyMemory( &Logfont.elfDesignVector,
|
||||
(PVOID) &elfexd->elfDesignVector,
|
||||
sizeof(DESIGNVECTOR));
|
||||
|
||||
return NtGdiHfontCreate( &Logfont, 0, 0, 0, NULL);
|
||||
}
|
||||
else return NULL;
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
|
@ -353,9 +353,11 @@ HFONT
|
|||
STDCALL
|
||||
CreateFontIndirectExW(const ENUMLOGFONTEXDVW *elfexd)
|
||||
{
|
||||
UNIMPLEMENTED;
|
||||
SetLastError(ERROR_CALL_NOT_IMPLEMENTED);
|
||||
return 0;
|
||||
if ( elfexd )
|
||||
{
|
||||
return NtGdiHfontCreate((PENUMLOGFONTEXDVW) elfexd, 0, 0, 0, NULL );
|
||||
}
|
||||
else return NULL;
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
|
@ -282,7 +282,7 @@ IntEnumFontFamilies(HDC Dc, LPLOGFONTW LogFont, PVOID EnumProc, LPARAM lParam,
|
|||
Info[i].FontType, lParam);
|
||||
}
|
||||
else
|
||||
{
|
||||
{ // Could use EnumLogFontExW2A here?
|
||||
LogFontW2A(&EnumLogFontExA.elfLogFont, &Info[i].EnumLogFontEx.elfLogFont);
|
||||
WideCharToMultiByte(CP_THREAD_ACP, 0, Info[i].EnumLogFontEx.elfFullName, -1,
|
||||
(LPSTR)EnumLogFontExA.elfFullName, LF_FULLFACESIZE, NULL, NULL);
|
||||
|
@ -814,10 +814,9 @@ GetOutlineTextMetricsW(
|
|||
LPOUTLINETEXTMETRICW lpOTM
|
||||
)
|
||||
{
|
||||
return NtGdiGetOutlineTextMetrics(hdc, cbData, lpOTM);
|
||||
// TMDIFF Tmd; // Should not be zero.
|
||||
// if ( lpOTM == NULL) return 0;
|
||||
// return NtGdiGetOutlineTextMetricsInternalW(hdc, cbData, lpOTM, &Tmd);
|
||||
TMDIFF Tmd; // Should not be zero.
|
||||
|
||||
return NtGdiGetOutlineTextMetricsInternalW(hdc, cbData, lpOTM, &Tmd);
|
||||
}
|
||||
|
||||
|
||||
|
@ -830,14 +829,14 @@ CreateFontIndirectA(
|
|||
CONST LOGFONTA *lplf
|
||||
)
|
||||
{
|
||||
LOGFONTW tlf;
|
||||
|
||||
if (lplf)
|
||||
{
|
||||
LOGFONTW tlf;
|
||||
|
||||
LogFontA2W(&tlf, lplf);
|
||||
return NtGdiCreateFontIndirect(&tlf);
|
||||
return CreateFontIndirectW(&tlf);
|
||||
}
|
||||
else return NtGdiCreateFontIndirect(NULL);
|
||||
else return NULL;
|
||||
}
|
||||
|
||||
|
||||
|
@ -850,7 +849,25 @@ CreateFontIndirectW(
|
|||
CONST LOGFONTW *lplf
|
||||
)
|
||||
{
|
||||
return NtGdiCreateFontIndirect((CONST LPLOGFONTW)lplf);
|
||||
if (lplf)
|
||||
{
|
||||
ENUMLOGFONTEXDVW Logfont;
|
||||
|
||||
RtlCopyMemory( &Logfont.elfEnumLogfontEx.elfLogFont, lplf, sizeof(LOGFONTW));
|
||||
// Need something other than just cleaning memory here.
|
||||
// Guess? Use caller data to determine the rest.
|
||||
RtlZeroMemory( &Logfont.elfEnumLogfontEx.elfFullName,
|
||||
sizeof(Logfont.elfEnumLogfontEx.elfFullName));
|
||||
RtlZeroMemory( &Logfont.elfEnumLogfontEx.elfStyle,
|
||||
sizeof(Logfont.elfEnumLogfontEx.elfStyle));
|
||||
RtlZeroMemory( &Logfont.elfEnumLogfontEx.elfScript,
|
||||
sizeof(Logfont.elfEnumLogfontEx.elfScript));
|
||||
|
||||
RtlZeroMemory( &Logfont.elfDesignVector, sizeof(DESIGNVECTOR));
|
||||
|
||||
return CreateFontIndirectExW(&Logfont);
|
||||
}
|
||||
else return NULL;
|
||||
}
|
||||
|
||||
|
||||
|
@ -883,8 +900,20 @@ CreateFontA(
|
|||
RtlInitAnsiString(&StringA, (LPSTR)lpszFace);
|
||||
RtlAnsiStringToUnicodeString(&StringU, &StringA, TRUE);
|
||||
|
||||
ret = CreateFontW(nHeight, nWidth, nEscapement, nOrientation, fnWeight, fdwItalic, fdwUnderline, fdwStrikeOut,
|
||||
fdwCharSet, fdwOutputPrecision, fdwClipPrecision, fdwQuality, fdwPitchAndFamily, StringU.Buffer);
|
||||
ret = CreateFontW(nHeight,
|
||||
nWidth,
|
||||
nEscapement,
|
||||
nOrientation,
|
||||
fnWeight,
|
||||
fdwItalic,
|
||||
fdwUnderline,
|
||||
fdwStrikeOut,
|
||||
fdwCharSet,
|
||||
fdwOutputPrecision,
|
||||
fdwClipPrecision,
|
||||
fdwQuality,
|
||||
fdwPitchAndFamily,
|
||||
StringU.Buffer);
|
||||
|
||||
RtlFreeUnicodeString(&StringU);
|
||||
|
||||
|
@ -914,8 +943,35 @@ CreateFontW(
|
|||
LPCWSTR lpszFace
|
||||
)
|
||||
{
|
||||
return NtGdiCreateFont(nHeight, nWidth, nEscapement, nOrientation, nWeight, fnItalic, fdwUnderline, fdwStrikeOut,
|
||||
fdwCharSet, fdwOutputPrecision, fdwClipPrecision, fdwQuality, fdwPitchAndFamily, lpszFace);
|
||||
LOGFONTW logfont;
|
||||
|
||||
logfont.lfHeight = nHeight;
|
||||
logfont.lfWidth = nWidth;
|
||||
logfont.lfEscapement = nEscapement;
|
||||
logfont.lfOrientation = nOrientation;
|
||||
logfont.lfWeight = nWeight;
|
||||
logfont.lfItalic = fnItalic;
|
||||
logfont.lfUnderline = fdwUnderline;
|
||||
logfont.lfStrikeOut = fdwStrikeOut;
|
||||
logfont.lfCharSet = fdwCharSet;
|
||||
logfont.lfOutPrecision = fdwOutputPrecision;
|
||||
logfont.lfClipPrecision = fdwClipPrecision;
|
||||
logfont.lfQuality = fdwQuality;
|
||||
logfont.lfPitchAndFamily = fdwPitchAndFamily;
|
||||
|
||||
if (NULL != lpszFace)
|
||||
{
|
||||
int Size = sizeof(logfont.lfFaceName) / sizeof(WCHAR);
|
||||
wcsncpy((wchar_t *)logfont.lfFaceName, lpszFace, Size - 1);
|
||||
/* Be 101% sure to have '\0' at end of string */
|
||||
logfont.lfFaceName[Size - 1] = '\0';
|
||||
}
|
||||
else
|
||||
{
|
||||
logfont.lfFaceName[0] = L'\0';
|
||||
}
|
||||
|
||||
return CreateFontIndirectW(&logfont);
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -390,13 +390,13 @@ EnumLogFontExW2A( LPENUMLOGFONTEXA fontA, CONST ENUMLOGFONTEXW *fontW )
|
|||
{
|
||||
LogFontW2A( (LPLOGFONTA)fontA, (CONST LOGFONTW *)fontW );
|
||||
|
||||
WideCharToMultiByte( CP_ACP, 0, fontW->elfFullName, -1,
|
||||
WideCharToMultiByte( CP_THREAD_ACP, 0, fontW->elfFullName, -1,
|
||||
(LPSTR) fontA->elfFullName, LF_FULLFACESIZE, NULL, NULL );
|
||||
fontA->elfFullName[LF_FULLFACESIZE-1] = '\0';
|
||||
WideCharToMultiByte( CP_ACP, 0, fontW->elfStyle, -1,
|
||||
WideCharToMultiByte( CP_THREAD_ACP, 0, fontW->elfStyle, -1,
|
||||
(LPSTR) fontA->elfStyle, LF_FACESIZE, NULL, NULL );
|
||||
fontA->elfStyle[LF_FACESIZE-1] = '\0';
|
||||
WideCharToMultiByte( CP_ACP, 0, fontW->elfScript, -1,
|
||||
WideCharToMultiByte( CP_THREAD_ACP, 0, fontW->elfScript, -1,
|
||||
(LPSTR) fontA->elfScript, LF_FACESIZE, NULL, NULL );
|
||||
fontA->elfScript[LF_FACESIZE-1] = '\0';
|
||||
}
|
||||
|
|
|
@ -2651,6 +2651,8 @@ HFONT WINAPI CreateFontA(int,int,int,int,int,DWORD,DWORD,DWORD,DWORD,DWORD,DWORD
|
|||
HFONT WINAPI CreateFontW(int,int,int,int,int,DWORD,DWORD,DWORD,DWORD,DWORD,DWORD,DWORD,DWORD,LPCWSTR);
|
||||
HFONT WINAPI CreateFontIndirectA(const LOGFONTA*);
|
||||
HFONT WINAPI CreateFontIndirectW(const LOGFONTW*);
|
||||
HFONT WINAPI CreateFontIndirectExA(const ENUMLOGFONTEXDVA *);
|
||||
HFONT WINAPI CreateFontIndirectExW(const ENUMLOGFONTEXDVW *);
|
||||
HPALETTE WINAPI CreateHalftonePalette(HDC);
|
||||
HBRUSH WINAPI CreateHatchBrush(int,COLORREF);
|
||||
HDC WINAPI CreateICA(LPCSTR,LPCSTR,LPCSTR,const DEVMODEA*);
|
||||
|
@ -2997,6 +2999,7 @@ typedef DISPLAY_DEVICEW DISPLAY_DEVICE, *PDISPLAY_DEVICE, *LPDISPLAY_DEVICE;
|
|||
#define CreateEnhMetaFile CreateEnhMetaFileW
|
||||
#define CreateFont CreateFontW
|
||||
#define CreateFontIndirect CreateFontIndirectW
|
||||
#define CreateFontIndirectEx CreateFontIndirectExW
|
||||
#define CreateIC CreateICW
|
||||
#define CreateMetaFile CreateMetaFileW
|
||||
#define CreateScalableFontResource CreateScalableFontResourceW
|
||||
|
@ -3069,6 +3072,7 @@ typedef DISPLAY_DEVICEA DISPLAY_DEVICE, *PDISPLAY_DEVICE, *LPDISPLAY_DEVICE;
|
|||
#define CreateEnhMetaFile CreateEnhMetaFileA
|
||||
#define CreateFont CreateFontA
|
||||
#define CreateFontIndirect CreateFontIndirectA
|
||||
#define CreateFontIndirectEx CreateFontIndirectExA
|
||||
#define CreateIC CreateICA
|
||||
#define CreateMetaFile CreateMetaFileA
|
||||
#define CreateScalableFontResource CreateScalableFontResourceA
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
/* GDI logical font object */
|
||||
typedef struct
|
||||
{
|
||||
LOGFONTW logfont;
|
||||
ENUMLOGFONTEXDVW logfont; //LOGFONTW logfont;
|
||||
FONTOBJ *Font;
|
||||
BOOLEAN Initialized; /* Don't reinitialize for each DC */
|
||||
} TEXTOBJ, *PTEXTOBJ;
|
||||
|
|
|
@ -499,11 +499,12 @@ TextIntCreateFontIndirect(CONST LPLOGFONTW lf, HFONT *NewFont)
|
|||
TextObj = TEXTOBJ_LockText(*NewFont);
|
||||
if (NULL != TextObj)
|
||||
{
|
||||
memcpy(&TextObj->logfont, lf, sizeof(LOGFONTW));
|
||||
memcpy(&TextObj->logfont.elfEnumLogfontEx.elfLogFont, lf, sizeof(LOGFONTW));
|
||||
if (lf->lfEscapement != lf->lfOrientation)
|
||||
{
|
||||
/* this should really depend on whether GM_ADVANCED is set */
|
||||
TextObj->logfont.lfOrientation = TextObj->logfont.lfEscapement;
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfOrientation =
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfEscapement;
|
||||
}
|
||||
TEXTOBJ_UnlockText(TextObj);
|
||||
}
|
||||
|
@ -601,6 +602,65 @@ NtGdiCreateFontIndirect(CONST LPLOGFONTW lf)
|
|||
return NT_SUCCESS(Status) ? NewFont : NULL;
|
||||
}
|
||||
|
||||
|
||||
HFONT
|
||||
STDCALL
|
||||
NtGdiHfontCreate(
|
||||
IN PENUMLOGFONTEXDVW pelfw,
|
||||
IN ULONG cjElfw,
|
||||
IN LFTYPE lft,
|
||||
IN FLONG fl,
|
||||
IN PVOID pvCliData )
|
||||
{
|
||||
ENUMLOGFONTEXDVW SafeLogfont;
|
||||
HFONT NewFont;
|
||||
PTEXTOBJ TextObj;
|
||||
NTSTATUS Status = STATUS_SUCCESS;
|
||||
|
||||
if (NULL != pelfw)
|
||||
{
|
||||
Status = MmCopyFromCaller(&SafeLogfont, pelfw, sizeof(ENUMLOGFONTEXDVW));
|
||||
if (NT_SUCCESS(Status))
|
||||
{
|
||||
NewFont = TEXTOBJ_AllocText();
|
||||
if (NULL != NewFont)
|
||||
{
|
||||
TextObj = TEXTOBJ_LockText(NewFont);
|
||||
|
||||
if (NULL != TextObj)
|
||||
{
|
||||
RtlCopyMemory ( &TextObj->logfont,
|
||||
&SafeLogfont,
|
||||
sizeof(ENUMLOGFONTEXDVW));
|
||||
|
||||
if (SafeLogfont.elfEnumLogfontEx.elfLogFont.lfEscapement !=
|
||||
SafeLogfont.elfEnumLogfontEx.elfLogFont.lfOrientation)
|
||||
{
|
||||
/* this should really depend on whether GM_ADVANCED is set */
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfOrientation =
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfEscapement;
|
||||
}
|
||||
TEXTOBJ_UnlockText(TextObj);
|
||||
}
|
||||
else
|
||||
{
|
||||
/* FIXME */
|
||||
/* ASSERT(FALSE);*/
|
||||
Status = STATUS_INVALID_HANDLE;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
Status = STATUS_INVALID_PARAMETER;
|
||||
}
|
||||
|
||||
return NT_SUCCESS(Status) ? NewFont : NULL;
|
||||
|
||||
}
|
||||
|
||||
|
||||
BOOL
|
||||
STDCALL
|
||||
NtGdiCreateScalableFontResource(DWORD Hidden,
|
||||
|
@ -1824,17 +1884,17 @@ NtGdiExtTextOut(
|
|||
|
||||
Render = IntIsFontRenderingEnabled();
|
||||
if (Render)
|
||||
RenderMode = IntGetFontRenderMode(&TextObj->logfont);
|
||||
RenderMode = IntGetFontRenderMode(&TextObj->logfont.elfEnumLogfontEx.elfLogFont);
|
||||
else
|
||||
RenderMode = FT_RENDER_MODE_MONO;
|
||||
|
||||
error = FT_Set_Pixel_Sizes(
|
||||
face,
|
||||
TextObj->logfont.lfWidth,
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfWidth,
|
||||
/* FIXME should set character height if neg */
|
||||
(TextObj->logfont.lfHeight < 0 ?
|
||||
- TextObj->logfont.lfHeight :
|
||||
TextObj->logfont.lfHeight == 0 ? 11 : TextObj->logfont.lfHeight));
|
||||
(TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight < 0 ?
|
||||
- TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight :
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight == 0 ? 11 : TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight));
|
||||
if (error)
|
||||
{
|
||||
DPRINT1("Error in setting pixel sizes: %u\n", error);
|
||||
|
@ -1884,7 +1944,8 @@ NtGdiExtTextOut(
|
|||
for (i = Start; i < Count; i++)
|
||||
{
|
||||
glyph_index = FT_Get_Char_Index(face, *TempText);
|
||||
if (!(realglyph = NtGdiGlyphCacheGet(face, glyph_index, TextObj->logfont.lfHeight)))
|
||||
if (!(realglyph = NtGdiGlyphCacheGet(face, glyph_index,
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight)))
|
||||
{
|
||||
error = FT_Load_Glyph(face, glyph_index, FT_LOAD_DEFAULT);
|
||||
if (error)
|
||||
|
@ -1893,7 +1954,8 @@ NtGdiExtTextOut(
|
|||
}
|
||||
|
||||
glyph = face->glyph;
|
||||
realglyph = NtGdiGlyphCacheSet(face, glyph_index, TextObj->logfont.lfHeight, glyph, RenderMode);
|
||||
realglyph = NtGdiGlyphCacheSet(face, glyph_index,
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight, glyph, RenderMode);
|
||||
}
|
||||
/* retrieve kerning distance */
|
||||
if (use_kerning && previous && glyph_index)
|
||||
|
@ -1932,7 +1994,8 @@ NtGdiExtTextOut(
|
|||
for (i = 0; i < Count; i++)
|
||||
{
|
||||
glyph_index = FT_Get_Char_Index(face, *String);
|
||||
if (!(realglyph = NtGdiGlyphCacheGet(face, glyph_index, TextObj->logfont.lfHeight)))
|
||||
if (!(realglyph = NtGdiGlyphCacheGet(face, glyph_index,
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight)))
|
||||
{
|
||||
error = FT_Load_Glyph(face, glyph_index, FT_LOAD_DEFAULT);
|
||||
|
||||
|
@ -1943,7 +2006,8 @@ NtGdiExtTextOut(
|
|||
goto fail;
|
||||
}
|
||||
glyph = face->glyph;
|
||||
realglyph = NtGdiGlyphCacheSet(face, glyph_index, TextObj->logfont.lfHeight, glyph, RenderMode);
|
||||
realglyph = NtGdiGlyphCacheSet(face, glyph_index,
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight, glyph, RenderMode);
|
||||
}
|
||||
// DbgPrint("realglyph: %x\n", realglyph);
|
||||
// DbgPrint("TextLeft: %d\n", TextLeft);
|
||||
|
@ -2238,10 +2302,10 @@ NtGdiGetCharABCWidths(HDC hDC,
|
|||
|
||||
IntLockFreeType;
|
||||
FT_Set_Pixel_Sizes(face,
|
||||
TextObj->logfont.lfWidth,
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfWidth,
|
||||
/* FIXME should set character height if neg */
|
||||
(TextObj->logfont.lfHeight < 0 ? - TextObj->logfont.lfHeight :
|
||||
TextObj->logfont.lfHeight == 0 ? 11 : TextObj->logfont.lfHeight));
|
||||
(TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight < 0 ? - TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight :
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight == 0 ? 11 : TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight));
|
||||
|
||||
for (i = FirstChar; i <= LastChar; i++)
|
||||
{
|
||||
|
@ -2382,11 +2446,11 @@ NtGdiGetCharWidth32(HDC hDC,
|
|||
|
||||
IntLockFreeType;
|
||||
FT_Set_Pixel_Sizes(face,
|
||||
TextObj->logfont.lfWidth,
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfWidth,
|
||||
/* FIXME should set character height if neg */
|
||||
(TextObj->logfont.lfHeight < 0 ?
|
||||
- TextObj->logfont.lfHeight :
|
||||
TextObj->logfont.lfHeight == 0 ? 11 : TextObj->logfont.lfHeight));
|
||||
(TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight < 0 ?
|
||||
- TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight :
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight == 0 ? 11 : TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight));
|
||||
|
||||
for (i = FirstChar; i <= LastChar; i++)
|
||||
{
|
||||
|
@ -2516,8 +2580,8 @@ NtGdiGetGlyphOutline(
|
|||
FontGDI = ObjToGDI(TextObj->Font, FONT);
|
||||
ft_face = FontGDI->face;
|
||||
|
||||
aveWidth = FT_IS_SCALABLE(ft_face) ? TextObj->logfont.lfWidth: 0;
|
||||
orientation = FT_IS_SCALABLE(ft_face) ? TextObj->logfont.lfOrientation: 0;
|
||||
aveWidth = FT_IS_SCALABLE(ft_face) ? TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfWidth: 0;
|
||||
orientation = FT_IS_SCALABLE(ft_face) ? TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfOrientation: 0;
|
||||
|
||||
Size = IntGetOutlineTextMetrics(FontGDI, 0, NULL);
|
||||
potm = ExAllocatePoolWithTag(PagedPool, Size, TAG_GDITEXT);
|
||||
|
@ -2561,10 +2625,10 @@ NtGdiGetGlyphOutline(
|
|||
}
|
||||
|
||||
// FT_Set_Pixel_Sizes(ft_face,
|
||||
// TextObj->logfont.lfWidth,
|
||||
// TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfWidth,
|
||||
/* FIXME should set character height if neg */
|
||||
// (TextObj->logfont.lfHeight < 0 ? - TextObj->logfont.lfHeight :
|
||||
// TextObj->logfont.lfHeight == 0 ? 11 : TextObj->logfont.lfHeight));
|
||||
// (TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight < 0 ? - TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight :
|
||||
// TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight == 0 ? 11 : TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight));
|
||||
|
||||
TEXTOBJ_UnlockText(TextObj);
|
||||
|
||||
|
@ -3107,11 +3171,12 @@ NtGdiGetKerningPairs(HDC hDC,
|
|||
From "Undocumented Windows 2000 Secrets" Appendix B, Table B-2, page
|
||||
472, this is NtGdiGetOutlineTextMetricsInternalW.
|
||||
*/
|
||||
UINT
|
||||
ULONG
|
||||
STDCALL
|
||||
NtGdiGetOutlineTextMetrics(HDC hDC,
|
||||
UINT Data,
|
||||
LPOUTLINETEXTMETRICW otm)
|
||||
NtGdiGetOutlineTextMetricsInternalW (HDC hDC,
|
||||
ULONG Data,
|
||||
OUTLINETEXTMETRICW *otm,
|
||||
TMDIFF *Tmd)
|
||||
{
|
||||
PDC dc;
|
||||
PTEXTOBJ TextObj;
|
||||
|
@ -3343,11 +3408,11 @@ TextIntGetTextExtentPoint(PDC dc,
|
|||
|
||||
IntLockFreeType;
|
||||
error = FT_Set_Pixel_Sizes(face,
|
||||
TextObj->logfont.lfWidth,
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfWidth,
|
||||
/* FIXME should set character height if neg */
|
||||
(TextObj->logfont.lfHeight < 0 ?
|
||||
- TextObj->logfont.lfHeight :
|
||||
TextObj->logfont.lfHeight == 0 ? 11 : TextObj->logfont.lfHeight));
|
||||
(TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight < 0 ?
|
||||
- TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight :
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight == 0 ? 11 : TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight));
|
||||
IntUnLockFreeType;
|
||||
if (error)
|
||||
{
|
||||
|
@ -3395,7 +3460,7 @@ TextIntGetTextExtentPoint(PDC dc,
|
|||
}
|
||||
|
||||
Size->cx = (TotalWidth + 32) >> 6;
|
||||
Size->cy = (TextObj->logfont.lfHeight < 0 ? - TextObj->logfont.lfHeight : TextObj->logfont.lfHeight);
|
||||
Size->cy = (TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight < 0 ? - TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight : TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight);
|
||||
Size->cy = EngMulDiv(Size->cy, IntGdiGetDeviceCaps(dc, LOGPIXELSY), 72);
|
||||
|
||||
return TRUE;
|
||||
|
@ -3657,8 +3722,8 @@ NtGdiGetTextFace(HDC hDC, INT Count, LPWSTR FaceName)
|
|||
|
||||
TextObj = TEXTOBJ_LockText(hFont);
|
||||
ASSERT(TextObj != NULL);
|
||||
Count = min(Count, wcslen(TextObj->logfont.lfFaceName));
|
||||
Status = MmCopyToCaller(FaceName, TextObj->logfont.lfFaceName, Count * sizeof(WCHAR));
|
||||
Count = min(Count, wcslen(TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfFaceName));
|
||||
Status = MmCopyToCaller(FaceName, TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfFaceName, Count * sizeof(WCHAR));
|
||||
TEXTOBJ_UnlockText(TextObj);
|
||||
if (!NT_SUCCESS(Status))
|
||||
{
|
||||
|
@ -3704,11 +3769,11 @@ NtGdiGetTextMetrics(HDC hDC,
|
|||
Face = FontGDI->face;
|
||||
IntLockFreeType;
|
||||
Error = FT_Set_Pixel_Sizes(Face,
|
||||
TextObj->logfont.lfWidth,
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfWidth,
|
||||
/* FIXME should set character height if neg */
|
||||
(TextObj->logfont.lfHeight < 0 ?
|
||||
- TextObj->logfont.lfHeight :
|
||||
TextObj->logfont.lfHeight == 0 ? 11 : TextObj->logfont.lfHeight));
|
||||
(TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight < 0 ?
|
||||
- TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight :
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight == 0 ? 11 : TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfHeight));
|
||||
IntUnLockFreeType;
|
||||
if (0 != Error)
|
||||
{
|
||||
|
@ -4059,7 +4124,7 @@ TextIntRealizeFont(HFONT FontHandle)
|
|||
return STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
if (! RtlCreateUnicodeString(&FaceName, TextObj->logfont.lfFaceName))
|
||||
if (! RtlCreateUnicodeString(&FaceName, TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfFaceName))
|
||||
{
|
||||
TEXTOBJ_UnlockText(TextObj);
|
||||
return STATUS_NO_MEMORY;
|
||||
|
@ -4072,21 +4137,21 @@ TextIntRealizeFont(HFONT FontHandle)
|
|||
Win32Process = PsGetCurrentProcessWin32Process();
|
||||
IntLockProcessPrivateFonts(Win32Process);
|
||||
FindBestFontFromList(&TextObj->Font, &MatchScore,
|
||||
&TextObj->logfont, &FaceName,
|
||||
&TextObj->logfont.elfEnumLogfontEx.elfLogFont, &FaceName,
|
||||
&Win32Process->PrivateFontListHead);
|
||||
IntUnLockProcessPrivateFonts(Win32Process);
|
||||
|
||||
/* Search system fonts */
|
||||
IntLockGlobalFonts;
|
||||
FindBestFontFromList(&TextObj->Font, &MatchScore,
|
||||
&TextObj->logfont, &FaceName,
|
||||
&TextObj->logfont.elfEnumLogfontEx.elfLogFont, &FaceName,
|
||||
&FontListHead);
|
||||
IntUnLockGlobalFonts;
|
||||
|
||||
if (NULL == TextObj->Font)
|
||||
{
|
||||
DPRINT1("Requested font %S not found, no fonts loaded at all\n",
|
||||
TextObj->logfont.lfFaceName);
|
||||
TextObj->logfont.elfEnumLogfontEx.elfLogFont.lfFaceName);
|
||||
Status = STATUS_NOT_FOUND;
|
||||
}
|
||||
else
|
||||
|
@ -4104,36 +4169,35 @@ TextIntRealizeFont(HFONT FontHandle)
|
|||
}
|
||||
|
||||
INT FASTCALL
|
||||
FontGetObject(PTEXTOBJ Font, INT Count, PVOID Buffer)
|
||||
FontGetObject(PTEXTOBJ TFont, INT Count, PVOID Buffer)
|
||||
{
|
||||
if( Buffer == NULL ) return sizeof(LOGFONTW);
|
||||
|
||||
switch (Count)
|
||||
{
|
||||
/* Everything will need to be converted over to ENUMLOGFONTEXDVW.
|
||||
|
||||
case sizeof(ENUMLOGFONTEXDVW):
|
||||
RtlCopyMemory( (LPENUMLOGFONTEXDVW) Buffer.elfDesignVector,
|
||||
&Font->logFont.elfDesignVector,
|
||||
sizeof(DESIGNVECTOR));
|
||||
RtlCopyMemory( (LPENUMLOGFONTEXDVW) Buffer,
|
||||
&TFont->logfont,
|
||||
sizeof(ENUMLOGFONTEXDVW));
|
||||
break;
|
||||
case sizeof(ENUMLOGFONTEXW):
|
||||
RtlCopyMemory( (LPENUMLOGFONTEXW) Buffer,
|
||||
&Font->logFont.elfEnumLogfontEx,
|
||||
&TFont->logfont.elfEnumLogfontEx,
|
||||
sizeof(ENUMLOGFONTEXW));
|
||||
break;
|
||||
|
||||
case sizeof(EXTLOGFONTW):
|
||||
case sizeof(ENUMLOGFONTW):
|
||||
RtlCopyMemory((LPENUMLOGFONTW) Buffer,
|
||||
(LPENUMLOGFONTW) &Font->logfont.elfEnumLogfontEx.elfLogFont,
|
||||
&TFont->logfont.elfEnumLogfontEx.elfLogFont,
|
||||
sizeof(ENUMLOGFONTW));
|
||||
break;
|
||||
*/
|
||||
|
||||
case sizeof(LOGFONTW):
|
||||
/* RtlCopyMemory((LPLOGFONTW) Buffer,
|
||||
&Font->logFont.elfEnumLogfontEx.elfLogFont,
|
||||
sizeof(LOGFONTW));
|
||||
*/
|
||||
RtlCopyMemory(Buffer, &Font->logfont, sizeof(LOGFONTW));
|
||||
RtlCopyMemory((LPLOGFONTW) Buffer,
|
||||
&TFont->logfont.elfEnumLogfontEx.elfLogFont,
|
||||
sizeof(LOGFONTW));
|
||||
break;
|
||||
|
||||
default:
|
||||
|
|
|
@ -33,8 +33,6 @@ NtGdiCreateDiscardableBitmap 3
|
|||
NtGdiCreateEllipticRgn 4
|
||||
NtGdiCreateEllipticRgnIndirect 1
|
||||
NtGdiCreateEnhMetaFile 4
|
||||
NtGdiCreateFont 14
|
||||
NtGdiCreateFontIndirect 1
|
||||
NtGdiCreateHalftonePalette 1
|
||||
NtGdiCreateHatchBrushInternal 3
|
||||
NtGdiCreateIC 4
|
||||
|
@ -138,7 +136,7 @@ NtGdiGetMetaRgn 2
|
|||
NtGdiGetMiterLimit 2
|
||||
NtGdiGetNearestColor 2
|
||||
NtGdiGetNearestPaletteIndex 2
|
||||
NtGdiGetOutlineTextMetrics 3
|
||||
NtGdiGetOutlineTextMetricsInternalW 4
|
||||
NtGdiGetPaletteEntries 4
|
||||
NtGdiGetPath 4
|
||||
NtGdiGetPixel 3
|
||||
|
@ -171,6 +169,7 @@ NtGdiGetWindowExtEx 2
|
|||
NtGdiGetWindowOrgEx 2
|
||||
NtGdiGetWorldTransform 2
|
||||
NtGdiGradientFill 6
|
||||
NtGdiHfontCreate 5
|
||||
NtGdiIntersectClipRect 5
|
||||
NtGdiInvertRgn 2
|
||||
NtGdiLPtoDP 3
|
||||
|
|
Loading…
Reference in a new issue