191 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			191 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C
		
	
	
	
/************************************************************
 | 
						|
 | 
						|
Copyright 1989, 1998  The Open Group
 | 
						|
 | 
						|
Permission to use, copy, modify, distribute, and sell this software and its
 | 
						|
documentation for any purpose is hereby granted without fee, provided that
 | 
						|
the above copyright notice appear in all copies and that both that
 | 
						|
copyright notice and this permission notice appear in supporting
 | 
						|
documentation.
 | 
						|
 | 
						|
The above copyright notice and this permission notice shall be included in
 | 
						|
all copies or substantial portions of the Software.
 | 
						|
 | 
						|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
						|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
						|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
 | 
						|
OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
 | 
						|
AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
 | 
						|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 | 
						|
 | 
						|
Except as contained in this notice, the name of The Open Group shall not be
 | 
						|
used in advertising or otherwise to promote the sale, use or other dealings
 | 
						|
in this Software without prior written authorization from The Open Group.
 | 
						|
 | 
						|
********************************************************/
 | 
						|
 | 
						|
 | 
						|
#ifndef __MIFILLARC_H__
 | 
						|
#define __MIFILLARC_H__
 | 
						|
 | 
						|
#define FULLCIRCLE (360 * 64)
 | 
						|
 | 
						|
typedef struct _miFillArc {
 | 
						|
    int xorg, yorg;
 | 
						|
    int y;
 | 
						|
    int dx, dy;
 | 
						|
    int e;
 | 
						|
    int ym, yk, xm, xk;
 | 
						|
} miFillArcRec;
 | 
						|
 | 
						|
/* could use 64-bit integers */
 | 
						|
typedef struct _miFillArcD {
 | 
						|
    int xorg, yorg;
 | 
						|
    int y;
 | 
						|
    int dx, dy;
 | 
						|
    double e;
 | 
						|
    double ym, yk, xm, xk;
 | 
						|
} miFillArcDRec;
 | 
						|
 | 
						|
#define miFillArcEmpty(arc) (!(arc)->angle2 || \
 | 
						|
			     !(arc)->width || !(arc)->height || \
 | 
						|
			     (((arc)->width == 1) && ((arc)->height & 1)))
 | 
						|
 | 
						|
#define miCanFillArc(arc) (((arc)->width == (arc)->height) || \
 | 
						|
			   (((arc)->width <= 800) && ((arc)->height <= 800)))
 | 
						|
 | 
						|
#define MIFILLARCSETUP() \
 | 
						|
    x = 0; \
 | 
						|
    y = info.y; \
 | 
						|
    e = info.e; \
 | 
						|
    xk = info.xk; \
 | 
						|
    xm = info.xm; \
 | 
						|
    yk = info.yk; \
 | 
						|
    ym = info.ym; \
 | 
						|
    dx = info.dx; \
 | 
						|
    dy = info.dy; \
 | 
						|
    xorg = info.xorg; \
 | 
						|
    yorg = info.yorg
 | 
						|
 | 
						|
#define MIFILLARCSTEP(slw) \
 | 
						|
    e += yk; \
 | 
						|
    while (e >= 0) \
 | 
						|
    { \
 | 
						|
	x++; \
 | 
						|
	xk -= xm; \
 | 
						|
	e += xk; \
 | 
						|
    } \
 | 
						|
    y--; \
 | 
						|
    yk -= ym; \
 | 
						|
    slw = (x << 1) + dx; \
 | 
						|
    if ((e == xk) && (slw > 1)) \
 | 
						|
	slw--
 | 
						|
 | 
						|
#define MIFILLCIRCSTEP(slw) MIFILLARCSTEP(slw)
 | 
						|
#define MIFILLELLSTEP(slw) MIFILLARCSTEP(slw)
 | 
						|
 | 
						|
#define miFillArcLower(slw) (((y + dy) != 0) && ((slw > 1) || (e != xk)))
 | 
						|
 | 
						|
typedef struct _miSliceEdge {
 | 
						|
    int	    x;
 | 
						|
    int     stepx;
 | 
						|
    int	    deltax;
 | 
						|
    int	    e;
 | 
						|
    int	    dy;
 | 
						|
    int	    dx;
 | 
						|
} miSliceEdgeRec, *miSliceEdgePtr;
 | 
						|
 | 
						|
