4 * Started by Robert Pouliot <krynos@clic.net>
22 typedef enum WING_DITHER_TYPE
24 WING_DISPERSED_4x4, WING_DISPERSED_8x8, WING_CLUSTERED_4x4
27 static int __WinGOK = -1;
30 * WinG DIB bitmaps can be selected into DC and then scribbled upon
31 * by GDI functions. They can also be changed directly. This gives us
33 * - use original WinG 16-bit DLL
34 * requires working 16-bit driver interface
35 * - implement DIB graphics driver from scratch
37 * - use shared pixmaps
38 * won't work with some videocards and/or videomodes
42 static BITMAPINFOHEADER __bmpiWinG = { 0, 1, -1, 1, 8, BI_RGB, 1, 0, 0, 0, 0 };
44 static void __initWinG(void)
48 Status s = TSXShmQueryExtension(display);
51 int i = TSXShmPixmapFormat(display);
52 if( i == ZPixmap && screenDepth == 8 )
58 FIXME(wing,"WinG: incorrect depth or unsupported card.\n");
63 /***********************************************************************
64 * WinGCreateDC16 (WING.1001)
66 HDC16 WINAPI WinGCreateDC16(void)
71 return CreateCompatibleDC16(0);
75 /***********************************************************************
76 * WinGRecommendDIBFormat16 (WING.1002)
78 BOOL16 WINAPI WinGRecommendDIBFormat16(BITMAPINFO *fmt)
80 FIXME(wing,"(%p): stub\n", fmt);
82 if( __WinGOK > 0 && fmt )
84 memcpy(&fmt->bmiHeader, &__bmpiWinG, sizeof(BITMAPINFOHEADER));
90 /***********************************************************************
91 * WinGCreateBitmap16 (WING.1003)
93 HBITMAP16 WINAPI WinGCreateBitmap16(HDC16 winDC, BITMAPINFO *header,
96 FIXME(wing,"(%x,%p,%p): empty stub! (expect failure)\n",
98 if( __WinGOK > 0 && header )
100 BITMAPINFOHEADER* bmpi = &header->bmiHeader;
102 FIXME(wing,"bytes=%i,planes=%i,bpp=%i,x=%i,y=%i,rle=0x%08x,size=%i\n",
103 (int)bmpi->biSize, bmpi->biPlanes, bmpi->biBitCount,
104 (int)bmpi->biWidth, (int)bmpi->biHeight,
105 (unsigned)bmpi->biCompression, (int)bmpi->biSizeImage);
107 #ifdef PRELIMINARY_WING16_SUPPORT
108 if( bmpi->biPlanes == __bmpiWinG.biPlanes && bmpi->biBitCount == __bmpiWinG.biBitCount &&
109 bmpi->biCompression == __bmpiWinG.biCompression && (int)bmpi->biHeight < 0 &&
112 unsigned bytes = (bmpi->biWidth + bmpi->biWidth % 2)*(-bmpi->biHeight) * bmpi->biBitCount/8;
113 int key = shmget(IPC_PRIVATE, bytes, IPC_CREAT | 0x01FF);
117 /* Create the BITMAPOBJ
119 * FIXME: A facility to manage shared memory structures
120 * which would clean up when Wine crashes. Perhaps a part of
121 * IPC code can be adapted. Otherwise this code leaves a lot
122 * of junk in shared memory.
125 HBITMAP16 hbitmap = GDI_AllocObject( sizeof(BITMAPOBJ), BITMAP_MAGIC );
128 __ShmBitmapCtl* p = (__ShmBitmapCtl*)xmalloc(sizeof(__ShmBitmapCtl));
129 BITMAPOBJ* bmpObjPtr = (BITMAPOBJ *) GDI_HEAP_LOCK( hbitmap );
131 bmpObjPtr->size.cx = 0;
132 bmpObjPtr->size.cy = 0;
133 bmpObjPtr->bitmap.bmType = 0;
134 bmpObjPtr->bitmap.bmWidth = (INT16)abs(bmpi->biWidth);
135 bmpObjPtr->bitmap.bmHeight = -(INT16)bmpi->biHeight;
136 bmpObjPtr->bitmap.bmPlanes = (BYTE)bmpi->biPlanes;
137 bmpObjPtr->bitmap.bmBitsPixel = (BYTE)bmpi->biBitCount;
138 bmpObjPtr->bitmap.bmWidthBytes =
139 (INT16)BITMAP_WIDTH_BYTES( bmpObjPtr->bitmap.bmWidth, bmpi->biBitCount );
140 bmpObjPtr->bitmap.bmBits = (SEGPTR)p;
143 p->si.shmaddr = shmat(key, NULL, 0);
144 p->si.readOnly = False;
150 TSXShmAttach(display, &p->si);
151 bmpObjPtr->pixmap = XShmCreatePixmap(display, rootWindow,
152 p->si.shmaddr, &p->si, bmpObjPtr->bitmap.bmWidth,
153 bmpObjPtr->bitmap.bmHeight, bmpi->biBitCount );
154 if( bmpObjPtr->pixmap )
156 sel = SELECTOR_AllocBlock( p->si.shmaddr, bytes,
157 SEGMENT_DATA, FALSE, FALSE);
158 if (sel) p->bits = PTR_SEG_OFF_TO_SEGPTR(sel,0);
159 else TSXFreePixmap( display, bmpObjPtr->pixmap );
163 shmdt( p->si.shmaddr );
164 p->si.shmaddr = NULL;
169 GDI_FreeObject( hbitmap );
173 GDI_HEAP_UNLOCK( hbitmap );
182 /***********************************************************************
183 * WinGGetDIBPointer (WING.1004)
185 SEGPTR WINAPI WinGGetDIBPointer16(HBITMAP16 hWinGBitmap, BITMAPINFO* bmpi)
187 #ifdef PRELIMINARY_WING16_SUPPORT
188 BITMAPOBJ* bmp = (BITMAPOBJ *) GDI_GetObjPtr( hWinGBitmap, BITMAP_MAGIC );
192 __ShmBitmapCtl* p = (__ShmBitmapCtl*)bmp->bitmap.bmBits;
195 if( bmpi ) memcpy( bmpi, &__bmpiWinG, sizeof(BITMAPINFOHEADER));
196 GDI_HEAP_UNLOCK( hWinGBitmap );
204 /***********************************************************************
205 * WinGSetDIBColorTable (WING.1004)
207 UINT16 WINAPI WinGSetDIBColorTable16(HDC16 hWinGDC, UINT16 start, UINT16 num,
210 FIXME(wing,"(%x,%d,%d,%p): empty stub!\n",hWinGDC,start,num,pColor);
214 /***********************************************************************
215 * WinGGetDIBColorTable16 (WING.1005)
217 UINT16 WINAPI WinGGetDIBColorTable16(HDC16 winDC, UINT16 start,
218 UINT16 num, RGBQUAD* colors)
220 FIXME(wing,"(%x,%d,%d,%p): empty stub!\n",winDC,start,num,colors);
224 /***********************************************************************
225 * WinGCreateHalfTonePalette16 (WING.1007)
227 HPALETTE16 WINAPI WinGCreateHalfTonePalette16(void)
229 FIXME(wing,"(void): empty stub!\n");
233 /***********************************************************************
234 * WinGCreateHalfToneBrush16 (WING.1008)
236 HPALETTE16 WINAPI WinGCreateHalfToneBrush16(HDC16 winDC, COLORREF col,
237 WING_DITHER_TYPE type)
239 FIXME(wing,"(...): empty stub!\n");
243 /***********************************************************************
244 * WinGStretchBlt16 (WING.1009)
246 BOOL16 WINAPI WinGStretchBlt16(HDC16 destDC, INT16 xDest, INT16 yDest,
247 INT16 widDest, INT16 heiDest,
248 HDC16 srcDC, INT16 xSrc, INT16 ySrc,
249 INT16 widSrc, INT16 heiSrc)
252 return StretchBlt16(destDC, xDest, yDest, widDest, heiDest, srcDC, xSrc, ySrc, widSrc, heiSrc, SRCCOPY);
255 /***********************************************************************
256 * WinGBitBlt16 (WING.1010)
258 BOOL16 WINAPI WinGBitBlt16(HDC16 destDC, INT16 xDest, INT16 yDest,
259 INT16 widDest, INT16 heiDest, HDC16 srcDC,
260 INT16 xSrc, INT16 ySrc)
262 /* destDC is a display DC, srcDC is a memory DC */
266 if (!(dcDst = (DC *)GDI_GetObjPtr( destDC, DC_MAGIC ))) return FALSE;
267 if (!(dcSrc = (DC *) GDI_GetObjPtr( srcDC, DC_MAGIC ))) return FALSE;
269 if (dcDst->w.flags & DC_DIRTY) CLIPPING_UpdateGCRegion( dcDst );
271 xSrc = dcSrc->w.DCOrgX + XLPTODP( dcSrc, xSrc );
272 ySrc = dcSrc->w.DCOrgY + YLPTODP( dcSrc, ySrc );
273 xDest = dcDst->w.DCOrgX + XLPTODP( dcDst, xDest );
274 yDest = dcDst->w.DCOrgY + YLPTODP( dcDst, yDest );
275 widDest = widDest * dcDst->vportExtX / dcDst->wndExtX;
276 heiDest = heiDest * dcDst->vportExtY / dcDst->wndExtY;
278 TSXSetFunction( display, dcDst->u.x.gc, GXcopy );
279 TSXCopyArea( display, dcSrc->u.x.drawable,
280 dcDst->u.x.drawable, dcDst->u.x.gc,
281 xSrc, ySrc, widDest, heiDest, xDest, yDest );