mirror of
git://source.winehq.org/git/wine.git
synced 2024-11-05 18:01:34 +00:00
e2abbb1bb3
Sun Mar 19 16:30:20 1995 Alexandre Julliard (julliard@sunsite.unc.edu) * [*/*] Implemented a new memory mapping scheme. There's no longer a one-to-one mapping between 16-bit and 32-bit pointers. Please see file DEVELOPERS-HINTS for technical details. * [controls/scroll.c] Fixed bug when dragging mouse in horizontal scrollbars. * [tools/build.c] [if1632/*.spec] Removed support for C callback functions and for re-ordering of the 32-bit arguments, as these were never used. This should allow a more efficient callback scheme to be implemented. * [if1632/olecli.spec] Reduced the number of entries to make the 16-bit code fit in 64k. This limitation will soon be removed. * [loader/ldt.c] Rewrote LDT manipulation functions and implemented LDT_GetEntry(). * [memory/global.c] Rewrote Global*() routines to use the new selector allocation mechanism. * [memory/local.c] Rewrote local heap handling to use a Windows-compatible layout (not really finished yet). Implemented TOOLHELP heap-walking routines. * [memory/selector.c] Implemented LDT manipulation API functions. Tue Mar 14 19:50:28 EST 1995 William Magro (wmagro@tc.cornell.edu) * [windows/defdlg.c] Fixed problem where dialogs closed using the System menu ('Close' item or double click on close box) would hang Wine. Sun Mar 12 14:28:13 1995 Michael Patra <micky@marie.physik.TU-Berlin.DE> * [controls/listbox.c] Removed most of the statements for sending a notification message ListBoxDirectory(), DlgDirSelect(), DlgDirList(): Improved the code; Borland's standard file open dialog will work now. * [misc/main.c], [misc/file.c], [miscemu/int21.c] Added support for new command line option "-allowreadonly". If set an attempt to open a read only file in write mode will be converted to opening it read only (many programs try to open all files in read/write mode even if they only intend to read it - this might cause a few under problems under an unix-like environment where most files are read only for a "normal" user) * [loader/selector.c] GetMemoryReference(): Added support for __AHIncr and __AHShift * [misc/dos_fs.c] DOS_SimplifyPath(): This routine simplifies path names ( e.g., it will change "/usr///local/bin/../lib//a" to "/usr/local/lib/a" ) match(): rewritten * [objects/text.c] TEXT_NextLine(): Removed a bug in the handling of LF's * [miscemu/int21.c] GetFileDateTime(): Fixed. SetFileDateTime() is still broken. Sat Mar 11 19:46:19 1995 Martin von Loewis <loewis@informatik.hu-berlin.de> * [controls/menu.c] ChangeMenu: defaults to MF_INSERT InsertMenu: allow insertion even if position is one after last item * [if1632/Imakefile] [if1632/compobj.spec] [if1632/relay.c] [if1632/storage.spec] [include/dlls.h] Added stubs for STORAGE.DLL and COMPOBJ.DLL * [if1632/user.spec] [windows/message.c] InSendMessage: new function * [include/neexe.h][include/ne_image.c] NE_FixupSegment: fixed handling of additive records * [loader/selector.c] GetEntryDLLName: return NULL instead of pointer to DLL.0 if not found * [loader/signal.c] win_fault: Enter debugger on SIGFPE, too Wed Mar 1 21:47:42 1995 Cameron Heide (heide@ee.ualberta.ca) * [miscemu/int*.c] Various minor modifications to the clock tick counter, FindFirst/FindNext funcs, and DPB handling.
213 lines
5.8 KiB
C
213 lines
5.8 KiB
C
/*
|
|
* GDI palette objects
|
|
*
|
|
* Copyright 1993,1994 Alexandre Julliard
|
|
*
|
|
static char Copyright[] = "Copyright Alexandre Julliard, 1993,1994";
|
|
*/
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <limits.h>
|
|
|
|
#if !defined (MAXINT)
|
|
#include <limits.h>
|
|
#define MAXINT INT_MAX
|
|
#endif
|
|
|
|
#include <X11/Xlib.h>
|
|
#include "color.h"
|
|
#include "palette.h"
|
|
#include "stddebug.h"
|
|
/* #define DEBUG_PALETTE */
|
|
#include "debug.h"
|
|
|
|
/***********************************************************************
|
|
* 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_LIN_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;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* GetSystemPaletteEntries (GDI.375)
|
|
*/
|
|
WORD GetSystemPaletteEntries( HDC hdc, WORD start, WORD count,
|
|
LPPALETTEENTRY entries )
|
|
{
|
|
WORD i;
|
|
DC *dc;
|
|
XColor color;
|
|
|
|
if (!(dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ))) return 0;
|
|
if (start >= dc->w.devCaps->sizePalette) return 0;
|
|
if (start+count >= dc->w.devCaps->sizePalette)
|
|
count = dc->w.devCaps->sizePalette - start;
|
|
for (i = 0; i < count; i++)
|
|
{
|
|
color.pixel = start + i;
|
|
XQueryColor( display, COLOR_WinColormap, &color );
|
|
entries[i].peRed = color.red >> 8;
|
|
entries[i].peGreen = color.green >> 8;
|
|
entries[i].peBlue = color.blue >> 8;
|
|
entries[i].peFlags = 0;
|
|
}
|
|
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; minDist !=0 &&
|
|
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++;
|
|
}
|
|
dprintf_palette(stddeb,"GetNearestPaletteIndex(%x,%06lx): returning %d\n",
|
|
hpalette, color, index );
|
|
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;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* GDISelectPalette (GDI.361)
|
|
*/
|
|
HPALETTE GDISelectPalette( HDC hdc, HPALETTE hpal )
|
|
{
|
|
HPALETTE prev;
|
|
DC *dc;
|
|
|
|
dprintf_palette(stddeb, "GDISelectPalette: %d %d\n", hdc, hpal );
|
|
if (!(dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ))) return 0;
|
|
prev = dc->w.hPalette;
|
|
dc->w.hPalette = hpal;
|
|
if (hpal != STOCK_DEFAULT_PALETTE) COLOR_SetMapping( dc, 0, 0, 0 );
|
|
else RealizeDefaultPalette( hdc ); /* Always realize default palette */
|
|
return prev;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* GDIRealizePalette (GDI.362)
|
|
*/
|
|
UINT GDIRealizePalette( HDC hdc )
|
|
{
|
|
dprintf_palette(stdnimp, "GDIRealizePalette: %d\n", hdc );
|
|
return 0;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* SelectPalette (USER.282)
|
|
*/
|
|
HPALETTE SelectPalette(HDC hDC, HPALETTE hPal, BOOL bForceBackground)
|
|
{
|
|
return GDISelectPalette( hDC, hPal );
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* RealizePalette (USER.283)
|
|
*/
|
|
UINT RealizePalette(HDC hDC)
|
|
{
|
|
return GDIRealizePalette( hDC );
|
|
}
|
|
|