comctl32: Also generate an alpha channel when replacing an image or icon in an imagelist.
[wine/multimedia.git] / dlls / gdiplus / customlinecap.c
blob00c228bf3cfa88ad2ac182257fecb336765af1d8
1 /*
2 * Copyright (C) 2007 Google (Evan Stade)
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19 #include <stdarg.h>
21 #include "windef.h"
22 #include "winbase.h"
23 #include "wingdi.h"
25 #include "objbase.h"
27 #include "gdiplus.h"
28 #include "gdiplus_private.h"
29 #include "wine/debug.h"
31 WINE_DEFAULT_DEBUG_CHANNEL(gdiplus);
33 GpStatus WINGDIPAPI GdipCloneCustomLineCap(GpCustomLineCap* from,
34 GpCustomLineCap** to)
36 TRACE("(%p, %p)\n", from, to);
38 if(!from || !to)
39 return InvalidParameter;
41 *to = GdipAlloc(sizeof(GpCustomLineCap));
42 if(!*to) return OutOfMemory;
44 memcpy(*to, from, sizeof(GpCustomLineCap));
46 (*to)->pathdata.Points = GdipAlloc(from->pathdata.Count * sizeof(PointF));
47 (*to)->pathdata.Types = GdipAlloc(from->pathdata.Count);
49 if((!(*to)->pathdata.Types || !(*to)->pathdata.Points) && (*to)->pathdata.Count){
50 GdipFree((*to)->pathdata.Points);
51 GdipFree((*to)->pathdata.Types);
52 GdipFree(*to);
53 return OutOfMemory;
56 memcpy((*to)->pathdata.Points, from->pathdata.Points, from->pathdata.Count
57 * sizeof(PointF));
58 memcpy((*to)->pathdata.Types, from->pathdata.Types, from->pathdata.Count);
60 TRACE("<-- %p\n", *to);
62 return Ok;
65 /* FIXME: Sometimes when fillPath is non-null and stroke path is null, the native
66 * version of this function returns NotImplemented. I cannot figure out why. */
67 GpStatus WINGDIPAPI GdipCreateCustomLineCap(GpPath* fillPath, GpPath* strokePath,
68 GpLineCap baseCap, REAL baseInset, GpCustomLineCap **customCap)
70 GpPathData *pathdata;
72 TRACE("%p %p %d %f %p\n", fillPath, strokePath, baseCap, baseInset, customCap);
74 if(!customCap || !(fillPath || strokePath))
75 return InvalidParameter;
77 *customCap = GdipAlloc(sizeof(GpCustomLineCap));
78 if(!*customCap) return OutOfMemory;
80 if(strokePath){
81 (*customCap)->fill = FALSE;
82 pathdata = &strokePath->pathdata;
84 else{
85 (*customCap)->fill = TRUE;
86 pathdata = &fillPath->pathdata;
89 (*customCap)->pathdata.Points = GdipAlloc(pathdata->Count * sizeof(PointF));
90 (*customCap)->pathdata.Types = GdipAlloc(pathdata->Count);
92 if((!(*customCap)->pathdata.Types || !(*customCap)->pathdata.Points) &&
93 pathdata->Count){
94 GdipFree((*customCap)->pathdata.Points);
95 GdipFree((*customCap)->pathdata.Types);
96 GdipFree(*customCap);
97 return OutOfMemory;
100 memcpy((*customCap)->pathdata.Points, pathdata->Points, pathdata->Count
101 * sizeof(PointF));
102 memcpy((*customCap)->pathdata.Types, pathdata->Types, pathdata->Count);
103 (*customCap)->pathdata.Count = pathdata->Count;
105 (*customCap)->inset = baseInset;
106 (*customCap)->cap = baseCap;
107 (*customCap)->join = LineJoinMiter;
108 (*customCap)->scale = 1.0;
110 TRACE("<-- %p\n", *customCap);
112 return Ok;
115 GpStatus WINGDIPAPI GdipDeleteCustomLineCap(GpCustomLineCap *customCap)
117 TRACE("(%p)\n", customCap);
119 if(!customCap)
120 return InvalidParameter;
122 GdipFree(customCap->pathdata.Points);
123 GdipFree(customCap->pathdata.Types);
124 GdipFree(customCap);
126 return Ok;
129 GpStatus WINGDIPAPI GdipGetCustomLineCapStrokeJoin(GpCustomLineCap* customCap,
130 GpLineJoin* lineJoin)
132 TRACE("(%p, %p)\n", customCap, lineJoin);
134 if(!customCap || !lineJoin)
135 return InvalidParameter;
137 *lineJoin = customCap->join;
139 return Ok;
142 GpStatus WINGDIPAPI GdipGetCustomLineCapWidthScale(GpCustomLineCap* custom,
143 REAL* widthScale)
145 TRACE("(%p, %p)\n", custom, widthScale);
147 if(!custom || !widthScale)
148 return InvalidParameter;
150 *widthScale = custom->scale;
152 return Ok;
155 GpStatus WINGDIPAPI GdipSetCustomLineCapStrokeCaps(GpCustomLineCap* custom,
156 GpLineCap start, GpLineCap end)
158 static int calls;
160 TRACE("(%p,%u,%u)\n", custom, start, end);
162 if(!custom)
163 return InvalidParameter;
165 if(!(calls++))
166 FIXME("not implemented\n");
168 return NotImplemented;
171 GpStatus WINGDIPAPI GdipSetCustomLineCapBaseCap(GpCustomLineCap* custom,
172 GpLineCap base)
174 static int calls;
176 TRACE("(%p,%u)\n", custom, base);
178 if(!(calls++))
179 FIXME("not implemented\n");
181 return NotImplemented;
184 GpStatus WINGDIPAPI GdipGetCustomLineCapBaseInset(GpCustomLineCap* custom,
185 REAL* inset)
187 TRACE("(%p, %p)\n", custom, inset);
189 if(!custom || !inset)
190 return InvalidParameter;
192 *inset = custom->inset;
194 return Ok;
197 GpStatus WINGDIPAPI GdipSetCustomLineCapBaseInset(GpCustomLineCap* custom,
198 REAL inset)
200 static int calls;
202 TRACE("(%p,%0.2f)\n", custom, inset);
204 if(!(calls++))
205 FIXME("not implemented\n");
207 return NotImplemented;
210 /*FIXME: LineJoin completely ignored now */
211 GpStatus WINGDIPAPI GdipSetCustomLineCapStrokeJoin(GpCustomLineCap* custom,
212 GpLineJoin join)
214 TRACE("(%p, %d)\n", custom, join);
216 if(!custom)
217 return InvalidParameter;
219 custom->join = join;
221 return Ok;
224 GpStatus WINGDIPAPI GdipSetCustomLineCapWidthScale(GpCustomLineCap* custom,
225 REAL width)
227 static int calls;
229 TRACE("(%p,%0.2f)\n", custom, width);
231 if(!(calls++))
232 FIXME("not implemented\n");
234 return NotImplemented;
237 GpStatus WINGDIPAPI GdipGetCustomLineCapBaseCap(GpCustomLineCap *customCap, GpLineCap *baseCap)
239 TRACE("(%p, %p)\n", customCap, baseCap);
241 if(!customCap || !baseCap)
242 return InvalidParameter;
244 *baseCap = customCap->cap;
246 return Ok;
249 GpStatus WINGDIPAPI GdipCreateAdjustableArrowCap(REAL height, REAL width, BOOL fill,
250 GpAdjustableArrowCap **cap)
252 static int calls;
254 TRACE("(%0.2f,%0.2f,%i,%p)\n", height, width, fill, cap);
256 if(!(calls++))
257 FIXME("not implemented\n");
259 return NotImplemented;
262 GpStatus WINGDIPAPI GdipGetAdjustableArrowCapFillState(GpAdjustableArrowCap* cap, BOOL* fill)
264 static int calls;
266 TRACE("(%p,%p)\n", cap, fill);
268 if(!(calls++))
269 FIXME("not implemented\n");
271 return NotImplemented;
274 GpStatus WINGDIPAPI GdipGetAdjustableArrowCapHeight(GpAdjustableArrowCap* cap, REAL* height)
276 static int calls;
278 TRACE("(%p,%p)\n", cap, height);
280 if(!(calls++))
281 FIXME("not implemented\n");
283 return NotImplemented;
286 GpStatus WINGDIPAPI GdipGetAdjustableArrowCapMiddleInset(GpAdjustableArrowCap* cap, REAL* middle)
288 static int calls;
290 TRACE("(%p,%p)\n", cap, middle);
292 if(!(calls++))
293 FIXME("not implemented\n");
295 return NotImplemented;
298 GpStatus WINGDIPAPI GdipGetAdjustableArrowCapWidth(GpAdjustableArrowCap* cap, REAL* width)
300 static int calls;
302 TRACE("(%p,%p)\n", cap, width);
304 if(!(calls++))
305 FIXME("not implemented\n");
307 return NotImplemented;
310 GpStatus WINGDIPAPI GdipSetAdjustableArrowCapFillState(GpAdjustableArrowCap* cap, BOOL fill)
312 static int calls;
314 TRACE("(%p,%i)\n", cap, fill);
316 if(!(calls++))
317 FIXME("not implemented\n");
319 return NotImplemented;
322 GpStatus WINGDIPAPI GdipSetAdjustableArrowCapHeight(GpAdjustableArrowCap* cap, REAL height)
324 static int calls;
326 TRACE("(%p,%0.2f)\n", cap, height);
328 if(!(calls++))
329 FIXME("not implemented\n");
331 return NotImplemented;
334 GpStatus WINGDIPAPI GdipSetAdjustableArrowCapMiddleInset(GpAdjustableArrowCap* cap, REAL middle)
336 static int calls;
338 TRACE("(%p,%0.2f)\n", cap, middle);
340 if(!(calls++))
341 FIXME("not implemented\n");
343 return NotImplemented;
346 GpStatus WINGDIPAPI GdipSetAdjustableArrowCapWidth(GpAdjustableArrowCap* cap, REAL width)
348 static int calls;
350 TRACE("(%p,%0.2f)\n", cap, width);
352 if(!(calls++))
353 FIXME("not implemented\n");
355 return NotImplemented;