4 * Copyright 1993 Alexandre Julliard
24 /* Object types for EnumObjects() */
28 /***********************************************************************
32 static BRUSHOBJ WhiteBrush
=
34 { 0, BRUSH_MAGIC
, 1 }, /* header */
35 { BS_SOLID
, RGB(255,255,255), 0 } /* logbrush */
38 static BRUSHOBJ LtGrayBrush
=
40 { 0, BRUSH_MAGIC
, 1 }, /* header */
41 { BS_SOLID
, RGB(192,192,192), 0 } /* logbrush */
44 static BRUSHOBJ GrayBrush
=
46 { 0, BRUSH_MAGIC
, 1 }, /* header */
47 { BS_SOLID
, RGB(128,128,128), 0 } /* logbrush */
50 static BRUSHOBJ DkGrayBrush
=
52 { 0, BRUSH_MAGIC
, 1 }, /* header */
53 { BS_SOLID
, RGB(64,64,64), 0 } /* logbrush */
56 static BRUSHOBJ BlackBrush
=
58 { 0, BRUSH_MAGIC
, 1 }, /* header */
59 { BS_SOLID
, RGB(0,0,0), 0 } /* logbrush */
62 static BRUSHOBJ NullBrush
=
64 { 0, BRUSH_MAGIC
, 1 }, /* header */
65 { BS_NULL
, 0, 0 } /* logbrush */
68 static PENOBJ WhitePen
=
70 { 0, PEN_MAGIC
, 1 }, /* header */
71 { PS_SOLID
, { 1, 0 }, RGB(255,255,255) } /* logpen */
74 static PENOBJ BlackPen
=
76 { 0, PEN_MAGIC
, 1 }, /* header */
77 { PS_SOLID
, { 1, 0 }, RGB(0,0,0) } /* logpen */
80 static PENOBJ NullPen
=
82 { 0, PEN_MAGIC
, 1 }, /* header */
83 { PS_NULL
, { 1, 0 }, 0 } /* logpen */
86 static FONTOBJ OEMFixedFont
=
88 { 0, FONT_MAGIC
, 1 }, /* header */
89 { 12, 0, 0, 0, FW_NORMAL
, FALSE
, FALSE
, FALSE
, OEM_CHARSET
,
90 0, 0, DEFAULT_QUALITY
, FIXED_PITCH
| FF_MODERN
, "" }
93 static FONTOBJ AnsiFixedFont
=
95 { 0, FONT_MAGIC
, 1 }, /* header */
96 { 12, 0, 0, 0, FW_NORMAL
, FALSE
, FALSE
, FALSE
, ANSI_CHARSET
,
97 0, 0, DEFAULT_QUALITY
, FIXED_PITCH
| FF_MODERN
, "" }
100 static FONTOBJ AnsiVarFont
=
102 { 0, FONT_MAGIC
, 1 }, /* header */
103 { 12, 0, 0, 0, FW_NORMAL
, FALSE
, FALSE
, FALSE
, ANSI_CHARSET
,
104 0, 0, DEFAULT_QUALITY
, VARIABLE_PITCH
| FF_SWISS
, "" }
107 static FONTOBJ SystemFont
=
109 { 0, FONT_MAGIC
, 1 }, /* header */
110 { 12, 0, 0, 0, FW_BOLD
, FALSE
, FALSE
, FALSE
, ANSI_CHARSET
,
111 0, 0, DEFAULT_QUALITY
, VARIABLE_PITCH
| FF_SWISS
, "" }
114 static FONTOBJ DeviceDefaultFont
=
116 { 0, FONT_MAGIC
, 1 }, /* header */
117 { 12, 0, 0, 0, FW_NORMAL
, FALSE
, FALSE
, FALSE
, ANSI_CHARSET
,
118 0, 0, DEFAULT_QUALITY
, VARIABLE_PITCH
| FF_SWISS
, "" }
121 static FONTOBJ SystemFixedFont
=
123 { 0, FONT_MAGIC
, 1 }, /* header */
124 { 12, 0, 0, 0, FW_BOLD
, FALSE
, FALSE
, FALSE
, ANSI_CHARSET
,
125 0, 0, DEFAULT_QUALITY
, FIXED_PITCH
| FF_MODERN
, "" }
129 static GDIOBJHDR
* StockObjects
[NB_STOCK_OBJECTS
] =
131 (GDIOBJHDR
*) &WhiteBrush
,
132 (GDIOBJHDR
*) &LtGrayBrush
,
133 (GDIOBJHDR
*) &GrayBrush
,
134 (GDIOBJHDR
*) &DkGrayBrush
,
135 (GDIOBJHDR
*) &BlackBrush
,
136 (GDIOBJHDR
*) &NullBrush
,
137 (GDIOBJHDR
*) &WhitePen
,
138 (GDIOBJHDR
*) &BlackPen
,
139 (GDIOBJHDR
*) &NullPen
,
141 (GDIOBJHDR
*) &OEMFixedFont
,
142 (GDIOBJHDR
*) &AnsiFixedFont
,
143 (GDIOBJHDR
*) &AnsiVarFont
,
144 (GDIOBJHDR
*) &SystemFont
,
145 (GDIOBJHDR
*) &DeviceDefaultFont
,
146 NULL
, /* DEFAULT_PALETTE created by COLOR_Init */
147 (GDIOBJHDR
*) &SystemFixedFont
151 /***********************************************************************
154 * GDI initialization.
156 BOOL32
GDI_Init(void)
159 extern BOOL32
X11DRV_Init(void);
161 /* Initialize drivers */
163 if (!X11DRV_Init()) return FALSE
;
165 /* Create default palette */
167 if (!(hpalette
= COLOR_Init())) return FALSE
;
168 StockObjects
[DEFAULT_PALETTE
] = (GDIOBJHDR
*)GDI_HEAP_LIN_ADDR( hpalette
);
170 /* Create default bitmap */
172 if (!BITMAP_Init()) return FALSE
;
174 /* Initialize brush dithering */
176 if (!BRUSH_Init()) return FALSE
;
178 /* Initialize fonts */
180 if (!FONT_Init()) return FALSE
;
186 /***********************************************************************
189 HGDIOBJ16
GDI_AllocObject( WORD size
, WORD magic
)
191 static DWORD count
= 0;
193 HGDIOBJ16 handle
= GDI_HEAP_ALLOC( size
);
194 if (!handle
) return 0;
195 obj
= (GDIOBJHDR
*) GDI_HEAP_LIN_ADDR( handle
);
198 obj
->dwCount
= ++count
;
203 /***********************************************************************
206 BOOL32
GDI_FreeObject( HGDIOBJ16 handle
)
210 /* Can't free stock objects */
211 if ((handle
>= FIRST_STOCK_HANDLE
) && (handle
<= LAST_STOCK_HANDLE
))
214 object
= (GDIOBJHDR
*) GDI_HEAP_LIN_ADDR( handle
);
215 if (!object
) return FALSE
;
216 object
->wMagic
= 0; /* Mark it as invalid */
220 GDI_HEAP_FREE( handle
);
224 /***********************************************************************
227 * Return a pointer to the GDI object associated to the handle.
228 * Return NULL if the object has the wrong magic number.
230 GDIOBJHDR
* GDI_GetObjPtr( HGDIOBJ16 handle
, WORD magic
)
232 GDIOBJHDR
* ptr
= NULL
;
234 if ((handle
>= FIRST_STOCK_HANDLE
) && (handle
<= LAST_STOCK_HANDLE
))
235 ptr
= StockObjects
[handle
- FIRST_STOCK_HANDLE
];
237 ptr
= (GDIOBJHDR
*) GDI_HEAP_LIN_ADDR( handle
);
238 if (!ptr
) return NULL
;
239 if ((magic
!= MAGIC_DONTCARE
) && (ptr
->wMagic
!= magic
)) return NULL
;
244 /***********************************************************************
245 * DeleteObject (GDI.69)
247 BOOL
DeleteObject( HGDIOBJ16 obj
)
249 /* Check if object is valid */
251 GDIOBJHDR
* header
= (GDIOBJHDR
*) GDI_HEAP_LIN_ADDR( obj
);
252 if (!header
) return FALSE
;
254 dprintf_gdi(stddeb
, "DeleteObject: %04x\n", obj
);
258 switch(header
->wMagic
)
260 case PEN_MAGIC
: return GDI_FreeObject( obj
);
261 case BRUSH_MAGIC
: return BRUSH_DeleteObject( obj
, (BRUSHOBJ
*)header
);
262 case FONT_MAGIC
: return GDI_FreeObject( obj
);
263 case PALETTE_MAGIC
: return PALETTE_DeleteObject(obj
,(PALETTEOBJ
*)header
);
264 case BITMAP_MAGIC
: return BITMAP_DeleteObject( obj
, (BITMAPOBJ
*)header
);
265 case REGION_MAGIC
: return REGION_DeleteObject( obj
, (RGNOBJ
*)header
);
271 /***********************************************************************
272 * GetStockObject (GDI.87)
274 HGDIOBJ16
GetStockObject( INT16 obj
)
276 if ((obj
< 0) || (obj
>= NB_STOCK_OBJECTS
)) return 0;
277 if (!StockObjects
[obj
]) return 0;
278 dprintf_gdi(stddeb
, "GetStockObject: returning %d\n",
279 FIRST_STOCK_HANDLE
+ obj
);
280 return (HGDIOBJ16
)(FIRST_STOCK_HANDLE
+ obj
);
284 /***********************************************************************
285 * GetObject16 (GDI.82)
287 INT16
GetObject16( HANDLE16 handle
, INT16 count
, LPVOID buffer
)
289 GDIOBJHDR
* ptr
= NULL
;
290 dprintf_gdi(stddeb
, "GetObject16: %04x %d %p\n", handle
, count
, buffer
);
291 if (!count
) return 0;
293 if ((handle
>= FIRST_STOCK_HANDLE
) && (handle
<= LAST_STOCK_HANDLE
))
294 ptr
= StockObjects
[handle
- FIRST_STOCK_HANDLE
];
296 ptr
= (GDIOBJHDR
*) GDI_HEAP_LIN_ADDR( handle
);
302 return PEN_GetObject( (PENOBJ
*)ptr
, count
, buffer
);
304 return BRUSH_GetObject( (BRUSHOBJ
*)ptr
, count
, buffer
);
306 return BITMAP_GetObject16( (BITMAPOBJ
*)ptr
, count
, buffer
);
308 return FONT_GetObject16( (FONTOBJ
*)ptr
, count
, buffer
);
310 return PALETTE_GetObject( (PALETTEOBJ
*)ptr
, count
, buffer
);
316 /***********************************************************************
317 * GetObject32A (GDI32.204)
319 INT32
GetObject32A( HANDLE32 handle
, INT32 count
, LPVOID buffer
)
321 GDIOBJHDR
* ptr
= NULL
;
322 dprintf_gdi(stddeb
, "GetObject32A: %08x %d %p\n", handle
, count
, buffer
);
323 if (!count
) return 0;
325 if ((handle
>= FIRST_STOCK_HANDLE
) && (handle
<= LAST_STOCK_HANDLE
))
326 ptr
= StockObjects
[handle
- FIRST_STOCK_HANDLE
];
328 ptr
= (GDIOBJHDR
*) GDI_HEAP_LIN_ADDR( handle
);
334 return BITMAP_GetObject32( (BITMAPOBJ
*)ptr
, count
, buffer
);
336 return FONT_GetObject32A( (FONTOBJ
*)ptr
, count
, buffer
);
340 fprintf( stderr
, "GetObject32: magic %04x not implemented\n",
348 /***********************************************************************
349 * GetObject32W (GDI32.206)
351 INT32
GetObject32W( HANDLE32 handle
, INT32 count
, LPVOID buffer
)
353 return GetObject32A( handle
, count
, buffer
);
357 /***********************************************************************
358 * SelectObject (GDI.45)
360 HGDIOBJ16
SelectObject( HDC hdc
, HGDIOBJ16 handle
)
362 GDIOBJHDR
* ptr
= NULL
;
365 dprintf_gdi(stddeb
, "SelectObject: hdc=%04x %04x\n", hdc
, handle
);
366 if ((handle
>= FIRST_STOCK_HANDLE
) && (handle
<= LAST_STOCK_HANDLE
))
367 ptr
= StockObjects
[handle
- FIRST_STOCK_HANDLE
];
369 ptr
= (GDIOBJHDR
*) GDI_HEAP_LIN_ADDR( handle
);
372 dc
= (DC
*) GDI_GetObjPtr( hdc
, DC_MAGIC
);
375 dc
= (DC
*)GDI_GetObjPtr(hdc
, METAFILE_DC_MAGIC
);
382 return PEN_SelectObject( dc
, handle
, (PENOBJ
*)ptr
);
384 return BRUSH_SelectObject( dc
, handle
, (BRUSHOBJ
*)ptr
);
386 return BITMAP_SelectObject( dc
, handle
, (BITMAPOBJ
*)ptr
);
388 return FONT_SelectObject( dc
, handle
, (FONTOBJ
*)ptr
);
390 return (HGDIOBJ16
)SelectClipRgn( hdc
, handle
);
396 /***********************************************************************
397 * UnrealizeObject (GDI.150)
399 BOOL
UnrealizeObject( HGDIOBJ16 obj
)
401 /* Check if object is valid */
403 GDIOBJHDR
* header
= (GDIOBJHDR
*) GDI_HEAP_LIN_ADDR( obj
);
404 if (!header
) return FALSE
;
406 dprintf_gdi( stddeb
, "UnrealizeObject: %04x\n", obj
);
408 /* Unrealize object */
410 switch(header
->wMagic
)
413 return PALETTE_UnrealizeObject( obj
, (PALETTEOBJ
*)header
);
416 /* Windows resets the brush origin. We don't need to. */
423 /***********************************************************************
424 * EnumObjects (GDI.71)
426 INT
EnumObjects( HDC hdc
, INT nObjType
, GOBJENUMPROC16 lpEnumFunc
,
429 /* Solid colors to enumerate */
430 static const COLORREF solid_colors
[] =
431 { RGB(0x00,0x00,0x00), RGB(0xff,0xff,0xff),
432 RGB(0xff,0x00,0x00), RGB(0x00,0xff,0x00),
433 RGB(0x00,0x00,0xff), RGB(0xff,0xff,0x00),
434 RGB(0xff,0x00,0xff), RGB(0x00,0xff,0xff),
435 RGB(0x80,0x00,0x00), RGB(0x00,0x80,0x00),
436 RGB(0x80,0x80,0x00), RGB(0x00,0x00,0x80),
437 RGB(0x80,0x00,0x80), RGB(0x00,0x80,0x80),
438 RGB(0x80,0x80,0x80), RGB(0xc0,0xc0,0xc0)
443 LOGBRUSH16
*brush
= NULL
;
445 dprintf_gdi( stddeb
, "EnumObjects: %04x %d %08lx %08lx\n",
446 hdc
, nObjType
, (DWORD
)lpEnumFunc
, lParam
);
450 /* Enumerate solid pens */
451 if (!(pen
= SEGPTR_NEW(LOGPEN16
))) break;
452 for (i
= 0; i
< sizeof(solid_colors
)/sizeof(solid_colors
[0]); i
++)
454 pen
->lopnStyle
= PS_SOLID
;
455 pen
->lopnWidth
.x
= 1;
456 pen
->lopnWidth
.y
= 0;
457 pen
->lopnColor
= solid_colors
[i
];
458 retval
= lpEnumFunc( SEGPTR_GET(pen
), lParam
);
459 dprintf_gdi( stddeb
, "EnumObject: solid pen %08lx, ret=%d\n",
460 solid_colors
[i
], retval
);
467 /* Enumerate solid brushes */
468 if (!(brush
= SEGPTR_NEW(LOGBRUSH16
))) break;
469 for (i
= 0; i
< sizeof(solid_colors
)/sizeof(solid_colors
[0]); i
++)
471 brush
->lbStyle
= BS_SOLID
;
472 brush
->lbColor
= solid_colors
[i
];
474 retval
= lpEnumFunc( SEGPTR_GET(brush
), lParam
);
475 dprintf_gdi( stddeb
, "EnumObject: solid brush %08lx, ret=%d\n",
476 solid_colors
[i
], retval
);
480 /* Now enumerate hatched brushes */
481 if (retval
) for (i
= HS_HORIZONTAL
; i
<= HS_DIAGCROSS
; i
++)
483 brush
->lbStyle
= BS_HATCHED
;
484 brush
->lbColor
= RGB(0,0,0);
486 retval
= lpEnumFunc( SEGPTR_GET(brush
), lParam
);
487 dprintf_gdi( stddeb
, "EnumObject: hatched brush %d, ret=%d\n",
495 fprintf( stderr
, "EnumObjects: invalid type %d\n", nObjType
);
502 /***********************************************************************
503 * IsGDIObject (GDI.462)
505 BOOL16
IsGDIObject( HGDIOBJ16 handle
)
507 GDIOBJHDR
*object
= (GDIOBJHDR
*) GDI_HEAP_LIN_ADDR( handle
);
509 return (object
->wMagic
>=PEN_MAGIC
&& object
->wMagic
<= METAFILE_DC_MAGIC
);
514 /***********************************************************************
517 INT16
MulDiv16( INT16 foo
, INT16 bar
, INT16 baz
)
520 if (!baz
) return -32768;
521 ret
= (foo
* bar
) / baz
;
522 if ((ret
> 32767) || (ret
< -32767)) return -32768;
527 /***********************************************************************
528 * MulDiv32 (KERNEL32.391)
530 INT32
MulDiv32( INT32 foo
, INT32 bar
, INT32 baz
)
535 ret
= ((long long)foo
* bar
) / baz
;
536 if ((ret
> 2147483647) || (ret
< -2147483647)) return -1;
540 return (foo
* bar
) / baz
;