filters: Add generated Nearest Neighbour filter.
[gfxprim.git] / libs / gfx / GP_Arc.c
blobac0360a66e44b7627ca7f068d13e8dff47d833de
1 /*****************************************************************************
2 * This file is part of gfxprim library. *
3 * *
4 * Gfxprim 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. *
8 * *
9 * Gfxprim 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. *
13 * *
14 * You should have received a copy of the GNU Lesser General Public *
15 * License along with gfxprim; if not, write to the Free Software *
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, *
17 * Boston, MA 02110-1301 USA *
18 * *
19 * Copyright (C) 2009-2011 Jiri "BlueBear" Dluhos *
20 * <jiri.bluebear.dluhos@gmail.com> *
21 * *
22 * Copyright (C) 2009-2012 Cyril Hrubis <metan@ucw.cz> *
23 * *
24 *****************************************************************************/
26 #include "core/GP_GetPutPixel.h"
27 #include "core/GP_FnPerBpp.h"
29 #include "gfx/GP_Arc.h"
31 #include "algo/Arc.algo.h"
33 /* Generate drawing functions for various bit depths. */
34 GP_DEF_DRAW_FN_PER_BPP(GP_ArcSegment_Raw, DEF_ARCSEGMENT_FN)
36 void GP_ArcSegment_Raw(GP_Context *context, GP_Coord xcenter, GP_Coord ycenter,
37 GP_Size a, GP_Size b, int direction,
38 double start, double end,
39 GP_Pixel pixel)
41 GP_CHECK_CONTEXT(context);
43 GP_FN_PER_BPP_CONTEXT(GP_ArcSegment_Raw, context, context,
44 xcenter, ycenter, a, b, direction,
45 start, end, pixel);
48 void GP_ArcSegment(GP_Context *context, GP_Coord xcenter, GP_Coord ycenter,
49 GP_Size a, GP_Size b, int direction,
50 double start, double end,
51 GP_Pixel pixel)
53 GP_CHECK_CONTEXT(context);
55 /* recalculate center point and swap a and b when axes are swapped */
56 GP_TRANSFORM_POINT(context, xcenter, ycenter);
57 GP_TRANSFORM_SWAP(context, a, b);
59 GP_ArcSegment_Raw(context, xcenter, ycenter, a, b, direction,
60 start, end, pixel);