Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

192 lines
7.0 KiB

  1. /*
  2. Copyright (c) 1999 Microsoft Corporation
  3. ******************************
  4. *** Microsoft Confidential ***
  5. ******************************
  6. Module Name:
  7. CT_Ras_Win.h
  8. Author:
  9. Paul Linnerud (paulli@microsoft.com)
  10. Abstract:
  11. This module defines the API mapping layer for the standalone implementation of the ClearType
  12. rasterizer. Applications written to use the Win32 API should make use of these functions to
  13. output using ClearType.
  14. Revision History:
  15. */
  16. #ifdef __cplusplus
  17. extern "C" {
  18. #endif
  19. #ifndef _CT_Ras_Win_
  20. #define _CT_Ras_Win_
  21. #if !defined(_CTWAPI_LIB_)
  22. #define CTWAPI __declspec(dllimport)
  23. #else
  24. #define CTWAPI
  25. #endif
  26. /* defines */
  27. typedef void *(__cdecl *CTWAPI_ALLOCPROC)(ULONG ulSize);
  28. typedef void *(__cdecl *CTWAPI_REALLOCPROC)(void * pMem, ULONG ulSize);
  29. typedef void (__cdecl *CTWAPI_FREEPROC)(void * pMem);
  30. typedef struct
  31. {
  32. CTWAPI_ALLOCPROC fnAlloc;
  33. CTWAPI_REALLOCPROC fnReAlloc;
  34. CTWAPI_FREEPROC fnFree;
  35. } CTWAPIMEMORYFUNCTIONS, *PCTWAPIMEMORYFUNCTIONS;
  36. typedef HANDLE WAPIFONTINSTANCEHANDLE;
  37. typedef struct
  38. {
  39. ULONG ulStructSize;
  40. /* System Parameters */
  41. BOOL bBGR;
  42. BOOL bHorizontal;
  43. // gamma clamp
  44. ULONG ulGammaBottom, ulGammaTop;
  45. /* User Parameters */
  46. // color filter
  47. ULONG ulColorThreshold;
  48. ULONG ulCLFRedFactor;
  49. ULONG ulCLFGreenFactor;
  50. // blue color filter
  51. ULONG ulBlueColorThreshold;
  52. ULONG ulBCLFGreenFactor;
  53. ULONG ulBCLFBlueFactor;
  54. ULONG ulBCLFRedFactor;
  55. }CTWAPIPARAMS, *PCTWAPIPARAMS;
  56. /* Fetch last error. */
  57. CTWAPI LONG WINAPI WAPI_CTGetLastError();
  58. /* Override the default memory handler. Optional function only should be called once per process and
  59. before any other functions in this module are called. */
  60. CTWAPI BOOL WAPI_CTOverrideDefaultMemoryFunctions(PCTWAPIMEMORYFUNCTIONS pMemFunctionStruct);
  61. /* Functions to manage an instance of a font. */
  62. /* From a handle to a DC, create a FONTINSTANCE handle. */
  63. CTWAPI WAPIFONTINSTANCEHANDLE WINAPI WAPI_CTCreateFontInstance(HDC hDC, DWORD dwFlags);
  64. /* Delete a FONTINSTANCE handle. */
  65. CTWAPI BOOL WINAPI WAPI_CTDeleteFontInstance(WAPIFONTINSTANCEHANDLE hFontInstance);
  66. /* Information functions. */
  67. /* Return the family name for the font. */
  68. CTWAPI LONG WINAPI WAPI_CTGetTextFaceW(WAPIFONTINSTANCEHANDLE hFontInstance, LONG lCount, PWSTR pTextFace);
  69. /* Get the TEXTMETRICW structure. */
  70. CTWAPI BOOL WINAPI WAPI_CTGetTextMetricsW(WAPIFONTINSTANCEHANDLE hFontInstance, PTEXTMETRICW ptm);
  71. /* Get the OUTLINETEXTMETRICW structure. */
  72. CTWAPI ULONG WINAPI WAPI_CTGetOutlineTextMetricsW(WAPIFONTINSTANCEHANDLE hFontInstance, ULONG ulcData, POUTLINETEXTMETRICW potm);
  73. /* Get the ABC widths. */
  74. CTWAPI BOOL WINAPI WAPI_CTGetCharABCWidthsW(WAPIFONTINSTANCEHANDLE hFontInstance, WCHAR wFirstChar, WCHAR wLastChar, PABC pabc);
  75. CTWAPI BOOL WINAPI WAPI_CTGetCharABCWidthsI(WAPIFONTINSTANCEHANDLE hFontInstance, WCHAR wFirstChar, WCHAR wLastChar, PABC pabc);
  76. /* Get the char widths. */
  77. CTWAPI BOOL WINAPI WAPI_CTGetCharWidthW(WAPIFONTINSTANCEHANDLE hFontInstance, WCHAR wFirstChar, WCHAR wLastChar, PLONG plWidths);
  78. CTWAPI BOOL WINAPI WAPI_CTGetCharWidthI(WAPIFONTINSTANCEHANDLE hFontInstance, WCHAR wFirstChar, WCHAR wLastChar, PLONG plWidths);
  79. /* GetTextExtentPoint */
  80. CTWAPI BOOL WINAPI WAPI_CTGetTextExtentPointW(WAPIFONTINSTANCEHANDLE hFontInstance, PWSTR pString, LONG lCount, PSIZE pSize);
  81. /* GetTextExtentExPoint */
  82. CTWAPI BOOL WINAPI WAPI_CTGetTextExtentExPointW(WAPIFONTINSTANCEHANDLE hFontInstance, PWSTR pString, LONG lCount, LONG lMaxExtent,
  83. PLONG pnFit, PLONG apDx, PSIZE pSize);
  84. /* Modes */
  85. CTWAPI COLORREF WINAPI WAPI_CTSetTextColor(WAPIFONTINSTANCEHANDLE hFontInstance, COLORREF crColor);
  86. CTWAPI COLORREF WINAPI WAPI_CTGetTextColor(WAPIFONTINSTANCEHANDLE hFontInstance);
  87. CTWAPI COLORREF WINAPI WAPI_CTSetBkColor(WAPIFONTINSTANCEHANDLE hFontInstance, COLORREF crColor);
  88. CTWAPI COLORREF WINAPI WAPI_CTGetBkColor(WAPIFONTINSTANCEHANDLE hFontInstance);
  89. CTWAPI LONG WINAPI WAPI_CTSetBkMode(WAPIFONTINSTANCEHANDLE hFontInstance, LONG lBkMode);
  90. /* Supports opaque and transparent with solid color. Note that we need to know the background color for the
  91. ClearType algorithm so even in transparent mode, the correct color must be set prior to rendering text. */
  92. CTWAPI LONG WINAPI WAPI_CTGetBkMode(WAPIFONTINSTANCEHANDLE hFontInstance);
  93. /* Set text alignment supporting TA_BASELINE, TA_TOP, TA_CENTER, TA_LEFT, TA_RIGHT. */
  94. CTWAPI ULONG WINAPI WAPI_CTSetTextAlign(WAPIFONTINSTANCEHANDLE hFontInstance, ULONG fMode);
  95. /* Get text alignment supporting TA_BASELINE, TA_TOP, TA_CENTER, TA_LEFT, TA_RIGHT.*/
  96. CTWAPI ULONG WINAPI WAPI_CTGetTextAlign(WAPIFONTINSTANCEHANDLE hFontInstance);
  97. CTWAPI BOOL WINAPI WAPI_CTSetSystemParameters(PCTWAPIPARAMS pParams);
  98. CTWAPI BOOL WINAPI WAPI_CTSetUserParameters(PCTWAPIPARAMS pParams);
  99. CTWAPI BOOL WINAPI WAPI_CTGetParameters(PCTWAPIPARAMS pParams);
  100. CTWAPI BOOL WINAPI WAPI_CTRestoreDefaultParameters();
  101. /* Output functions. */
  102. /* Output the text the basic way. */
  103. CTWAPI BOOL WINAPI WAPI_CTTextOutW(WAPIFONTINSTANCEHANDLE hFontInstance, HDC hdc, LONG lXStart, LONG lYStart, PWSTR pString, LONG lCount);
  104. /* Output text via glyph index. */
  105. CTWAPI BOOL WINAPI WAPI_CTTextOutI(WAPIFONTINSTANCEHANDLE hFontInstance, HDC hdc, LONG lXStart, LONG lYStart, PWSTR pString, LONG lCount);
  106. /* Output the text with limited extended functionality.
  107. supports: lpDx and flags ETO_GLYPH_INDEX and ETO_PDY and ETO_OPAQUE. */
  108. CTWAPI BOOL WINAPI WAPI_CTExtTextOutW(WAPIFONTINSTANCEHANDLE hFontInstance, HDC hdc, LONG lXStart, LONG lYStart, DWORD dwOptions,
  109. CONST RECT* lprc, PWSTR pString, ULONG ulCount, CONST LONG *lpDx);
  110. /* Alternative EZ functions that trade off speed for being easier to use and integrate. Functions are DC based so we store
  111. the WAPIFONTINSTANCEHANDLE internally and must find it for each function. Additional time is also taken since we fetch
  112. the various modes from DC for each call. Any support limitations mentioned above with faster functions also apply to the
  113. EZ functions. */
  114. CTWAPI BOOL WINAPI WAPI_EZCTCreateFontInstance(HDC hDC, DWORD dwFlags);
  115. CTWAPI BOOL WINAPI WAPI_EZCTDeleteFontInstance(HFONT hFont);
  116. // can be used to get WAPIFONTINSTANCEHANDLE from DC so additional function above such as WAPI_CTGetTextMetrics may be used.
  117. CTWAPI WAPIFONTINSTANCEHANDLE WINAPI WAPI_EZCTDcToFontInst(HDC hDC);
  118. CTWAPI BOOL WINAPI WAPI_EZCTTextOutW(HDC hDC, LONG lXStart, LONG lYStart, PWSTR pString, LONG lCount);
  119. CTWAPI BOOL WINAPI WAPI_EZCTTextOutI(HDC hDC, LONG lXStart, LONG lYStart, PWSTR pString, LONG lCount);
  120. CTWAPI BOOL WINAPI WAPI_EZCTExtTextOutW(HDC hDC, LONG lXStart, LONG lYStart, DWORD dwOptions,
  121. CONST RECT* lprc, PWSTR pString, ULONG ulCount, CONST LONG *lpDx);
  122. CTWAPI BOOL WINAPI WAPI_EZCTGetCharABCWidthsW(HDC hDC, WCHAR wFirstChar, WCHAR wLastChar, PABC pabc);
  123. CTWAPI BOOL WINAPI WAPI_EZCTGetCharABCWidthsI(HDC hDC, WCHAR wFirstChar, WCHAR wLastChar, PABC pabc);
  124. CTWAPI BOOL WINAPI WAPI_EZCTGetCharWidthW(HDC hDC, WCHAR wFirstChar, WCHAR wLastChar, PLONG plWidths);
  125. CTWAPI BOOL WINAPI WAPI_EZCTGetCharWidthI(HDC hDC, WCHAR wFirstChar, WCHAR wLastChar, PLONG plWidths);
  126. #endif /* _CT_Ras_Win_ */
  127. #ifdef __cplusplus
  128. }
  129. #endif