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
);