4 * Copyright 1993,1994 Alexandre Julliard
5 * Copyright 1996 Alex Korobka
7 * PALETTEOBJ is documented in the Dr. Dobbs Journal May 1993.
8 * Information in the "Undocumented Windows" is incorrect.
17 #include "wine/winuser16.h"
21 #include "debugtools.h"
24 DEFAULT_DEBUG_CHANNEL(palette
)
26 PALETTE_DRIVER
*PALETTE_Driver
= NULL
;
28 FARPROC pfnSelectPalette
= NULL
;
29 FARPROC pfnRealizePalette
= NULL
;
31 static UINT SystemPaletteUse
= SYSPAL_STATIC
; /* currently not considered */
33 static HPALETTE16 hPrimaryPalette
= 0; /* used for WM_PALETTECHANGED */
34 static HPALETTE16 hLastRealizedPalette
= 0; /* UnrealizeObject() needs it */
37 /***********************************************************************
40 * Create the system palette.
42 HPALETTE16
PALETTE_Init(void)
48 const PALETTEENTRY
* __sysPalTemplate
= COLOR_GetSystemPaletteTemplate();
50 /* create default palette (20 system colors) */
52 palPtr
= HeapAlloc( GetProcessHeap(), 0,
53 sizeof(LOGPALETTE
) + (NB_RESERVED_COLORS
-1)*sizeof(PALETTEENTRY
));
54 if (!palPtr
) return FALSE
;
56 palPtr
->palVersion
= 0x300;
57 palPtr
->palNumEntries
= NB_RESERVED_COLORS
;
58 for( i
= 0; i
< NB_RESERVED_COLORS
; i
++ )
60 palPtr
->palPalEntry
[i
].peRed
= __sysPalTemplate
[i
].peRed
;
61 palPtr
->palPalEntry
[i
].peGreen
= __sysPalTemplate
[i
].peGreen
;
62 palPtr
->palPalEntry
[i
].peBlue
= __sysPalTemplate
[i
].peBlue
;
63 palPtr
->palPalEntry
[i
].peFlags
= 0;
65 hpalette
= CreatePalette16( palPtr
);
66 HeapFree( GetProcessHeap(), 0, palPtr
);
68 palObj
= (PALETTEOBJ
*) GDI_GetObjPtr( hpalette
, PALETTE_MAGIC
);
71 if (!(palObj
->mapping
= HeapAlloc( GetProcessHeap(), 0, sizeof(int) * 20 )))
72 ERR("Can not create palette mapping -- out of memory!");
73 GDI_HEAP_UNLOCK( hpalette
);
79 /***********************************************************************
80 * PALETTE_ValidateFlags
82 void PALETTE_ValidateFlags(PALETTEENTRY
* lpPalE
, int size
)
86 lpPalE
[i
].peFlags
= PC_SYS_USED
| (lpPalE
[i
].peFlags
& 0x07);
90 /***********************************************************************
91 * CreatePalette16 (GDI.360)
93 HPALETTE16 WINAPI
CreatePalette16( const LOGPALETTE
* palette
)
95 return CreatePalette( palette
);
99 /***********************************************************************
100 * CreatePalette [GDI32.53] Creates a logical color palette
103 * Success: Handle to logical palette
106 HPALETTE WINAPI
CreatePalette(
107 const LOGPALETTE
* palette
) /* [in] Pointer to logical color palette */
109 PALETTEOBJ
* palettePtr
;
113 if (!palette
) return 0;
114 TRACE("entries=%i\n", palette
->palNumEntries
);
116 size
= sizeof(LOGPALETTE
) + (palette
->palNumEntries
- 1) * sizeof(PALETTEENTRY
);
118 hpalette
= GDI_AllocObject( size
+ sizeof(int*) +sizeof(GDIOBJHDR
) , PALETTE_MAGIC
);
119 if (!hpalette
) return 0;
121 palettePtr
= (PALETTEOBJ
*) GDI_HEAP_LOCK( hpalette
);
122 memcpy( &palettePtr
->logpalette
, palette
, size
);
123 PALETTE_ValidateFlags(palettePtr
->logpalette
.palPalEntry
,
124 palettePtr
->logpalette
.palNumEntries
);
125 palettePtr
->mapping
= NULL
;
126 GDI_HEAP_UNLOCK( hpalette
);
128 TRACE(" returning %04x\n", hpalette
);
133 /***********************************************************************
134 * CreateHalftonePalette16 [GDI.?] Creates a halftone palette
137 * Success: Handle to logical halftone palette
140 HPALETTE16 WINAPI
CreateHalftonePalette16(
141 HDC16 hdc
) /* [in] Handle to device context */
143 return CreateHalftonePalette(hdc
);
147 /***********************************************************************
148 * CreateHalftonePalette [GDI32.47] Creates a halftone palette
151 * Success: Handle to logical halftone palette
154 * FIXME: not truly tested
156 HPALETTE WINAPI
CreateHalftonePalette(
157 HDC hdc
) /* [in] Handle to device context */
162 WORD NumberOfEntries
;
163 PALETTEENTRY aEntries
[256];
168 GetSystemPaletteEntries(hdc
, 0, 256, Palette
.aEntries
);
169 return CreatePalette((LOGPALETTE
*)&Palette
);
171 for (r
= 0; r
< 6; r
++) {
172 for (g
= 0; g
< 6; g
++) {
173 for (b
= 0; b
< 6; b
++) {
174 i
= r
+ g
*6 + b
*36 + 10;
175 Palette
.aEntries
[i
].peRed
= r
* 51;
176 Palette
.aEntries
[i
].peGreen
= g
* 51;
177 Palette
.aEntries
[i
].peBlue
= b
* 51;
182 for (i
= 216; i
< 246; i
++) {
183 int v
= (i
- 216) * 8;
184 Palette
.aEntries
[i
].peRed
= v
;
185 Palette
.aEntries
[i
].peGreen
= v
;
186 Palette
.aEntries
[i
].peBlue
= v
;
189 return CreatePalette((LOGPALETTE
*)&Palette
);
193 /***********************************************************************
194 * GetPaletteEntries16 (GDI.363)
196 UINT16 WINAPI
GetPaletteEntries16( HPALETTE16 hpalette
, UINT16 start
,
197 UINT16 count
, LPPALETTEENTRY entries
)
199 return GetPaletteEntries( hpalette
, start
, count
, entries
);
203 /***********************************************************************
204 * GetPaletteEntries [GDI32.209] Retrieves palette entries
207 * Success: Number of entries from logical palette
210 UINT WINAPI
GetPaletteEntries(
211 HPALETTE hpalette
, /* [in] Handle of logical palette */
212 UINT start
, /* [in] First entry to receive */
213 UINT count
, /* [in] Number of entries to receive */
214 LPPALETTEENTRY entries
) /* [out] Address of array receiving entries */
219 TRACE("hpal = %04x, count=%i\n", hpalette
, count
);
221 palPtr
= (PALETTEOBJ
*) GDI_GetObjPtr( hpalette
, PALETTE_MAGIC
);
222 if (!palPtr
) return 0;
224 numEntries
= palPtr
->logpalette
.palNumEntries
;
225 if (start
+count
> numEntries
) count
= numEntries
- start
;
228 if (start
>= numEntries
)
230 GDI_HEAP_UNLOCK( hpalette
);
233 memcpy( entries
, &palPtr
->logpalette
.palPalEntry
[start
],
234 count
* sizeof(PALETTEENTRY
) );
235 for( numEntries
= 0; numEntries
< count
; numEntries
++ )
236 if (entries
[numEntries
].peFlags
& 0xF0)
237 entries
[numEntries
].peFlags
= 0;
238 GDI_HEAP_UNLOCK( hpalette
);
245 /***********************************************************************
246 * SetPaletteEntries16 (GDI.364)
248 UINT16 WINAPI
SetPaletteEntries16( HPALETTE16 hpalette
, UINT16 start
,
249 UINT16 count
, LPPALETTEENTRY entries
)
251 return SetPaletteEntries( hpalette
, start
, count
, entries
);
255 /***********************************************************************
256 * SetPaletteEntries [GDI32.326] Sets color values for range in palette
259 * Success: Number of entries that were set
262 UINT WINAPI
SetPaletteEntries(
263 HPALETTE hpalette
, /* [in] Handle of logical palette */
264 UINT start
, /* [in] Index of first entry to set */
265 UINT count
, /* [in] Number of entries to set */
266 LPPALETTEENTRY entries
) /* [in] Address of array of structures */
271 TRACE("hpal=%04x,start=%i,count=%i\n",hpalette
,start
,count
);
273 palPtr
= (PALETTEOBJ
*) GDI_GetObjPtr( hpalette
, PALETTE_MAGIC
);
274 if (!palPtr
) return 0;
276 numEntries
= palPtr
->logpalette
.palNumEntries
;
277 if (start
>= numEntries
)
279 GDI_HEAP_UNLOCK( hpalette
);
282 if (start
+count
> numEntries
) count
= numEntries
- start
;
283 memcpy( &palPtr
->logpalette
.palPalEntry
[start
], entries
,
284 count
* sizeof(PALETTEENTRY
) );
285 PALETTE_ValidateFlags(palPtr
->logpalette
.palPalEntry
,
286 palPtr
->logpalette
.palNumEntries
);
287 HeapFree( GetProcessHeap(), 0, palPtr
->mapping
);
288 palPtr
->mapping
= NULL
;
289 GDI_HEAP_UNLOCK( hpalette
);
294 /***********************************************************************
295 * ResizePalette16 (GDI.368)
297 BOOL16 WINAPI
ResizePalette16( HPALETTE16 hPal
, UINT16 cEntries
)
299 return ResizePalette( hPal
, cEntries
);
303 /***********************************************************************
304 * ResizePalette [GDI32.289] Resizes logical palette
310 BOOL WINAPI
ResizePalette(
311 HPALETTE hPal
, /* [in] Handle of logical palette */
312 UINT cEntries
) /* [in] Number of entries in logical palette */
314 PALETTEOBJ
* palPtr
= (PALETTEOBJ
*) GDI_GetObjPtr( hPal
, PALETTE_MAGIC
);
315 UINT cPrevEnt
, prevVer
;
316 int prevsize
, size
= sizeof(LOGPALETTE
) + (cEntries
- 1) * sizeof(PALETTEENTRY
);
319 TRACE("hpal = %04x, prev = %i, new = %i\n",
320 hPal
, palPtr
? palPtr
->logpalette
.palNumEntries
: -1,
322 if( !palPtr
) return FALSE
;
323 cPrevEnt
= palPtr
->logpalette
.palNumEntries
;
324 prevVer
= palPtr
->logpalette
.palVersion
;
325 prevsize
= sizeof(LOGPALETTE
) + (cPrevEnt
- 1) * sizeof(PALETTEENTRY
) +
326 sizeof(int*) + sizeof(GDIOBJHDR
);
327 size
+= sizeof(int*) + sizeof(GDIOBJHDR
);
328 mapping
= palPtr
->mapping
;
330 GDI_HEAP_UNLOCK( hPal
);
332 hPal
= GDI_HEAP_REALLOC( hPal
, size
);
333 palPtr
= (PALETTEOBJ
*) GDI_GetObjPtr( hPal
, PALETTE_MAGIC
);
334 if( !palPtr
) return FALSE
;
338 int *newMap
= (int*) HeapReAlloc(GetProcessHeap(), 0,
339 mapping
, cEntries
* sizeof(int) );
342 ERR("Can not resize mapping -- out of memory!");
343 GDI_HEAP_UNLOCK( hPal
);
346 palPtr
->mapping
= newMap
;
349 if( cEntries
> cPrevEnt
)
352 memset(palPtr
->mapping
+ cPrevEnt
, 0, (cEntries
- cPrevEnt
)*sizeof(int));
353 memset( (BYTE
*)palPtr
+ prevsize
, 0, size
- prevsize
);
354 PALETTE_ValidateFlags((PALETTEENTRY
*)((BYTE
*)palPtr
+ prevsize
),
355 cEntries
- cPrevEnt
);
357 palPtr
->logpalette
.palNumEntries
= cEntries
;
358 palPtr
->logpalette
.palVersion
= prevVer
;
359 GDI_HEAP_UNLOCK( hPal
);
364 /***********************************************************************
365 * AnimatePalette16 (GDI.367)
367 void WINAPI
AnimatePalette16( HPALETTE16 hPal
, UINT16 StartIndex
,
368 UINT16 NumEntries
, const PALETTEENTRY
* PaletteColors
)
370 AnimatePalette( hPal
, StartIndex
, NumEntries
, PaletteColors
);
374 /***********************************************************************
375 * AnimatePalette [GDI32.6] Replaces entries in logical palette
382 * Should use existing mapping when animating a primary palette
384 BOOL WINAPI
AnimatePalette(
385 HPALETTE hPal
, /* [in] Handle to logical palette */
386 UINT StartIndex
, /* [in] First entry in palette */
387 UINT NumEntries
, /* [in] Count of entries in palette */
388 const PALETTEENTRY
* PaletteColors
) /* [in] Pointer to first replacement */
390 TRACE("%04x (%i - %i)\n", hPal
, StartIndex
,StartIndex
+NumEntries
);
392 if( hPal
!= STOCK_DEFAULT_PALETTE
)
394 PALETTEOBJ
* palPtr
= (PALETTEOBJ
*)GDI_GetObjPtr(hPal
, PALETTE_MAGIC
);
395 if (!palPtr
) return FALSE
;
397 if( (StartIndex
+ NumEntries
) <= palPtr
->logpalette
.palNumEntries
)
400 for( u
= 0; u
< NumEntries
; u
++ )
401 palPtr
->logpalette
.palPalEntry
[u
+ StartIndex
] = PaletteColors
[u
];
403 pSetMapping(palPtr
, StartIndex
, NumEntries
,
404 hPal
!= hPrimaryPalette
);
405 GDI_HEAP_UNLOCK( hPal
);
413 /***********************************************************************
414 * SetSystemPaletteUse16 (GDI.373)
416 UINT16 WINAPI
SetSystemPaletteUse16( HDC16 hdc
, UINT16 use
)
418 return SetSystemPaletteUse( hdc
, use
);
422 /***********************************************************************
423 * SetSystemPaletteUse [GDI32.335]
426 * Success: Previous system palette
427 * Failure: SYSPAL_ERROR
429 UINT WINAPI
SetSystemPaletteUse(
430 HDC hdc
, /* [in] Handle of device context */
431 UINT use
) /* [in] Palette-usage flag */
433 UINT old
= SystemPaletteUse
;
434 FIXME("(%04x,%04x): stub\n", hdc
, use
);
435 SystemPaletteUse
= use
;
440 /***********************************************************************
441 * GetSystemPaletteUse16 (GDI.374)
443 UINT16 WINAPI
GetSystemPaletteUse16( HDC16 hdc
)
445 return SystemPaletteUse
;
449 /***********************************************************************
450 * GetSystemPaletteUse [GDI32.223] Gets state of system palette
453 * Current state of system palette
455 UINT WINAPI
GetSystemPaletteUse(
456 HDC hdc
) /* [in] Handle of device context */
458 return SystemPaletteUse
;
462 /***********************************************************************
463 * GetSystemPaletteEntries16 (GDI.375)
465 UINT16 WINAPI
GetSystemPaletteEntries16( HDC16 hdc
, UINT16 start
, UINT16 count
,
466 LPPALETTEENTRY entries
)
468 return GetSystemPaletteEntries( hdc
, start
, count
, entries
);
472 /***********************************************************************
473 * GetSystemPaletteEntries [GDI32.222] Gets range of palette entries
476 * Success: Number of entries retrieved from palette
479 UINT WINAPI
GetSystemPaletteEntries(
480 HDC hdc
, /* [in] Handle of device context */
481 UINT start
, /* [in] Index of first entry to be retrieved */
482 UINT count
, /* [in] Number of entries to be retrieved */
483 LPPALETTEENTRY entries
) /* [out] Array receiving system-palette entries */
488 TRACE("hdc=%04x,start=%i,count=%i\n", hdc
,start
,count
);
490 if (!(dc
= (DC
*) GDI_GetObjPtr( hdc
, DC_MAGIC
))) return 0;
491 if (!entries
) return dc
->w
.devCaps
->sizePalette
;
492 if (start
>= dc
->w
.devCaps
->sizePalette
)
494 GDI_HEAP_UNLOCK( hdc
);
497 if (start
+count
>= dc
->w
.devCaps
->sizePalette
)
498 count
= dc
->w
.devCaps
->sizePalette
- start
;
499 for (i
= 0; i
< count
; i
++)
501 *(COLORREF
*)(entries
+ i
) = COLOR_GetSystemPaletteEntry( start
+ i
);
503 TRACE("\tidx(%02x) -> RGB(%08lx)\n",
504 start
+ i
, *(COLORREF
*)(entries
+ i
) );
506 GDI_HEAP_UNLOCK( hdc
);
511 /***********************************************************************
512 * GetNearestPaletteIndex16 (GDI.370)
514 UINT16 WINAPI
GetNearestPaletteIndex16( HPALETTE16 hpalette
, COLORREF color
)
516 return GetNearestPaletteIndex( hpalette
, color
);
520 /***********************************************************************
521 * GetNearestPaletteIndex [GDI32.203] Gets palette index for color
524 * Should index be initialized to CLR_INVALID instead of 0?
527 * Success: Index of entry in logical palette
528 * Failure: CLR_INVALID
530 UINT WINAPI
GetNearestPaletteIndex(
531 HPALETTE hpalette
, /* [in] Handle of logical color palette */
532 COLORREF color
) /* [in] Color to be matched */
534 PALETTEOBJ
* palObj
= (PALETTEOBJ
*)GDI_GetObjPtr( hpalette
, PALETTE_MAGIC
);
538 index
= COLOR_PaletteLookupPixel(palObj
->logpalette
.palPalEntry
,
539 palObj
->logpalette
.palNumEntries
,
540 NULL
, color
, FALSE
);
542 TRACE("(%04x,%06lx): returning %d\n", hpalette
, color
, index
);
543 GDI_HEAP_UNLOCK( hpalette
);
548 /***********************************************************************
549 * GetNearestColor16 (GDI.154)
551 COLORREF WINAPI
GetNearestColor16( HDC16 hdc
, COLORREF color
)
553 return GetNearestColor( hdc
, color
);
557 /***********************************************************************
558 * GetNearestColor [GDI32.202] Gets a system color to match
561 * Should this return CLR_INVALID instead of FadeCafe?
564 * Success: Color from system palette that corresponds to given color
565 * Failure: CLR_INVALID
567 COLORREF WINAPI
GetNearestColor(
568 HDC hdc
, /* [in] Handle of device context */
569 COLORREF color
) /* [in] Color to be matched */
571 COLORREF nearest
= 0xFADECAFE;
575 if ( (dc
= (DC
*) GDI_GetObjPtr( hdc
, DC_MAGIC
)) )
577 palObj
= (PALETTEOBJ
*)
578 GDI_GetObjPtr( (dc
->w
.hPalette
)? dc
->w
.hPalette
579 : STOCK_DEFAULT_PALETTE
, PALETTE_MAGIC
);
580 if (!palObj
) return nearest
;
582 nearest
= COLOR_LookupNearestColor( palObj
->logpalette
.palPalEntry
,
583 palObj
->logpalette
.palNumEntries
, color
);
584 GDI_HEAP_UNLOCK( dc
->w
.hPalette
);
587 TRACE("(%06lx): returning %06lx\n", color
, nearest
);
588 GDI_HEAP_UNLOCK( hdc
);
593 /***********************************************************************
596 int PALETTE_GetObject( PALETTEOBJ
* palette
, int count
, LPSTR buffer
)
598 if (count
> sizeof(WORD
)) count
= sizeof(WORD
);
599 memcpy( buffer
, &palette
->logpalette
.palNumEntries
, count
);
604 /***********************************************************************
605 * PALETTE_UnrealizeObject
607 BOOL
PALETTE_UnrealizeObject( HPALETTE16 hpalette
, PALETTEOBJ
*palette
)
609 if (palette
->mapping
)
611 HeapFree( GetProcessHeap(), 0, palette
->mapping
);
612 palette
->mapping
= NULL
;
614 if (hLastRealizedPalette
== hpalette
) hLastRealizedPalette
= 0;
619 /***********************************************************************
620 * PALETTE_DeleteObject
622 BOOL
PALETTE_DeleteObject( HPALETTE16 hpalette
, PALETTEOBJ
*palette
)
624 HeapFree( GetProcessHeap(), 0, palette
->mapping
);
625 if (hLastRealizedPalette
== hpalette
) hLastRealizedPalette
= 0;
626 return GDI_FreeObject( hpalette
);
630 /***********************************************************************
631 * GDISelectPalette (GDI.361)
633 HPALETTE16 WINAPI
GDISelectPalette16( HDC16 hdc
, HPALETTE16 hpal
, WORD wBkg
)
638 TRACE("%04x %04x\n", hdc
, hpal
);
640 dc
= (DC
*) GDI_GetObjPtr( hdc
, DC_MAGIC
);
643 dc
= (DC
*)GDI_GetObjPtr(hdc
, METAFILE_DC_MAGIC
);
646 prev
= dc
->w
.hPalette
;
647 dc
->w
.hPalette
= hpal
;
648 GDI_HEAP_UNLOCK( hdc
);
649 if (!wBkg
) hPrimaryPalette
= hpal
;
654 /***********************************************************************
655 * GDIRealizePalette (GDI.362)
657 UINT16 WINAPI
GDIRealizePalette16( HDC16 hdc
)
661 DC
* dc
= (DC
*) GDI_GetObjPtr( hdc
, DC_MAGIC
);
664 dc
= (DC
*)GDI_GetObjPtr(hdc
, METAFILE_DC_MAGIC
);
668 TRACE("%04x...\n", hdc
);
670 if( dc
&& dc
->w
.hPalette
!= hLastRealizedPalette
)
672 if( dc
->w
.hPalette
== STOCK_DEFAULT_PALETTE
)
673 return RealizeDefaultPalette16( hdc
);
675 palPtr
= (PALETTEOBJ
*) GDI_GetObjPtr( dc
->w
.hPalette
, PALETTE_MAGIC
);
678 FIXME("invalid selected palette %04x\n",dc
->w
.hPalette
);
682 realized
= PALETTE_Driver
->
683 pSetMapping(palPtr
,0,palPtr
->logpalette
.palNumEntries
,
684 (dc
->w
.hPalette
!= hPrimaryPalette
) ||
685 (dc
->w
.hPalette
== STOCK_DEFAULT_PALETTE
));
686 GDI_HEAP_UNLOCK( dc
->w
.hPalette
);
687 hLastRealizedPalette
= dc
->w
.hPalette
;
689 else TRACE(" skipping (hLastRealizedPalette = %04x)\n",
690 hLastRealizedPalette
);
691 GDI_HEAP_UNLOCK( hdc
);
693 TRACE(" realized %i colors.\n", realized
);
694 return (UINT16
)realized
;
698 /***********************************************************************
699 * RealizeDefaultPalette (GDI.365)
701 UINT16 WINAPI
RealizeDefaultPalette16( HDC16 hdc
)
706 TRACE("%04x\n", hdc
);
708 dc
= (DC
*) GDI_GetObjPtr( hdc
, DC_MAGIC
);
711 dc
= (DC
*)GDI_GetObjPtr(hdc
, METAFILE_DC_MAGIC
);
715 if ( dc
->w
.flags
& DC_MEMORY
)
717 GDI_HEAP_UNLOCK( hdc
);
721 hPrimaryPalette
= STOCK_DEFAULT_PALETTE
;
722 hLastRealizedPalette
= STOCK_DEFAULT_PALETTE
;
724 palPtr
= (PALETTEOBJ
*)GDI_GetObjPtr(STOCK_DEFAULT_PALETTE
, PALETTE_MAGIC
);
725 if (!palPtr
) return 0;
727 /* lookup is needed to account for SetSystemPaletteUse() stuff */
729 return PALETTE_Driver
->pUpdateMapping(palPtr
);
732 /***********************************************************************
733 * IsDCCurrentPalette (GDI.412)
735 BOOL16 WINAPI
IsDCCurrentPalette16(HDC16 hDC
)
737 DC
* dc
= (DC
*)GDI_GetObjPtr( hDC
, DC_MAGIC
);
740 GDI_HEAP_UNLOCK( hDC
);
741 return dc
->w
.hPalette
== hPrimaryPalette
;
747 /***********************************************************************
748 * SelectPalette16 (USER.282)
750 HPALETTE16 WINAPI
SelectPalette16( HDC16 hDC
, HPALETTE16 hPal
,
751 BOOL16 bForceBackground
)
753 return SelectPalette( hDC
, hPal
, bForceBackground
);
757 /***********************************************************************
758 * SelectPalette [GDI32.300] Selects logical palette into DC
761 * Success: Previous logical palette
764 HPALETTE WINAPI
SelectPalette(
765 HDC hDC
, /* [in] Handle of device context */
766 HPALETTE hPal
, /* [in] Handle of logical color palette */
767 BOOL bForceBackground
) /* [in] Foreground/background mode */
769 WORD wBkgPalette
= 1;
770 PALETTEOBJ
* lpt
= (PALETTEOBJ
*) GDI_GetObjPtr( hPal
, PALETTE_MAGIC
);
772 TRACE("dc=%04x,pal=%04x,force=%i\n", hDC
, hPal
, bForceBackground
);
775 TRACE(" entries = %d\n", lpt
->logpalette
.palNumEntries
);
776 GDI_HEAP_UNLOCK( hPal
);
778 if( hPal
!= STOCK_DEFAULT_PALETTE
)
780 HWND hWnd
= WindowFromDC( hDC
);
781 HWND hActive
= GetActiveWindow();
783 /* set primary palette if it's related to current active */
785 if((!hWnd
|| (hActive
== hWnd
|| IsChild16(hActive
,hWnd
))) &&
789 return GDISelectPalette16( hDC
, hPal
, wBkgPalette
);
793 /***********************************************************************
794 * RealizePalette16 (USER.283)
796 UINT16 WINAPI
RealizePalette16( HDC16 hDC
)
798 return RealizePalette( hDC
);
802 /***********************************************************************
803 * RealizePalette [GDI32.280] Maps palette entries to system palette
806 * Success: Number of entries in logical palette
809 UINT WINAPI
RealizePalette(
810 HDC hDC
) /* [in] Handle of device context */
815 if (!(dc
= (DC
*) GDI_GetObjPtr( hDC
, DC_MAGIC
))) return 0;
817 realized
= GDIRealizePalette16( hDC
);
819 /* do not send anything if no colors were changed */
821 if( IsDCCurrentPalette16( hDC
) && realized
&&
822 dc
->w
.devCaps
->sizePalette
)
824 /* Send palette change notification */
827 if( (hWnd
= WindowFromDC( hDC
)) )
828 SendMessage16( HWND_BROADCAST
, WM_PALETTECHANGED
, hWnd
, 0L);
831 GDI_HEAP_UNLOCK( hDC
);
836 /**********************************************************************
837 * UpdateColors16 (GDI.366)
839 INT16 WINAPI
UpdateColors16( HDC16 hDC
)
844 if (!(dc
= (DC
*) GDI_GetObjPtr( hDC
, DC_MAGIC
))) return 0;
846 hWnd
= WindowFromDC( hDC
);
848 /* Docs say that we have to remap current drawable pixel by pixel
849 * but it would take forever given the speed of XGet/PutPixel.
851 if (hWnd
&& dc
->w
.devCaps
->sizePalette
)
852 InvalidateRect( hWnd
, NULL
, FALSE
);
854 GDI_HEAP_UNLOCK( hDC
);
860 /**********************************************************************
861 * UpdateColors [GDI32.359] Remaps current colors to logical palette
867 BOOL WINAPI
UpdateColors(
868 HDC hDC
) /* [in] Handle of device context */
870 UpdateColors16( hDC
);
875 /*********************************************************************
876 * SetMagicColors16 (GDI.606)
878 VOID WINAPI
SetMagicColors16(HDC16 hDC
, COLORREF color
, UINT16 index
)
880 FIXME("(hDC %04x, color %04x, index %04x): stub\n", hDC
, (int)color
, index
);
884 /**********************************************************************
885 * GetICMProfileA [GDI32.316]
887 * Returns the filename of the specified device context's color
888 * management profile, even if color management is not enabled
892 * TRUE if name copied succesfully OR lpszFilename is NULL
893 * FALSE if the buffer length pointed to by lpcbName is too small
896 * The buffer length pointed to by lpcbName is ALWAYS updated to
897 * the length required regardless of other actions this function
901 * How does Windows assign these? Some registry key?
904 #define WINEICM "winefake.icm" /* easy-to-identify fake filename */
906 BOOL WINAPI
GetICMProfileA(HDC hDC
, LPDWORD lpcbName
, LPSTR lpszFilename
)
910 FIXME("(%04x, %p, %p): partial stub\n", hDC
, lpcbName
, lpszFilename
);
912 callerLen
= *lpcbName
;
914 /* all 3 behaviors require the required buffer size to be set */
915 *lpcbName
= strlen(WINEICM
);
917 /* behavior 1: if lpszFilename is NULL, return size of string and no error */
918 if ((DWORD
)lpszFilename
== (DWORD
)0x00000000)
921 /* behavior 2: if buffer size too small, return size of string and error */
922 if (callerLen
< strlen(WINEICM
))
924 SetLastError(ERROR_INSUFFICIENT_BUFFER
);
928 /* behavior 3: if buffer size OK and pointer not NULL, copy and return size */
929 lstrcpyA(lpszFilename
, WINEICM
);