2 * PostScript brush handling
4 * Copyright 1998 Huw D M Davies
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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
22 #include "wine/debug.h"
25 WINE_DEFAULT_DEBUG_CHANNEL(psdrv);
27 /***********************************************************************
28 * SelectBrush (WINEPS.@)
30 HBRUSH CDECL PSDRV_SelectBrush( PSDRV_PDEVICE *physDev, HBRUSH hbrush )
34 if (!GetObjectA( hbrush, sizeof(logbrush), &logbrush )) return 0;
36 TRACE("hbrush = %p\n", hbrush);
38 switch(logbrush.lbStyle) {
41 PSDRV_CreateColor(physDev, &physDev->brush.color, logbrush.lbColor);
48 PSDRV_CreateColor(physDev, &physDev->brush.color, logbrush.lbColor);
56 FIXME("Unrecognized brush style %d\n", logbrush.lbStyle);
60 physDev->brush.set = FALSE;
65 /**********************************************************************
70 static BOOL PSDRV_SetBrush(PSDRV_PDEVICE *physDev)
75 if (!GetObjectA( GetCurrentObject(physDev->hdc,OBJ_BRUSH), sizeof(logbrush), &logbrush ))
77 ERR("Can't get BRUSHOBJ\n");
81 switch (logbrush.lbStyle) {
84 PSDRV_WriteSetColor(physDev, &physDev->brush.color);
95 physDev->brush.set = TRUE;
100 /**********************************************************************
105 static BOOL PSDRV_Fill(PSDRV_PDEVICE *physDev, BOOL EO)
108 return PSDRV_WriteFill(physDev);
110 return PSDRV_WriteEOFill(physDev);
114 /**********************************************************************
119 static BOOL PSDRV_Clip(PSDRV_PDEVICE *physDev, BOOL EO)
122 return PSDRV_WriteClip(physDev);
124 return PSDRV_WriteEOClip(physDev);
127 /**********************************************************************
132 BOOL PSDRV_Brush(PSDRV_PDEVICE *physDev, BOOL EO)
137 if(physDev->pathdepth)
140 if (!GetObjectA( GetCurrentObject(physDev->hdc,OBJ_BRUSH), sizeof(logbrush), &logbrush ))
142 ERR("Can't get BRUSHOBJ\n");
146 switch (logbrush.lbStyle) {
148 PSDRV_WriteGSave(physDev);
149 PSDRV_SetBrush(physDev);
150 PSDRV_Fill(physDev, EO);
151 PSDRV_WriteGRestore(physDev);
155 PSDRV_WriteGSave(physDev);
156 PSDRV_SetBrush(physDev);
158 switch(logbrush.lbHatch) {
161 PSDRV_WriteGSave(physDev);
162 PSDRV_Clip(physDev, EO);
163 PSDRV_WriteHatch(physDev);
164 PSDRV_WriteStroke(physDev);
165 PSDRV_WriteGRestore(physDev);
166 if(logbrush.lbHatch == HS_VERTICAL)
168 /* else fallthrough for HS_CROSS */
171 PSDRV_WriteGSave(physDev);
172 PSDRV_Clip(physDev, EO);
173 PSDRV_WriteRotate(physDev, 90.0);
174 PSDRV_WriteHatch(physDev);
175 PSDRV_WriteStroke(physDev);
176 PSDRV_WriteGRestore(physDev);
181 PSDRV_WriteGSave(physDev);
182 PSDRV_Clip(physDev, EO);
183 PSDRV_WriteRotate(physDev, -45.0);
184 PSDRV_WriteHatch(physDev);
185 PSDRV_WriteStroke(physDev);
186 PSDRV_WriteGRestore(physDev);
187 if(logbrush.lbHatch == HS_FDIAGONAL)
189 /* else fallthrough for HS_DIAGCROSS */
192 PSDRV_WriteGSave(physDev);
193 PSDRV_Clip(physDev, EO);
194 PSDRV_WriteRotate(physDev, 45.0);
195 PSDRV_WriteHatch(physDev);
196 PSDRV_WriteStroke(physDev);
197 PSDRV_WriteGRestore(physDev);
201 ERR("Unknown hatch style\n");
205 PSDRV_WriteGRestore(physDev);
215 GetObjectA( (HBITMAP)logbrush.lbHatch, sizeof(BITMAP), &bm);
216 TRACE("BS_PATTERN %dx%d %d bpp\n", bm.bmWidth, bm.bmHeight,
218 bits = HeapAlloc(PSDRV_Heap, 0, bm.bmWidthBytes * bm.bmHeight);
219 GetBitmapBits( (HBITMAP)logbrush.lbHatch, bm.bmWidthBytes * bm.bmHeight, bits);
221 if(physDev->pi->ppd->LanguageLevel > 1) {
222 PSDRV_WriteGSave(physDev);
223 PSDRV_WritePatternDict(physDev, &bm, bits);
224 PSDRV_Fill(physDev, EO);
225 PSDRV_WriteGRestore(physDev);
227 FIXME("Trying to set a pattern brush on a level 1 printer\n");
230 HeapFree(PSDRV_Heap, 0, bits);
236 BITMAPINFO *bmi = GlobalLock( (HGLOBAL)logbrush.lbHatch );
237 UINT usage = logbrush.lbColor;
238 TRACE("size %dx%dx%d\n", bmi->bmiHeader.biWidth,
239 bmi->bmiHeader.biHeight, bmi->bmiHeader.biBitCount);
240 if(physDev->pi->ppd->LanguageLevel > 1) {
241 PSDRV_WriteGSave(physDev);
242 ret = PSDRV_WriteDIBPatternDict(physDev, bmi, usage);
243 PSDRV_Fill(physDev, EO);
244 PSDRV_WriteGRestore(physDev);
246 FIXME("Trying to set a pattern brush on a level 1 printer\n");
249 GlobalUnlock( (HGLOBAL)logbrush.lbHatch );