4 * Copyright (C) Robert Pouliot <krynos@clic.net>
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
26 #include "gdi_private.h"
27 #include "wine/wingdi16.h"
28 #include "wine/debug.h"
30 WINE_DEFAULT_DEBUG_CHANNEL(wing
);
32 /*************************************************************************
35 * The Windows Game dll provides a number of functions designed to allow
36 * programmers to bypass Gdi and write directly to video memory. The intention
37 * was to bolster the use of Windows as a gaming platform and remove the
38 * need for Dos based games using 32 bit Dos extenders.
40 * This initial approach could not compete with the performance of Dos games
41 * (such as Doom and Warcraft) at the time, and so this dll was eventually
42 * superseded by DirectX. It should not be used by new applications, and is
43 * provided only for compatibility with older Windows programs.
46 typedef enum WING_DITHER_TYPE
48 WING_DISPERSED_4x4
, WING_DISPERSED_8x8
, WING_CLUSTERED_4x4
52 * WinG DIB bitmaps can be selected into DC and then scribbled upon
53 * by GDI functions. They can also be changed directly. This gives us
55 * - use original WinG 16-bit DLL
56 * requires working 16-bit driver interface
57 * - implement DIB graphics driver from scratch
59 * - use shared pixmaps
60 * won't work with some videocards and/or videomodes
64 /***********************************************************************
65 * WinGCreateDC (WING.1001)
67 * Create a new WinG device context.
73 * Success: A handle to the created device context.
74 * Failure: A NULL handle.
76 HDC16 WINAPI
WinGCreateDC16(void)
79 return CreateCompatibleDC16(0);
82 /***********************************************************************
83 * WinGRecommendDIBFormat (WING.1002)
85 * Get the recommended format of bitmaps for the current display.
88 * bmpi [O] Destination for format information
91 * Success: TRUE. bmpi is filled with the best (fastest) bitmap format
92 * Failure: FALSE, if bmpi is NULL.
94 BOOL16 WINAPI
WinGRecommendDIBFormat16(BITMAPINFO
*bmpi
)
96 static const WCHAR szDisplayW
[] = { 'D','I','S','P','L','A','Y','\0' };
98 TRACE("(%p)\n", bmpi
);
102 hdc
= CreateDCW( szDisplayW
, NULL
, NULL
, NULL
);
103 bmpi
->bmiHeader
.biSize
= sizeof(BITMAPINFOHEADER
);
104 bmpi
->bmiHeader
.biWidth
= 320;
105 bmpi
->bmiHeader
.biHeight
= -1;
106 bmpi
->bmiHeader
.biPlanes
= 1;
107 bmpi
->bmiHeader
.biBitCount
= 8;
108 bmpi
->bmiHeader
.biCompression
= BI_RGB
;
109 bmpi
->bmiHeader
.biSizeImage
= 0;
110 bmpi
->bmiHeader
.biXPelsPerMeter
= 0;
111 bmpi
->bmiHeader
.biYPelsPerMeter
= 0;
112 bmpi
->bmiHeader
.biClrUsed
= 0;
113 bmpi
->bmiHeader
.biClrImportant
= 0;
118 /***********************************************************************
119 * WinGCreateBitmap (WING.1003)
121 * Create a new WinG bitmap.
124 * hdc [I] WinG device context
125 * bmpi [I] Information about the bitmap
126 * bits [I] Location of the bitmap image data
129 * Success: A handle to the created bitmap.
130 * Failure: A NULL handle.
132 HBITMAP16 WINAPI
WinGCreateBitmap16(HDC16 hdc
, BITMAPINFO
*bmpi
,
135 TRACE("(%d,%p,%p)\n", hdc
, bmpi
, bits
);
136 TRACE(": create %ldx%ldx%d bitmap\n", bmpi
->bmiHeader
.biWidth
,
137 bmpi
->bmiHeader
.biHeight
, bmpi
->bmiHeader
.biPlanes
);
138 return CreateDIBSection16(hdc
, bmpi
, 0, bits
, 0, 0);
141 /***********************************************************************
142 * WinGGetDIBPointer (WING.1004)
144 SEGPTR WINAPI
WinGGetDIBPointer16(HBITMAP16 hWinGBitmap
, BITMAPINFO
* bmpi
)
146 BITMAPOBJ
* bmp
= (BITMAPOBJ
*) GDI_GetObjPtr( HBITMAP_32(hWinGBitmap
),
150 TRACE("(%d,%p)\n", hWinGBitmap
, bmpi
);
153 if (bmpi
) FIXME(": Todo - implement setting BITMAPINFO\n");
155 res
= bmp
->segptr_bits
;
156 GDI_ReleaseObj( HBITMAP_32(hWinGBitmap
) );
160 /***********************************************************************
161 * WinGSetDIBColorTable (WING.1006)
163 * Set all or part of the color table for a WinG device context.
166 * hdc [I] WinG device context
167 * start [I] Start color
168 * num [I] Number of entries to set
169 * colors [I] Array of color data
172 * The number of entries set.
174 UINT16 WINAPI
WinGSetDIBColorTable16(HDC16 hdc
, UINT16 start
, UINT16 num
,
177 TRACE("(%d,%d,%d,%p)\n", hdc
, start
, num
, colors
);
178 return SetDIBColorTable16(hdc
, start
, num
, colors
);
181 /***********************************************************************
182 * WinGGetDIBColorTable (WING.1005)
184 * Get all or part of the color table for a WinG device context.
187 * hdc [I] WinG device context
188 * start [I] Start color
189 * num [I] Number of entries to set
190 * colors [O] Destination for the array of color data
193 * The number of entries retrieved.
195 UINT16 WINAPI
WinGGetDIBColorTable16(HDC16 hdc
, UINT16 start
, UINT16 num
,
198 TRACE("(%d,%d,%d,%p)\n", hdc
, start
, num
, colors
);
199 return GetDIBColorTable16(hdc
, start
, num
, colors
);
202 /***********************************************************************
203 * WinGCreateHalfTonePalette (WING.1007)
205 * Create a half tone palette.
211 * Success: A handle to the created palette.
212 * Failure: A NULL handle.
214 HPALETTE16 WINAPI
WinGCreateHalfTonePalette16(void)
216 HDC16 hdc
= CreateCompatibleDC16(0);
217 HPALETTE16 ret
= CreateHalftonePalette16(hdc
);
223 /***********************************************************************
224 * WinGCreateHalfToneBrush (WING.1008)
226 * Create a half tone brush for a WinG device context.
229 * winDC [I] WinG device context
231 * type [I] Desired dithering type.
234 * Success: A handle to the created brush.
235 * Failure: A NULL handle.
237 HBRUSH16 WINAPI
WinGCreateHalfToneBrush16(HDC16 winDC
, COLORREF col
,
238 WING_DITHER_TYPE type
)
240 TRACE("(%d,%ld,%d)\n", winDC
, col
, type
);
241 return CreateSolidBrush16(col
);
244 /***********************************************************************
245 * WinGStretchBlt (WING.1009)
249 BOOL16 WINAPI
WinGStretchBlt16(HDC16 destDC
, INT16 xDest
, INT16 yDest
,
250 INT16 widDest
, INT16 heiDest
,
251 HDC16 srcDC
, INT16 xSrc
, INT16 ySrc
,
252 INT16 widSrc
, INT16 heiSrc
)
255 TRACE("(%d,%d,...)\n", destDC
, srcDC
);
256 SetStretchBltMode16 ( destDC
, COLORONCOLOR
);
257 retval
=StretchBlt16(destDC
, xDest
, yDest
, widDest
, heiDest
, srcDC
,
258 xSrc
, ySrc
, widSrc
, heiSrc
, SRCCOPY
);
259 SetStretchBltMode16 ( destDC
, BLACKONWHITE
);
263 /***********************************************************************
264 * WinGBitBlt (WING.1010)
268 BOOL16 WINAPI
WinGBitBlt16(HDC16 destDC
, INT16 xDest
, INT16 yDest
,
269 INT16 widDest
, INT16 heiDest
, HDC16 srcDC
,
270 INT16 xSrc
, INT16 ySrc
)
272 TRACE("(%d,%d,...)\n", destDC
, srcDC
);
273 return BitBlt16(destDC
, xDest
, yDest
, widDest
, heiDest
, srcDC
,
274 xSrc
, ySrc
, SRCCOPY
);