2 * Enhanced MetaFile objects
4 * Copyright 1999 Huw D M Davies
12 #include "enhmetafiledrv.h"
17 DEFAULT_DEBUG_CHANNEL(enhmetafile
)
19 /***********************************************************************
20 * EMFDRV_BITMAP_SelectObject
22 static HBITMAP
EMFDRV_BITMAP_SelectObject( DC
* dc
, HBITMAP hbitmap
)
28 /***********************************************************************
29 * EMFDRV_CreateBrushIndirect
31 DWORD
EMFDRV_CreateBrushIndirect( DC
*dc
, HBRUSH hBrush
)
34 BRUSHOBJ
*brushObj
= (BRUSHOBJ
*)GDI_GetObjPtr( hBrush
, BRUSH_MAGIC
);
36 switch (brushObj
->logbrush
.lbStyle
) {
41 EMRCREATEBRUSHINDIRECT emr
;
42 emr
.emr
.iType
= EMR_CREATEBRUSHINDIRECT
;
43 emr
.emr
.nSize
= sizeof(emr
);
44 emr
.ihBrush
= index
= EMFDRV_AddHandleDC( dc
);
45 emr
.lb
= brushObj
->logbrush
;
47 if(!EMFDRV_WriteRecord( dc
, &emr
.emr
))
53 EMRCREATEDIBPATTERNBRUSHPT
*emr
;
54 DWORD bmSize
, biSize
, size
;
55 BITMAPINFO
*info
= GlobalLock16(brushObj
->logbrush
.lbHatch
);
57 if (info
->bmiHeader
.biCompression
)
58 bmSize
= info
->bmiHeader
.biSizeImage
;
60 bmSize
= DIB_GetDIBImageBytes(info
->bmiHeader
.biWidth
,
61 info
->bmiHeader
.biHeight
,
62 info
->bmiHeader
.biBitCount
);
63 biSize
= DIB_BitmapInfoSize(info
, LOWORD(brushObj
->logbrush
.lbColor
));
64 size
= sizeof(EMRCREATEDIBPATTERNBRUSHPT
) + biSize
+ bmSize
;
65 emr
= HeapAlloc( SystemHeap
, 0, size
);
67 emr
->emr
.iType
= EMR_CREATEDIBPATTERNBRUSHPT
;
68 emr
->emr
.nSize
= size
;
69 emr
->ihBrush
= index
= EMFDRV_AddHandleDC( dc
);
70 emr
->iUsage
= LOWORD(brushObj
->logbrush
.lbColor
);
71 emr
->offBmi
= sizeof(EMRCREATEDIBPATTERNBRUSHPT
);
73 emr
->offBits
= sizeof(EMRCREATEDIBPATTERNBRUSHPT
) + biSize
;
74 memcpy((char *)emr
+ sizeof(EMRCREATEDIBPATTERNBRUSHPT
), info
,
77 if(!EMFDRV_WriteRecord( dc
, &emr
->emr
))
79 HeapFree( SystemHeap
, 0, emr
);
80 GlobalUnlock16(brushObj
->logbrush
.lbHatch
);
85 FIXME(enhmetafile
, "Unsupported style %x\n",
86 brushObj
->logbrush
.lbStyle
);
89 FIXME(enhmetafile
, "Unknown style %x\n", brushObj
->logbrush
.lbStyle
);
92 GDI_HEAP_UNLOCK( hBrush
);
97 /***********************************************************************
98 * EMFDRV_BRUSH_SelectObject
100 static HBRUSH
EMFDRV_BRUSH_SelectObject(DC
*dc
, HBRUSH hBrush
)
106 index
= EMFDRV_CreateBrushIndirect(dc
, hBrush
);
107 if(!index
) return FALSE
;
109 emr
.emr
.iType
= EMR_SELECTOBJECT
;
110 emr
.emr
.nSize
= sizeof(emr
);
111 emr
.ihObject
= index
;
112 if(!EMFDRV_WriteRecord( dc
, &emr
.emr
))
115 hOldBrush
= dc
->w
.hBrush
;
116 dc
->w
.hBrush
= hBrush
;
121 /******************************************************************
122 * EMFDRV_CreateFontIndirect
124 static BOOL
EMFDRV_CreateFontIndirect(DC
*dc
, HFONT hFont
)
127 FONTOBJ
*fontObj
= (FONTOBJ
*)GDI_GetObjPtr( hFont
, FONT_MAGIC
);
128 EMREXTCREATEFONTINDIRECTW emr
;
130 emr
.emr
.iType
= EMR_EXTCREATEFONTINDIRECTW
;
131 emr
.emr
.nSize
= (sizeof(emr
) + 3) / 4 * 4;
132 emr
.ihFont
= index
= EMFDRV_AddHandleDC( dc
);
133 FONT_LogFont16To32W( &(fontObj
->logfont
), &(emr
.elfw
.elfLogFont
) );
134 emr
.elfw
.elfFullName
[0] = '\0';
135 emr
.elfw
.elfStyle
[0] = '\0';
136 emr
.elfw
.elfVersion
= 0;
137 emr
.elfw
.elfStyleSize
= 0;
138 emr
.elfw
.elfMatch
= 0;
139 emr
.elfw
.elfReserved
= 0;
140 for(i
= 0; i
< ELF_VENDOR_SIZE
; i
++)
141 emr
.elfw
.elfVendorId
[i
] = 0;
142 emr
.elfw
.elfCulture
= PAN_CULTURE_LATIN
;
143 emr
.elfw
.elfPanose
.bFamilyType
= PAN_NO_FIT
;
144 emr
.elfw
.elfPanose
.bSerifStyle
= PAN_NO_FIT
;
145 emr
.elfw
.elfPanose
.bWeight
= PAN_NO_FIT
;
146 emr
.elfw
.elfPanose
.bProportion
= PAN_NO_FIT
;
147 emr
.elfw
.elfPanose
.bContrast
= PAN_NO_FIT
;
148 emr
.elfw
.elfPanose
.bStrokeVariation
= PAN_NO_FIT
;
149 emr
.elfw
.elfPanose
.bArmStyle
= PAN_NO_FIT
;
150 emr
.elfw
.elfPanose
.bLetterform
= PAN_NO_FIT
;
151 emr
.elfw
.elfPanose
.bMidline
= PAN_NO_FIT
;
152 emr
.elfw
.elfPanose
.bXHeight
= PAN_NO_FIT
;
154 if(!EMFDRV_WriteRecord( dc
, &emr
.emr
))
156 GDI_HEAP_UNLOCK( hFont
);
161 /***********************************************************************
162 * EMFDRV_FONT_SelectObject
164 static HFONT
EMFDRV_FONT_SelectObject( DC
* dc
, HFONT hFont
)
170 index
= EMFDRV_CreateFontIndirect(dc
, hFont
);
171 if(!index
) return FALSE
;
173 emr
.emr
.iType
= EMR_SELECTOBJECT
;
174 emr
.emr
.nSize
= sizeof(emr
);
175 emr
.ihObject
= index
;
176 if(!EMFDRV_WriteRecord( dc
, &emr
.emr
))
179 hOldFont
= dc
->w
.hFont
;
186 /******************************************************************
187 * EMFDRV_CreatePenIndirect
189 static HPEN
EMFDRV_CreatePenIndirect(DC
*dc
, HPEN hPen
)
192 PENOBJ
*penObj
= (PENOBJ
*)GDI_GetObjPtr( hPen
, PEN_MAGIC
);
195 emr
.emr
.iType
= EMR_CREATEPEN
;
196 emr
.emr
.nSize
= sizeof(emr
);
197 emr
.ihPen
= index
= EMFDRV_AddHandleDC( dc
);
198 emr
.lopn
= penObj
->logpen
;
200 if(!EMFDRV_WriteRecord( dc
, &emr
.emr
))
202 GDI_HEAP_UNLOCK( hPen
);
206 /******************************************************************
207 * EMFDRV_PEN_SelectObject
209 static HPEN
EMFDRV_PEN_SelectObject(DC
*dc
, HPEN hPen
)
215 index
= EMFDRV_CreatePenIndirect(dc
, hPen
);
216 if(!index
) return FALSE
;
218 emr
.emr
.iType
= EMR_SELECTOBJECT
;
219 emr
.emr
.nSize
= sizeof(emr
);
220 emr
.ihObject
= index
;
221 if(!EMFDRV_WriteRecord( dc
, &emr
.emr
))
224 hOldPen
= dc
->w
.hPen
;
230 /***********************************************************************
231 * EMFDRV_SelectObject
233 HGDIOBJ
EMFDRV_SelectObject( DC
*dc
, HGDIOBJ handle
)
235 GDIOBJHDR
* ptr
= GDI_GetObjPtr( handle
, MAGIC_DONTCARE
);
239 TRACE(enhmetafile
, "hdc=%04x %04x\n", dc
->hSelf
, handle
);
244 ret
= EMFDRV_PEN_SelectObject( dc
, handle
);
247 ret
= EMFDRV_BRUSH_SelectObject( dc
, handle
);
250 ret
= EMFDRV_FONT_SelectObject( dc
, handle
);
253 ret
= EMFDRV_BITMAP_SelectObject( dc
, handle
);
256 GDI_HEAP_UNLOCK( handle
);