Tue Jan 4 13:01:33 1994 David Metcalfe <david@prism.demon.co.uk> * [window/caret.c] Modified code to use system timer. Jan 9, 94 martin2@trgcorp.solucorp.qc.ca (Martin Ayotte) * [windows/win.c] Windows create if required new XLIB MenuBar & CaptionBar. * [windows/defwnd.c] WM_CALCSIZE Move & Resize caption, menubar & scrollbars. (I'm not sure it's the good place for it, but it work...) * [loader/resource.c] optimize in FindResourceByNumber, make lseek() if next type ... * [controls/scroll.c] scrollbar buttons are now using system resources bitmaps. * [controls/caption.c] - new file ... captionbar showing title, close button with SysMenu, and other buttons using system resources bitmaps. * [controls/menu.c] New functions: SetMenuItemBitmaps() with 'glues', Make new version of LoadMenu() & ParseMenu(), ( put #define USE_POPUPMENU ). Implementation of MenuBar functions. * [sysres.dll] New bitmaps for system such OBM_CLOSE, OBM_MINIMIZE, OBM_UPARROWI. New SYSMENU menu, it don't work yet ! :-(( Tue Jan 11 05:27:45 1994 julliard@di.epfl.ch (Alexandre Julliard * [memory/atom.c] Fixed a bug that could cause atoms to be case-sensitive. * [misc/rect.c] Bug fix in SubtractRect(). * [objects/clipping.c] Bug fix when setting the clip mask to an empty region. * [windows/dce.c] Bug fix in ReleaseDC(). * [windows/dialog.c] Call AdjustWindowRectEx() before creating the dialog window. Added support for DS_MODALFRAME style. * [windows/event.c] Cleaned up event handling and removed old Xt stuff. Moved double-click handling to windows/message.c * [windows/focus.c] Bug fix: only set the X focus when the window is viewable. * [windows/graphics.c] Rewritten DrawReliefRect() to use brush instead of pen, and to use the system colors. * [windows/message.c] Implemented WM_NCHITTEST message sending, and non-client mouse messages. Cleaned up double-click handling, and removed the Xt code. * [windows/nonclient.c] (New file) Implemented AdjustWindowRect(). Implemented WM_NCCALCSIZE, WM_NCHITTEST and WM_NCPAINT handling. * [windows/painting.c] Added sending of the WM_NCPAINT message in BeginPaint(). * [windows/sysmetrics.c] [include/sysmetrics.h] (New files) Implemented system metrics. * [windows/win.c] Bug fix in setting the parent and owner in CreateWindow(). Removed the Xt code. * [windows/winpos.c] Added sending of the WM_NCPAINT message in SetWindowPos(). Removed the Xt code.
194 lines
5.1 KiB
C
194 lines
5.1 KiB
C
/*
|
|
* GDI palette objects
|
|
*
|
|
* Copyright 1993 Alexandre Julliard
|
|
*/
|
|
|
|
static char Copyright[] = "Copyright Alexandre Julliard, 1993";
|
|
|
|
#include <stdlib.h>
|
|
#ifdef linux
|
|
#include <values.h>
|
|
#endif
|
|
#ifdef __NetBSD__
|
|
#include <limits.h>
|
|
#define MAXINT INT_MAX
|
|
#endif
|
|
#include <X11/Xlib.h>
|
|
|
|
#include "gdi.h"
|
|
|
|
extern Colormap COLOR_WinColormap;
|
|
|
|
GDIOBJHDR * PALETTE_systemPalette;
|
|
|
|
|
|
/***********************************************************************
|
|
* PALETTE_Init
|
|
*/
|
|
BOOL PALETTE_Init()
|
|
{
|
|
int i, size;
|
|
XColor color;
|
|
HPALETTE hpalette;
|
|
LOGPALETTE * palPtr;
|
|
|
|
size = DefaultVisual( display, DefaultScreen(display) )->map_entries;
|
|
palPtr = malloc( sizeof(LOGPALETTE) + (size-1)*sizeof(PALETTEENTRY) );
|
|
if (!palPtr) return FALSE;
|
|
palPtr->palVersion = 0x300;
|
|
palPtr->palNumEntries = size;
|
|
memset( palPtr->palPalEntry, 0xff, size*sizeof(PALETTEENTRY) );
|
|
|
|
for (i = 0; i < size; i++)
|
|
{
|
|
color.pixel = i;
|
|
XQueryColor( display, COLOR_WinColormap, &color );
|
|
palPtr->palPalEntry[i].peRed = color.red >> 8;
|
|
palPtr->palPalEntry[i].peGreen = color.green >> 8;
|
|
palPtr->palPalEntry[i].peBlue = color.blue >> 8;
|
|
palPtr->palPalEntry[i].peFlags = 0;
|
|
}
|
|
|
|
hpalette = CreatePalette( palPtr );
|
|
PALETTE_systemPalette = (GDIOBJHDR *) GDI_HEAP_ADDR( hpalette );
|
|
free( palPtr );
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* CreatePalette (GDI.360)
|
|
*/
|
|
HPALETTE CreatePalette( LOGPALETTE * palette )
|
|
{
|
|
PALETTEOBJ * palettePtr;
|
|
HPALETTE hpalette;
|
|
int size;
|
|
|
|
size = sizeof(LOGPALETTE) + (palette->palNumEntries - 1) * sizeof(PALETTEENTRY);
|
|
hpalette = GDI_AllocObject( sizeof(GDIOBJHDR) + size, PALETTE_MAGIC );
|
|
if (!hpalette) return 0;
|
|
palettePtr = (PALETTEOBJ *) GDI_HEAP_ADDR( hpalette );
|
|
memcpy( &palettePtr->logpalette, palette, size );
|
|
return hpalette;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* GetPaletteEntries (GDI.363)
|
|
*/
|
|
WORD GetPaletteEntries( HPALETTE hpalette, WORD start, WORD count,
|
|
LPPALETTEENTRY entries )
|
|
{
|
|
PALETTEOBJ * palPtr;
|
|
int numEntries;
|
|
|
|
palPtr = (PALETTEOBJ *) GDI_GetObjPtr( hpalette, PALETTE_MAGIC );
|
|
if (!palPtr) return 0;
|
|
numEntries = palPtr->logpalette.palNumEntries;
|
|
if (start >= numEntries) return 0;
|
|
if (start+count > numEntries) count = numEntries - start;
|
|
memcpy( entries, &palPtr->logpalette.palPalEntry[start],
|
|
count * sizeof(PALETTEENTRY) );
|
|
return count;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* SetPaletteEntries (GDI.364)
|
|
*/
|
|
WORD SetPaletteEntries( HPALETTE hpalette, WORD start, WORD count,
|
|
LPPALETTEENTRY entries )
|
|
{
|
|
PALETTEOBJ * palPtr;
|
|
int numEntries;
|
|
|
|
palPtr = (PALETTEOBJ *) GDI_GetObjPtr( hpalette, PALETTE_MAGIC );
|
|
if (!palPtr) return 0;
|
|
numEntries = palPtr->logpalette.palNumEntries;
|
|
if (start >= numEntries) return 0;
|
|
if (start+count > numEntries) count = numEntries - start;
|
|
memcpy( &palPtr->logpalette.palPalEntry[start], entries,
|
|
count * sizeof(PALETTEENTRY) );
|
|
return count;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* GetNearestPaletteIndex (GDI.370)
|
|
*/
|
|
WORD GetNearestPaletteIndex( HPALETTE hpalette, COLORREF color )
|
|
{
|
|
int i, minDist, dist;
|
|
WORD index = 0;
|
|
BYTE r, g, b;
|
|
PALETTEENTRY * entry;
|
|
PALETTEOBJ * palPtr;
|
|
|
|
palPtr = (PALETTEOBJ *) GDI_GetObjPtr( hpalette, PALETTE_MAGIC );
|
|
if (!palPtr) return 0;
|
|
|
|
if ((COLOR_WinColormap != DefaultColormapOfScreen(screen)) &&
|
|
(hpalette == STOCK_DEFAULT_PALETTE))
|
|
{
|
|
if ((color & 0xffffff) == 0) return 0; /* Entry 0 is black */
|
|
if ((color & 0xffffff) == 0xffffff) /* Max entry is white */
|
|
return palPtr->logpalette.palNumEntries - 1;
|
|
}
|
|
|
|
r = GetRValue(color);
|
|
g = GetGValue(color);
|
|
b = GetBValue(color);
|
|
|
|
entry = palPtr->logpalette.palPalEntry;
|
|
for (i = 0, minDist = MAXINT; i < palPtr->logpalette.palNumEntries; i++)
|
|
{
|
|
if (entry->peFlags != 0xff)
|
|
{
|
|
dist = (r - entry->peRed) * (r - entry->peRed) +
|
|
(g - entry->peGreen) * (g - entry->peGreen) +
|
|
(b - entry->peBlue) * (b - entry->peBlue);
|
|
if (dist < minDist)
|
|
{
|
|
minDist = dist;
|
|
index = i;
|
|
}
|
|
}
|
|
entry++;
|
|
}
|
|
#ifdef DEBUG_GDI
|
|
printf( "GetNearestPaletteIndex(%x,%06x) : returning %d\n",
|
|
hpalette, color, index );
|
|
#endif
|
|
return index;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* PALETTE_GetObject
|
|
*/
|
|
int PALETTE_GetObject( PALETTEOBJ * palette, int count, LPSTR buffer )
|
|
{
|
|
if (count > sizeof(WORD)) count = sizeof(WORD);
|
|
memcpy( buffer, &palette->logpalette.palNumEntries, count );
|
|
return count;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* SelectPalette (USER.282)
|
|
*/
|
|
HPALETTE SelectPalette(HDC hDC, HPALETTE hPal, BOOL bForceBackground)
|
|
{
|
|
return (HPALETTE)NULL;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* RealizePalette (USER.283)
|
|
*/
|
|
int RealizePalette(HDC hDC)
|
|
{
|
|
return 0;
|
|
}
|
|
|