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
28 #include "gdiplus_private.h"
29 #include "wine/debug.h"
31 WINE_DEFAULT_DEBUG_CHANNEL(gdiplus
);
33 GpStatus WINGDIPAPI
GdipCloneCustomLineCap(GpCustomLineCap
* from
,
37 return InvalidParameter
;
39 *to
= GdipAlloc(sizeof(GpCustomLineCap
));
40 if(!*to
) return OutOfMemory
;
42 memcpy(*to
, from
, sizeof(GpCustomLineCap
));
44 (*to
)->pathdata
.Points
= GdipAlloc(from
->pathdata
.Count
* sizeof(PointF
));
45 (*to
)->pathdata
.Types
= GdipAlloc(from
->pathdata
.Count
);
47 if((!(*to
)->pathdata
.Types
|| !(*to
)->pathdata
.Points
) && (*to
)->pathdata
.Count
){
48 GdipFree((*to
)->pathdata
.Points
);
49 GdipFree((*to
)->pathdata
.Types
);
54 memcpy((*to
)->pathdata
.Points
, from
->pathdata
.Points
, from
->pathdata
.Count
56 memcpy((*to
)->pathdata
.Types
, from
->pathdata
.Types
, from
->pathdata
.Count
);
61 /* FIXME: Sometimes when fillPath is non-null and stroke path is null, the native
62 * version of this function returns NotImplemented. I cannot figure out why. */
63 GpStatus WINGDIPAPI
GdipCreateCustomLineCap(GpPath
* fillPath
, GpPath
* strokePath
,
64 GpLineCap baseCap
, REAL baseInset
, GpCustomLineCap
**customCap
)
68 TRACE("%p %p %d %f %p\n", fillPath
, strokePath
, baseCap
, baseInset
, customCap
);
70 if(!customCap
|| !(fillPath
|| strokePath
))
71 return InvalidParameter
;
73 *customCap
= GdipAlloc(sizeof(GpCustomLineCap
));
74 if(!*customCap
) return OutOfMemory
;
77 (*customCap
)->fill
= FALSE
;
78 pathdata
= &strokePath
->pathdata
;
81 (*customCap
)->fill
= TRUE
;
82 pathdata
= &fillPath
->pathdata
;
85 (*customCap
)->pathdata
.Points
= GdipAlloc(pathdata
->Count
* sizeof(PointF
));
86 (*customCap
)->pathdata
.Types
= GdipAlloc(pathdata
->Count
);
88 if((!(*customCap
)->pathdata
.Types
|| !(*customCap
)->pathdata
.Points
) &&
90 GdipFree((*customCap
)->pathdata
.Points
);
91 GdipFree((*customCap
)->pathdata
.Types
);
96 memcpy((*customCap
)->pathdata
.Points
, pathdata
->Points
, pathdata
->Count
98 memcpy((*customCap
)->pathdata
.Types
, pathdata
->Types
, pathdata
->Count
);
99 (*customCap
)->pathdata
.Count
= pathdata
->Count
;
101 (*customCap
)->inset
= baseInset
;
102 (*customCap
)->cap
= baseCap
;
103 (*customCap
)->join
= LineJoinMiter
;
104 (*customCap
)->scale
= 1.0;
109 GpStatus WINGDIPAPI
GdipDeleteCustomLineCap(GpCustomLineCap
*customCap
)
112 return InvalidParameter
;
114 GdipFree(customCap
->pathdata
.Points
);
115 GdipFree(customCap
->pathdata
.Types
);
121 GpStatus WINGDIPAPI
GdipGetCustomLineCapStrokeJoin(GpCustomLineCap
* customCap
,
122 GpLineJoin
* lineJoin
)
124 if(!customCap
|| !lineJoin
)
125 return InvalidParameter
;
127 *lineJoin
= customCap
->join
;
132 GpStatus WINGDIPAPI
GdipGetCustomLineCapWidthScale(GpCustomLineCap
* custom
,
135 if(!custom
|| !widthScale
)
136 return InvalidParameter
;
138 *widthScale
= custom
->scale
;
143 GpStatus WINGDIPAPI
GdipSetCustomLineCapStrokeCaps(GpCustomLineCap
* custom
,
144 GpLineCap start
, GpLineCap end
)
149 return InvalidParameter
;
152 FIXME("not implemented\n");
154 return NotImplemented
;
157 GpStatus WINGDIPAPI
GdipSetCustomLineCapBaseCap(GpCustomLineCap
* custom
,
163 FIXME("not implemented\n");
165 return NotImplemented
;
168 GpStatus WINGDIPAPI
GdipGetCustomLineCapBaseInset(GpCustomLineCap
* custom
,
171 if(!custom
|| !inset
)
172 return InvalidParameter
;
174 *inset
= custom
->inset
;
179 GpStatus WINGDIPAPI
GdipSetCustomLineCapBaseInset(GpCustomLineCap
* custom
,
185 FIXME("not implemented\n");
187 return NotImplemented
;
190 /*FIXME: LineJoin completely ignored now */
191 GpStatus WINGDIPAPI
GdipSetCustomLineCapStrokeJoin(GpCustomLineCap
* custom
,
195 return InvalidParameter
;
202 GpStatus WINGDIPAPI
GdipSetCustomLineCapWidthScale(GpCustomLineCap
* custom
,
208 FIXME("not implemented\n");
210 return NotImplemented
;
213 GpStatus WINGDIPAPI
GdipGetCustomLineCapBaseCap(GpCustomLineCap
*customCap
, GpLineCap
*baseCap
)
215 if(!customCap
|| !baseCap
)
216 return InvalidParameter
;
218 *baseCap
= customCap
->cap
;