typedef struct _miArcSlice {
 | 
						|
    miSliceEdgeRec edge1, edge2;
 | 
						|
    int min_top_y, max_top_y;
 | 
						|
    int min_bot_y, max_bot_y;
 | 
						|
    Bool edge1_top, edge2_top;
 | 
						|
    Bool flip_top, flip_bot;
 | 
						|
} miArcSliceRec;
 | 
						|
 | 
						|
#define MIARCSLICESTEP(edge) \
 | 
						|
    edge.x -= edge.stepx; \
 | 
						|
    edge.e -= edge.dx; \
 | 
						|
    if (edge.e <= 0) \
 | 
						|
    { \
 | 
						|
	edge.x -= edge.deltax; \
 | 
						|
	edge.e += edge.dy; \
 | 
						|
    }
 | 
						|
 | 
						|
#define miFillSliceUpper(slice) \
 | 
						|
		((y >= slice.min_top_y) && (y <= slice.max_top_y))
 | 
						|
 | 
						|
#define miFillSliceLower(slice) \
 | 
						|
		((y >= slice.min_bot_y) && (y <= slice.max_bot_y))
 | 
						|
 | 
						|
#define MIARCSLICEUPPER(xl,xr,slice,slw) \
 | 
						|
    xl = xorg - x; \
 | 
						|
    xr = xl + slw - 1; \
 | 
						|
    if (slice.edge1_top && (slice.edge1.x < xr)) \
 | 
						|
	xr = slice.edge1.x; \
 | 
						|
    if (slice.edge2_top && (slice.edge2.x > xl)) \
 | 
						|
	xl = slice.edge2.x;
 | 
						|
 | 
						|
#define MIARCSLICELOWER(xl,xr,slice,slw) \
 | 
						|
    xl = xorg - x; \
 | 
						|
    xr = xl + slw - 1; \
 | 
						|
    if (!slice.edge1_top && (slice.edge1.x > xl)) \
 | 
						|
	xl = slice.edge1.x; \
 | 
						|
    if (!slice.edge2_top && (slice.edge2.x < xr)) \
 | 
						|
	xr = slice.edge2.x;
 | 
						|
 | 
						|
#define MIWIDEARCSETUP(x,y,dy,slw,e,xk,xm,yk,ym) \
 | 
						|
    x = 0; \
 | 
						|
    y = slw >> 1; \
 | 
						|
    yk = y << 3; \
 | 
						|
    xm = 8; \
 | 
						|
    ym = 8; \
 | 
						|
    if (dy) \
 | 
						|
    { \
 | 
						|
	xk = 0; \
 | 
						|
	if (slw & 1) \
 | 
						|
	    e = -1; \
 | 
						|
	else \
 | 
						|
	    e = -(y << 2) - 2; \
 | 
						|
    } \
 | 
						|
    else \
 | 
						|
    { \
 | 
						|
	y++; \
 | 
						|
	yk += 4; \
 | 
						|
	xk = -4; \
 | 
						|
	if (slw & 1) \
 | 
						|
	    e = -(y << 2) - 3; \
 | 
						|
	else \
 | 
						|
	    e = - (y << 3); \
 | 
						|
    }
 | 
						|
 | 
						|
#define MIFILLINARCSTEP(slw) \
 | 
						|
    ine += inyk; \
 | 
						|
    while (ine >= 0) \
 | 
						|
    { \
 | 
						|
	inx++; \
 | 
						|
	inxk -= inxm; \
 | 
						|
	ine += inxk; \
 | 
						|
    } \
 | 
						|
    iny--; \
 | 
						|
    inyk -= inym; \
 | 
						|
    slw = (inx << 1) + dx; \
 | 
						|
    if ((ine == inxk) && (slw > 1)) \
 | 
						|
	slw--
 | 
						|
 | 
						|
#define miFillInArcLower(slw) (((iny + dy) != 0) && \
 | 
						|
			       ((slw > 1) || (ine != inxk)))
 | 
						|
 | 
						|
extern void miFillArcSetup(
 | 
						|
    xArc * /*arc*/,
 | 
						|
    miFillArcRec * /*info*/
 | 
						|
);
 | 
						|
 | 
						|
extern void miFillArcSliceSetup(
 | 
						|
    xArc * /*arc*/,
 | 
						|
    miArcSliceRec * /*slice*/,
 | 
						|
    GCPtr /*pGC*/
 | 
						|
);
 | 
						|
 | 
						|
#endif /* __MIFILLARC_H__ */
 |