2 * GDI OEM bitmap objects
4 * Copyright 1994, 1995 Alexandre Julliard
11 #include <X11/Xutil.h>
17 #include "cursoricon.h"
22 /* Include OEM pixmaps */
23 #include "bitmaps/obm_cdrom"
24 #include "bitmaps/obm_harddisk"
25 #include "bitmaps/obm_drive"
26 #include "bitmaps/obm_folder2"
27 #include "bitmaps/obm_folder"
28 #include "bitmaps/obm_lfarrowi"
29 #include "bitmaps/obm_rgarrowi"
30 #include "bitmaps/obm_dnarrowi"
31 #include "bitmaps/obm_uparrowi"
32 #include "bitmaps/obm_combo"
33 #include "bitmaps/obm_mnarrow"
34 #include "bitmaps/obm_lfarrowd"
35 #include "bitmaps/obm_rgarrowd"
36 #include "bitmaps/obm_dnarrowd"
37 #include "bitmaps/obm_uparrowd"
38 #include "bitmaps/obm_restored"
39 #include "bitmaps/obm_restore"
40 #include "bitmaps/obm_lfarrow"
41 #include "bitmaps/obm_rgarrow"
42 #include "bitmaps/obm_dnarrow"
43 #include "bitmaps/obm_uparrow"
44 #include "bitmaps/obm_old_restore"
45 #include "bitmaps/obm_old_zoom"
46 #include "bitmaps/obm_old_reduce"
47 #include "bitmaps/obm_btncorners"
48 #include "bitmaps/obm_checkboxes"
49 #include "bitmaps/obm_check"
50 #include "bitmaps/obm_btsize"
51 #include "bitmaps/obm_old_lfarrow"
52 #include "bitmaps/obm_old_rgarrow"
53 #include "bitmaps/obm_old_dnarrow"
54 #include "bitmaps/obm_old_uparrow"
55 #include "bitmaps/obm_size"
56 #include "bitmaps/obm_old_close"
57 #include "bitmaps/obm_trtype"
60 #include "bitmaps/obm_zoomd"
61 #include "bitmaps/obm_reduced"
62 #include "bitmaps/obm_zoom"
63 #include "bitmaps/obm_reduce"
64 #include "bitmaps/obm_close"
66 #include "bitmaps/obm_zoomd_95"
67 #include "bitmaps/obm_reduced_95"
68 #include "bitmaps/obm_zoom_95"
69 #include "bitmaps/obm_reduce_95"
70 #include "bitmaps/obm_close_95"
71 #include "bitmaps/obm_closed_95"
72 #endif /* WIN_95_LOOK */
74 #define OBM_FIRST OBM_TRTYPE /* First OEM bitmap */
75 #define OBM_LAST OBM_OLD_CLOSE /* Last OEM bitmap */
79 char** data
; /* Pointer to bitmap data */
80 BOOL color
; /* Is it a color bitmap? */
81 } OBM_Pixmaps_Data
[OBM_LAST
-OBM_FIRST
+1] = {
82 { obm_trtype
, TRUE
}, /* OBM_TRTYPE */
83 { obm_cdrom
, TRUE
}, /* OBM_CDROM */
84 { obm_harddisk
, TRUE
}, /* OBM_HARDDISK */
85 { obm_drive
, TRUE
}, /* OBM_DRIVE */
86 { obm_folder2
, TRUE
}, /* OBM_FOLDER2 */
87 { obm_folder
, TRUE
}, /* OBM_FOLDER */
88 { obm_lfarrowi
, TRUE
}, /* OBM_LFARROWI */
89 { obm_rgarrowi
, TRUE
}, /* OBM_RGARROWI */
90 { obm_dnarrowi
, TRUE
}, /* OBM_DNARROWI */
91 { obm_uparrowi
, TRUE
}, /* OBM_UPARROWI */
92 { obm_combo
, FALSE
}, /* OBM_COMBO */
93 { obm_mnarrow
, FALSE
}, /* OBM_MNARROW */
94 { obm_lfarrowd
, TRUE
}, /* OBM_LFARROWD */
95 { obm_rgarrowd
, TRUE
}, /* OBM_RGARROWD */
96 { obm_dnarrowd
, TRUE
}, /* OBM_DNARROWD */
97 { obm_uparrowd
, TRUE
}, /* OBM_UPARROWD */
98 { obm_restored
, TRUE
}, /* OBM_RESTORED */
100 { obm_zoomd_95
, TRUE
}, /* OBM_ZOOMD */
101 { obm_reduced_95
, TRUE
}, /* OBM_REDUCED */
103 { obm_zoomd
, TRUE
}, /* OBM_ZOOMD */
104 { obm_reduced
, TRUE
}, /* OBM_REDUCED */
106 { obm_restore
, TRUE
}, /* OBM_RESTORE */
108 { obm_zoom_95
, TRUE
}, /* OBM_ZOOM */
109 { obm_reduce_95
, TRUE
}, /* OBM_REDUCE */
111 { obm_zoom
, TRUE
}, /* OBM_ZOOM */
112 { obm_reduce
, TRUE
}, /* OBM_REDUCE */
114 { obm_lfarrow
, TRUE
}, /* OBM_LFARROW */
115 { obm_rgarrow
, TRUE
}, /* OBM_RGARROW */
116 { obm_dnarrow
, TRUE
}, /* OBM_DNARROW */
117 { obm_uparrow
, TRUE
}, /* OBM_UPARROW */
119 { obm_close_95
, TRUE
}, /* OBM_CLOSE */
121 { obm_close
, TRUE
}, /* OBM_CLOSE */
123 { obm_old_restore
, FALSE
}, /* OBM_OLD_RESTORE */
124 { obm_old_zoom
, FALSE
}, /* OBM_OLD_ZOOM */
125 { obm_old_reduce
, FALSE
}, /* OBM_OLD_REDUCE */
126 { obm_btncorners
, FALSE
}, /* OBM_BTNCORNERS */
127 { obm_checkboxes
, FALSE
}, /* OBM_CHECKBOXES */
128 { obm_check
, FALSE
}, /* OBM_CHECK */
129 { obm_btsize
, FALSE
}, /* OBM_BTSIZE */
130 { obm_old_lfarrow
, FALSE
}, /* OBM_OLD_LFARROW */
131 { obm_old_rgarrow
, FALSE
}, /* OBM_OLD_RGARROW */
132 { obm_old_dnarrow
, FALSE
}, /* OBM_OLD_DNARROW */
133 { obm_old_uparrow
, FALSE
}, /* OBM_OLD_UPARROW */
134 { obm_size
, FALSE
}, /* OBM_SIZE */
135 { obm_old_close
, FALSE
}, /* OBM_OLD_CLOSE */
139 /* Include OEM icons */
140 #include "bitmaps/oic_sample"
141 #include "bitmaps/oic_hand"
142 #include "bitmaps/oic_ques"
143 #include "bitmaps/oic_bang"
144 #include "bitmaps/oic_note"
145 #include "bitmaps/oic_portrait"
146 #include "bitmaps/oic_landscape"
147 #include "bitmaps/oic_wineicon"
149 #define OIC_FIRST OIC_SAMPLE /* First OEM icon */
150 #define OIC_LAST OIC_WINEICON /* Last OEM icon */
152 static char ** const OBM_Icons_Data
[OIC_LAST
-OIC_FIRST
+1] =
154 oic_sample
, /* OIC_SAMPLE */
155 oic_hand
, /* OIC_HAND */
156 oic_ques
, /* OIC_QUES */
157 oic_bang
, /* OIC_BANG */
158 oic_note
, /* OIC_NOTE */
159 oic_portrait
, /* OIC_PORTRAIT */
160 oic_landscape
, /* OIC_LANDSCAPE */
161 oic_wineicon
/* OIC_WINEICON */
165 /* Include OEM cursors */
166 #include "bitmaps/ocr_normal"
167 #include "bitmaps/ocr_ibeam"
168 #include "bitmaps/ocr_wait"
169 #include "bitmaps/ocr_cross"
170 #include "bitmaps/ocr_up"
171 #include "bitmaps/ocr_size"
172 #include "bitmaps/ocr_icon"
173 #include "bitmaps/ocr_sizenwse"
174 #include "bitmaps/ocr_sizenesw"
175 #include "bitmaps/ocr_sizewe"
176 #include "bitmaps/ocr_sizens"
177 #include "bitmaps/ocr_bummer"
178 #include "bitmaps/ocr_dragobject"
180 #include "bitmaps/ocr_sizeall"
181 #include "bitmaps/ocr_icocur"
184 /* Cursor are not all contiguous (go figure...) */
185 #define OCR_FIRST0 OCR_BUMMER
186 #define OCR_LAST0 OCR_DRAGOBJECT
189 #define OCR_FIRST1 OCR_NORMAL
190 #define OCR_LAST1 OCR_UP
191 #define OCR_BASE1 (OCR_BASE0 + OCR_LAST0 - OCR_FIRST0 + 1)
193 #define OCR_FIRST2 OCR_SIZE
194 #define OCR_LAST2 OCR_SIZENS
195 #define OCR_BASE2 (OCR_BASE1 + OCR_LAST1 - OCR_FIRST1 + 1)
197 #define NB_CURSORS (OCR_BASE2 + OCR_LAST2 - OCR_FIRST2 + 1)
198 static char **OBM_Cursors_Data
[NB_CURSORS
] =
200 ocr_bummer
, /* OCR_BUMMER */
201 ocr_dragobject
,/* OCR_DRAGOBJECT */
202 ocr_normal
, /* OCR_NORMAL */
203 ocr_ibeam
, /* OCR_IBEAM */
204 ocr_wait
, /* OCR_WAIT */
205 ocr_cross
, /* OCR_CROSS */
207 ocr_size
, /* OCR_SIZE */
208 ocr_icon
, /* OCR_ICON */
209 ocr_sizenwse
, /* OCR_SIZENWSE */
210 ocr_sizenesw
, /* OCR_SIZENESW */
211 ocr_sizewe
, /* OCR_SIZEWE */
212 ocr_sizens
/* OCR_SIZENS */
214 ocr_sizeall
, /* OCR_SIZEALL */
215 ocr_icocur
/* OCR_ICOCUR */
219 static HCURSOR OBM_Cursors
[NB_CURSORS
];
222 /* All the colors used in the xpm files must be included in this */
223 /* list, to make sure that the loaded bitmaps only use colors from */
224 /* the Windows colormap. Note: the PALETTEINDEX() are not really */
225 /* palette indexes, but system colors that will be converted to */
226 /* indexes later on. */
232 } OBM_SymbolicColors
[] =
234 { "black", RGB(0,0,0) },
235 { "white", RGB(255,255,255) },
236 { "red", RGB(255,0,0) },
237 { "green", RGB(0,255,0) },
238 { "blue", RGB(0,0,255) },
239 { "yellow", RGB(255,255,0) },
240 { "cyan", RGB(0,255,255) },
241 { "dkyellow", RGB(128,128,0) },
242 { "purple", RGB(128,0,128) },
243 { "ltgray", RGB(192,192,192) },
244 { "dkgray", RGB(128,128,128) },
245 { "foldercol", RGB(0,191,191) },
246 { "button_face", PALETTEINDEX(COLOR_BTNFACE
) },
247 { "button_shadow", PALETTEINDEX(COLOR_BTNSHADOW
) },
248 { "button_highlight", PALETTEINDEX(COLOR_BTNHIGHLIGHT
) },
249 { "button_edge", PALETTEINDEX(COLOR_BTNHIGHLIGHT
) },
250 { "button_text", PALETTEINDEX(COLOR_BTNTEXT
) },
251 { "window_frame", PALETTEINDEX(COLOR_WINDOWFRAME
) }
254 #define NB_COLOR_SYMBOLS \
255 (sizeof(OBM_SymbolicColors)/sizeof(OBM_SymbolicColors[0]))
257 /* These are the symbolic colors for monochrome bitmaps */
258 /* This is needed to make sure that black is always 0 and */
259 /* white always 1, as required by Windows. */
261 static XpmColorSymbol OBM_BlackAndWhite
[2] =
263 { "black", NULL
, 0 },
264 { "white", NULL
, 0xffffffff }
267 static XpmColorSymbol
*OBM_Colors
= NULL
;
270 /***********************************************************************
271 * OBM_InitColorSymbols
273 static BOOL
OBM_InitColorSymbols()
277 if (OBM_Colors
) return TRUE
; /* Already initialised */
279 OBM_Colors
= (XpmColorSymbol
*) malloc( sizeof(XpmColorSymbol
) *
281 if (!OBM_Colors
) return FALSE
;
282 for (i
= 0; i
< NB_COLOR_SYMBOLS
; i
++)
284 OBM_Colors
[i
].name
= OBM_SymbolicColors
[i
].name
;
285 OBM_Colors
[i
].value
= NULL
;
286 if (OBM_SymbolicColors
[i
].color
& 0xff000000) /* PALETTEINDEX */
287 OBM_Colors
[i
].pixel
= COLOR_ToPhysical( NULL
,
288 GetSysColor(OBM_SymbolicColors
[i
].color
& 0xff));
290 OBM_Colors
[i
].pixel
= COLOR_ToPhysical( NULL
,
291 OBM_SymbolicColors
[i
].color
);
297 /***********************************************************************
300 * Allocate a GDI bitmap.
302 static HBITMAP
OBM_MakeBitmap( WORD width
, WORD height
,
303 WORD bpp
, Pixmap pixmap
)
306 BITMAPOBJ
* bmpObjPtr
;
308 if (!pixmap
) return 0;
310 hbitmap
= GDI_AllocObject( sizeof(BITMAPOBJ
), BITMAP_MAGIC
);
311 if (!hbitmap
) return 0;
313 bmpObjPtr
= (BITMAPOBJ
*) GDI_HEAP_LIN_ADDR( hbitmap
);
314 bmpObjPtr
->size
.cx
= 0;
315 bmpObjPtr
->size
.cy
= 0;
316 bmpObjPtr
->pixmap
= pixmap
;
317 bmpObjPtr
->bitmap
.bmType
= 0;
318 bmpObjPtr
->bitmap
.bmWidth
= width
;
319 bmpObjPtr
->bitmap
.bmHeight
= height
;
320 bmpObjPtr
->bitmap
.bmWidthBytes
= BITMAP_WIDTH_BYTES( width
, bpp
);
321 bmpObjPtr
->bitmap
.bmPlanes
= 1;
322 bmpObjPtr
->bitmap
.bmBitsPixel
= bpp
;
323 bmpObjPtr
->bitmap
.bmBits
= NULL
;
328 /***********************************************************************
331 * Create the 2 bitmaps from XPM data.
333 static BOOL
OBM_CreateBitmaps( char **data
, BOOL color
, HBITMAP
*hBitmap
,
334 HBITMAP
*hBitmapMask
, POINT16
*hotspot
)
336 Pixmap pixmap
, pixmask
;
337 XpmAttributes
*attrs
;
340 attrs
= (XpmAttributes
*)xmalloc( XpmAttributesSize() );
341 attrs
->valuemask
= XpmColormap
| XpmDepth
| XpmColorSymbols
|XpmHotspot
;
342 attrs
->colormap
= COLOR_GetColormap();
343 attrs
->depth
= color
? screenDepth
: 1;
344 attrs
->colorsymbols
= (attrs
->depth
> 1) ? OBM_Colors
: OBM_BlackAndWhite
;
345 attrs
->numsymbols
= (attrs
->depth
> 1) ? NB_COLOR_SYMBOLS
: 2;
347 err
= XpmCreatePixmapFromData( display
, rootWindow
, data
,
348 &pixmap
, &pixmask
, attrs
);
350 if (err
!= XpmSuccess
)
357 hotspot
->x
= attrs
->x_hotspot
;
358 hotspot
->y
= attrs
->y_hotspot
;
360 *hBitmap
= OBM_MakeBitmap( attrs
->width
, attrs
->height
,
361 attrs
->depth
, pixmap
);
362 if (hBitmapMask
) *hBitmapMask
= OBM_MakeBitmap(attrs
->width
, attrs
->height
,
367 if (pixmap
) XFreePixmap( display
, pixmap
);
368 if (pixmask
) XFreePixmap( display
, pixmask
);
369 if (*hBitmap
) GDI_FreeObject( *hBitmap
);
370 if (hBitmapMask
&& *hBitmapMask
) GDI_FreeObject( *hBitmapMask
);
377 /***********************************************************************
380 HBITMAP
OBM_LoadBitmap( WORD id
)
384 if ((id
< OBM_FIRST
) || (id
> OBM_LAST
)) return 0;
387 if (!OBM_InitColorSymbols()) return 0;
389 if (!CallTo32_LargeStack( (int(*)())OBM_CreateBitmaps
, 5,
390 OBM_Pixmaps_Data
[id
].data
,
391 OBM_Pixmaps_Data
[id
].color
,
392 &hbitmap
, NULL
, NULL
))
394 fprintf( stderr
, "Error creating OEM bitmap %d\n", OBM_FIRST
+id
);
401 /***********************************************************************
404 HANDLE
OBM_LoadCursorIcon( WORD id
, BOOL fCursor
)
407 CURSORICONINFO
*pInfo
;
408 BITMAPOBJ
*bmpXor
, *bmpAnd
;
409 HBITMAP hXorBits
, hAndBits
;
411 int sizeXor
, sizeAnd
;
415 if ((id
>= OCR_FIRST1
) && (id
<= OCR_LAST1
))
416 id
= OCR_BASE1
+ id
- OCR_FIRST1
;
417 else if ((id
>= OCR_FIRST2
) && (id
<= OCR_LAST2
))
418 id
= OCR_BASE2
+ id
- OCR_FIRST2
;
419 else if ((id
>= OCR_FIRST0
) && (id
<= OCR_LAST0
))
420 id
= OCR_BASE0
+ id
- OCR_FIRST0
;
422 if (OBM_Cursors
[id
]) return OBM_Cursors
[id
];
426 if ((id
< OIC_FIRST
) || (id
> OIC_LAST
)) return 0;
430 if (!OBM_InitColorSymbols()) return 0;
432 if (!CallTo32_LargeStack( (int(*)())OBM_CreateBitmaps
, 5,
433 fCursor
? OBM_Cursors_Data
[id
] : OBM_Icons_Data
[id
],
434 !fCursor
, &hXorBits
, &hAndBits
, &hotspot
))
436 fprintf( stderr
, "Error creating OEM cursor/icon %d\n", id
);
440 bmpXor
= (BITMAPOBJ
*) GDI_GetObjPtr( hXorBits
, BITMAP_MAGIC
);
441 bmpAnd
= (BITMAPOBJ
*) GDI_GetObjPtr( hAndBits
, BITMAP_MAGIC
);
442 sizeXor
= bmpXor
->bitmap
.bmHeight
* bmpXor
->bitmap
.bmWidthBytes
;
443 sizeAnd
= bmpXor
->bitmap
.bmHeight
* BITMAP_WIDTH_BYTES( bmpXor
->bitmap
.bmWidth
, 1 );
445 if (!(handle
= GlobalAlloc16( GMEM_MOVEABLE
,
446 sizeof(CURSORICONINFO
) + sizeXor
+ sizeAnd
)))
448 DeleteObject( hXorBits
);
449 DeleteObject( hAndBits
);
453 pInfo
= (CURSORICONINFO
*)GlobalLock16( handle
);
454 pInfo
->ptHotSpot
.x
= hotspot
.x
;
455 pInfo
->ptHotSpot
.y
= hotspot
.y
;
456 pInfo
->nWidth
= bmpXor
->bitmap
.bmWidth
;
457 pInfo
->nHeight
= bmpXor
->bitmap
.bmHeight
;
458 pInfo
->nWidthBytes
= bmpXor
->bitmap
.bmWidthBytes
;
459 pInfo
->bPlanes
= bmpXor
->bitmap
.bmPlanes
;
460 pInfo
->bBitsPerPixel
= bmpXor
->bitmap
.bmBitsPixel
;
464 /* Invert the mask */
466 XSetFunction( display
, BITMAP_monoGC
, GXinvert
);
467 XFillRectangle( display
, bmpAnd
->pixmap
, BITMAP_monoGC
, 0, 0,
468 bmpAnd
->bitmap
.bmWidth
, bmpAnd
->bitmap
.bmHeight
);
469 XSetFunction( display
, BITMAP_monoGC
, GXcopy
);
471 /* Set the masked pixels to black */
473 if (bmpXor
->bitmap
.bmBitsPixel
!= 1)
475 XSetForeground( display
, BITMAP_colorGC
,
476 COLOR_ToPhysical( NULL
, RGB(0,0,0) ));
477 XSetBackground( display
, BITMAP_colorGC
, 0 );
478 XSetFunction( display
, BITMAP_colorGC
, GXor
);
479 XCopyPlane(display
, bmpAnd
->pixmap
, bmpXor
->pixmap
, BITMAP_colorGC
,
480 0, 0, bmpXor
->bitmap
.bmWidth
, bmpXor
->bitmap
.bmHeight
,
482 XSetFunction( display
, BITMAP_colorGC
, GXcopy
);
486 if (hAndBits
) GetBitmapBits( hAndBits
, sizeAnd
, (char *)(pInfo
+ 1) );
487 else memset( (char *)(pInfo
+ 1), 0xff, sizeAnd
);
488 GetBitmapBits( hXorBits
, sizeXor
, (char *)(pInfo
+ 1) + sizeAnd
);
490 DeleteObject( hXorBits
);
491 DeleteObject( hAndBits
);
493 if (fCursor
) OBM_Cursors
[id
] = handle
;