Leaked source code of windows server 2003
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.

347 lines
12 KiB

  1. /*****************************************************************************
  2. *
  3. * MF3216.h - The include file for MF3216. This will contain all
  4. * the miscellaneous includes.
  5. *
  6. * Author: Jeffrey Newman (c-jeffn)
  7. *
  8. * Creation Date: 31-Jan-1992
  9. *
  10. ****************************************************************************/
  11. //////////////////////////////////////////////////////////////////////////////
  12. // GillesK: April 2000
  13. // This is a full copy of the MF3216 source code for use with GDI+...
  14. // Whatever gets fixed in the real MF3216 should be reflected here. in order
  15. // to keep the bugs consistent.
  16. //////////////////////////////////////////////////////////////////////////////
  17. #ifndef _MF3216_
  18. #define _MF3216_
  19. #define NOTUSED(x) {}
  20. #define NOTXORPASS 0
  21. #define DRAWXORPASS 1
  22. #define OBJECTRECREATION 2
  23. #define ERASEXORPASS 3
  24. #define STARTPSIGNORE 1
  25. #define ENDPSIGNORE 0
  26. /* Types for postscript written to metafiles */
  27. #define CLIP_SAVE 0
  28. #define CLIP_RESTORE 1
  29. #define CLIP_INCLUSIVE 2
  30. #define CLIP_EXCLUSIVE 3
  31. typedef struct _w16objhndlslotstatus {
  32. INT use ;
  33. HANDLE w32Handle ;
  34. INT iXORPassCreation ; // In which XOR pass the object was created
  35. PBYTE pbCreatRec; // Which EMF record created the object
  36. } W16OBJHNDLSLOTSTATUS ;
  37. typedef W16OBJHNDLSLOTSTATUS *PW16OBJHNDLSLOTSTATUS ;
  38. typedef struct _w16recreationslot {
  39. INT slot ; // The slot that we need to create the object in
  40. PBYTE pbCreatRec ; // The record that will create the object
  41. struct _w16recreationslot* pNext ;
  42. } W16RECREATIONSLOT ;
  43. typedef W16RECREATIONSLOT *PW16RECREATIONSLOT ;
  44. // This structure contains the current metafile information to gather the
  45. // proper transforms
  46. typedef struct tagMAPPING { // The Page transform in its less
  47. INT iMapMode;
  48. INT iWox;
  49. INT iWoy;
  50. INT iVox;
  51. INT iVoy;
  52. INT iWex;
  53. INT iWey;
  54. INT iVex;
  55. INT iVey;
  56. } MAPPING, *PMAPPING;
  57. typedef struct _localDC {
  58. UINT nSize ; // Size of this Local DC structure.
  59. DWORD flags ; // Boolean controls.
  60. PBYTE pMf32Bits ; // ptr to W32 metafile bits.
  61. UINT cMf32Bits ; // count of W32 metafile size.
  62. PBYTE pMf16Bits ; // ptr to user supplied out buffer
  63. UINT cMf16Dest ; // length of user supplied buffer
  64. HDC hdcHelper ; // Our helper DC.
  65. HDC hdcRef ; // Reference DC.
  66. HBITMAP hbmpMem; // A Memory Bitmap for Win9x
  67. INT iMapMode ; // User requested map mode.
  68. INT cxPlayDevMM,
  69. cyPlayDevMM,
  70. cxPlayDevPels,
  71. cyPlayDevPels ;
  72. XFORM xformRWorldToRDev, // aka Metafile-World to Metafile-Device
  73. xformRDevToRWorld, // aka Metafile-Device to Metafile-World
  74. xformRDevToPDev, // aka Metafile-Device to Reference-Device
  75. xformPDevToPPage, // aka Reference-Device to Reference-Logical
  76. xformPPageToPDev, // aka Reference-Logical to Reference-Device
  77. xformRDevToPPage, // aka Metafile-Device to Reference-Logical
  78. xformRWorldToPPage ;
  79. XFORM xformW ; // The World Transform for Win9x
  80. XFORM xformP ; // The Page Transform for Win9x
  81. XFORM xformDC ; // The DC Transform for Win9x
  82. MAPPING map ; // The mapping info for Win9x
  83. POINT ptCP ; // Current position
  84. PBYTE pbEnd ; // End of W32 metafile bits.
  85. METAHEADER mf16Header ; // The W16 metafile header.
  86. PINT piW32ToW16ObjectMap ;
  87. UINT cW16ObjHndlSlotStatus ; // used in slot search
  88. UINT cW32ToW16ObjectMap ; // used in Normalize handle.
  89. PW16OBJHNDLSLOTSTATUS pW16ObjHndlSlotStatus ;
  90. COLORREF crTextColor ; // current text color - used by
  91. // ExtCreatePen.
  92. COLORREF crBkColor ; // Current background color
  93. INT iArcDirection ; // Current arc direction in W32 metafile
  94. LONG lhpn32; // Currently selected pen. Used in path and text
  95. LONG lhbr32; // Currently selected brush. Used in text
  96. DWORD ihpal32; // Currently selected (i32) palette.
  97. DWORD ihpal16; // Currently selected (i16) palette.
  98. UINT iLevel; // Current DC save level.
  99. INT iSavePSClipPath; // Number of times we save the PSclipPath
  100. struct _localDC *pLocalDCSaved; // Point to the saved DCs
  101. // The following fields are not restored by RestoreDC!
  102. // Information for the XOR ClipPath rendering
  103. INT iROP; // Current ROP Mode
  104. POINT pOldPosition ;
  105. INT iXORPass ;
  106. INT iXORPassDCLevel ;
  107. UINT ulBytesEmitted ; // Total bytes emitted so far.
  108. UINT ulMaxRecord ; // Max W16 record size.
  109. INT nObjectHighWaterMark; // Max slot index used so far.
  110. PBYTE pbRecord ; // Current record in W32 metafile bits.
  111. PBYTE pbCurrent; // Next record in W32 metafile bits.
  112. DWORD cW32hPal; // Size of private W32 palette table.
  113. PBYTE pbChange ; // Old position in the metafile
  114. PBYTE pbLastSelectClip ; // Old position in the metafile for path drawing
  115. LONG lholdp32 ;
  116. LONG lholdbr32;
  117. HPALETTE *pW32hPal; // Private W32 palette table.
  118. PW16RECREATIONSLOT pW16RecreationSlot ; // Used to recreate objects deleted in XOR Pass
  119. } LOCALDC ;
  120. typedef LOCALDC *PLOCALDC ;
  121. // Routines in apientry.c
  122. BOOL bHandleWin32Comment(PLOCALDC pLocalDC);
  123. // Routines in misc.c
  124. BOOL bValidateMetaFileCP(PLOCALDC pLocalDC, LONG x, LONG y);
  125. // Following are the bit definitions for the flags.
  126. #define SIZE_ONLY 0x00000001
  127. #define INCLUDE_W32MF_COMMENT 0x00000002
  128. #define STRANGE_XFORM 0x00000004
  129. #define RECORDING_PATH 0x00000008
  130. #define INCLUDE_W32MF_XORPATH 0x00000010
  131. #define ERR_BUFFER_OVERFLOW 0x80000000
  132. #define ERR_XORCLIPPATH 0x40000000
  133. // Make this big in case more flags are added to MF3216
  134. #define GPMF3216_INCLUDE_XORPATH 0x1000
  135. // This define sets the size of each Win32 metafile comment record.
  136. // The reason we do not just use a 64K record is due to a caution given
  137. // to use about large escape records in Win3.0 by the GBU (MS Palo Alto).
  138. #define MAX_WIN32_COMMENT_REC_SIZE 0x2000
  139. // Function(s) used in parser.c
  140. extern BOOL bParseWin32Metafile(PBYTE pMetafileBits, PLOCALDC pLocalDC) ;
  141. // Function definitions for preamble.
  142. extern BOOL bUpdateMf16Header(PLOCALDC pLocalDC) ;
  143. // Function definitions for the emitter.
  144. extern BOOL bEmit(PLOCALDC pLocalDC, PVOID pBuffer, DWORD nCount) ;
  145. extern VOID vUpdateMaxRecord(PLOCALDC pLocalDC, PMETARECORD pmr);
  146. // Defines used in objects.c
  147. #define OPEN_AVAILABLE_SLOT 1
  148. #define REALIZED_BRUSH 2
  149. #define REALIZED_PEN 3
  150. #define REALIZED_BITMAP 4
  151. #define REALIZED_PALETTE 5
  152. #define REALIZED_REGION 6
  153. #define REALIZED_FONT 7
  154. #define REALIZED_OBJECT 8 // used by multiformats record
  155. #define REALIZED_DUMMY 9 // used by multiformats record
  156. #define UNMAPPED -1
  157. // Routines in objects.c
  158. extern BOOL bInitHandleTableManager(PLOCALDC pLocalDC, PENHMETAHEADER pmf32header) ;
  159. extern INT iGetW16ObjectHandleSlot(PLOCALDC pLocalDC, INT iIntendedUse) ;
  160. extern INT iValidateHandle(PLOCALDC pLocalDC, INT ihW32) ;
  161. extern INT iAllocateW16Handle(PLOCALDC pLocalDC, INT ihW32, INT iIntendedUse) ;
  162. extern BOOL bDeleteW16Object(PLOCALDC pLocalDC, INT ihW16) ;
  163. extern INT iNormalizeHandle(PLOCALDC pLocalDC, INT ihW32) ;
  164. // Routines in text.c
  165. VOID vUnicodeToAnsi(HDC hdc, PCHAR pAnsi, PWCH pUnicode, DWORD cch) ;
  166. // Routines in regions.c
  167. BOOL bNoDCRgn(PLOCALDC pLocalDC, INT iType);
  168. BOOL bDumpDCClipping(PLOCALDC pLocalDC);
  169. // Defines used in bNoDCRgn().
  170. #define DCRGN_CLIP 1
  171. #define DCRGN_META 2
  172. // Defines used in xforms.c
  173. #define CX_MAG 1
  174. #define CY_MAG 2
  175. typedef struct
  176. {
  177. FLOAT x;
  178. FLOAT y;
  179. } POINTFL;
  180. typedef POINTFL *PPOINTFL;
  181. // Function definitions from xform
  182. extern BOOL bInitXformMatrices(PLOCALDC pLocalDC, PENHMETAHEADER pmf32header, RECTL* frameBounds) ;
  183. extern BOOL bXformRWorldToPPage(PLOCALDC pLocalDC, PPOINTL aptl, DWORD nCount) ;
  184. extern BOOL bXformRWorldToRDev(PLOCALDC pLocalDC, PPOINTL aptl, INT nCount) ;
  185. extern BOOL bXformPDevToPPage(PLOCALDC pLocalDC, PPOINTL aptl, INT nCount) ;
  186. extern BOOL bXformPPageToPDev(PLOCALDC pLocalDC, PPOINTL aptl, INT nCount) ;
  187. extern BOOL bXformRDevToRWorld(PLOCALDC pLocalDC, PPOINTL aptl, INT nCount) ;
  188. extern INT iMagnitudeXform (PLOCALDC pLocalDC, INT value, INT iType) ;
  189. extern XFORM xformIdentity ;
  190. extern BOOL bRotationTest(PXFORM pxform) ;
  191. extern INT iMagXformWorkhorse (INT value, PXFORM pxform, INT iType) ;
  192. extern BOOL bXformWorkhorse(PPOINTL aptl, DWORD nCount, PXFORM pXform) ;
  193. extern VOID vXformWorkhorseFloat(PPOINTFL aptfl, UINT nCount, PXFORM pXform);
  194. extern BOOL bCoordinateOverflowTest(PLONG pCoordinates, INT nCount) ;
  195. BOOL bCombineTransform(
  196. LPXFORM lpxformResult, // combined transformation
  197. CONST XFORM *lpxform1, // first transformation
  198. CONST XFORM *lpxform2 // second transformation
  199. );
  200. // Defines used in Conics
  201. #define SWAP(x,y,t) {t = x; x = y; y = t;}
  202. #define ePI ((FLOAT)(((FLOAT) 22.0 / (FLOAT) 7.0 )))
  203. // Exported support functions and defines for Conics & rectangles.
  204. extern BOOL bConicCommon (PLOCALDC pLocalDC, INT x1, INT y1, INT x2, INT y2,
  205. INT x3, INT y3, INT x4, INT y4,
  206. DWORD mrType) ;
  207. extern BOOL bRenderCurveWithPath
  208. (
  209. PLOCALDC pLocalDC,
  210. LPPOINT pptl,
  211. PBYTE pb,
  212. DWORD cptl,
  213. INT x1,
  214. INT y1,
  215. INT x2,
  216. INT y2,
  217. INT x3,
  218. INT y3,
  219. INT x4,
  220. INT y4,
  221. DWORD nRadius,
  222. FLOAT eStartAngle,
  223. FLOAT eSweepAngle,
  224. DWORD mrType
  225. );
  226. // Exported functions from lines.c
  227. extern VOID vCompressPoints(PVOID pBuff, LONG nCount) ;
  228. // Defines (macros) used in bitmaps.
  229. // Check if a source is needed in a 3-way bitblt operation.
  230. // This works on both rop and rop3. We assume that a rop contains zero
  231. // in the high byte.
  232. //
  233. // This is tested by comparing the rop result bits with source (column A
  234. // below) vs. those without source (column B). If the two cases are
  235. // identical, then the effect of the rop does not depend on the source
  236. // and we don't need a source device. Recall the rop construction from
  237. // input (pattern, source, target --> result):
  238. //
  239. // P S T | R A B mask for A = 0CCh
  240. // ------+-------- mask for B = 33h
  241. // 0 0 0 | x 0 x
  242. // 0 0 1 | x 0 x
  243. // 0 1 0 | x x 0
  244. // 0 1 1 | x x 0
  245. // 1 0 0 | x 0 x
  246. // 1 0 1 | x 0 x
  247. // 1 1 0 | x x 0
  248. // 1 1 1 | x x 0
  249. #define ISSOURCEINROP3(rop3) \
  250. (((rop3) & 0xCCCC0000) != (((rop3) << 2) & 0xCCCC0000))
  251. #define CJSCAN(width,planes,bits) ((((width)*(planes)*(bits)+31) & ~31) / 8)
  252. #define MAX4(a, b, c, d) max(max(max(a,b),c),d)
  253. #define MIN4(a, b, c, d) min(min(min(a,b),c),d)
  254. // GillesK: Mar 2000
  255. // This is needed because GetTransform is not in GDI32.lib but is in GDI32.dll
  256. typedef BOOL (*fnGetTransform)(HDC,DWORD,LPXFORM);
  257. typedef BOOL (*fnSetVirtualResolution)(HDC,
  258. int,
  259. int,
  260. int,
  261. int);
  262. #endif //_MF3216_