mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2024-11-17 23:10:22 +00:00
113 lines
3.7 KiB
C
113 lines
3.7 KiB
C
|
/* $TOG: mifpoly.h /main/10 1998/02/09 14:47:09 kaleb $ */
|
||
|
/***********************************************************
|
||
|
|
||
|
Copyright 1987, 1998 The Open Group
|
||
|
|
||
|
All Rights Reserved.
|
||
|
|
||
|
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.
|
||
|
|
||
|
|
||
|
Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts.
|
||
|
|
||
|
All Rights Reserved
|
||
|
|
||
|
Permission to use, copy, modify, and distribute this software and its
|
||
|
documentation for any purpose and without fee is hereby granted,
|
||
|
provided that the above copyright notice appear in all copies and that
|
||
|
both that copyright notice and this permission notice appear in
|
||
|
supporting documentation, and that the name of Digital not be
|
||
|
used in advertising or publicity pertaining to distribution of the
|
||
|
software without specific, written prior permission.
|
||
|
|
||
|
DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
|
||
|
ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
|
||
|
DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
|
||
|
ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
|
||
|
WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
|
||
|
ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
|
||
|
SOFTWARE.
|
||
|
|
||
|
******************************************************************/
|
||
|
|
||
|
#ifndef MIFPOLY_H
|
||
|
#define MIFPOLY_H 1
|
||
|
|
||
|
#define EPSILON 0.000001
|
||
|
#define ISEQUAL(a,b) (fabs((a) - (b)) <= EPSILON)
|
||
|
#define UNEQUAL(a,b) (fabs((a) - (b)) > EPSILON)
|
||
|
#define WITHINHALF(a, b) (((a) - (b) > 0.0) ? (a) - (b) < 0.5 : \
|
||
|
(b) - (a) <= 0.5)
|
||
|
#define ROUNDTOINT(x) ((int) (((x) > 0.0) ? ((x) + 0.5) : ((x) - 0.5)))
|
||
|
#define ISZERO(x) (fabs((x)) <= EPSILON)
|
||
|
#define PTISEQUAL(a,b) (ISEQUAL(a.x,b.x) && ISEQUAL(a.y,b.y))
|
||
|
#define PTUNEQUAL(a,b) (UNEQUAL(a.x,b.x) || UNEQUAL(a.y,b.y))
|
||
|
#define PtEqual(a, b) (((a).x == (b).x) && ((a).y == (b).y))
|
||
|
|
||
|
#define NotEnd 0
|
||
|
#define FirstEnd 1
|
||
|
#define SecondEnd 2
|
||
|
|
||
|
#define SQSECANT 108.856472512142 /* 1/sin^2(11/2) - for 11o miter cutoff */
|
||
|
#define D2SECANT 5.21671526231167 /* 1/2*sin(11/2) - max extension per width */
|
||
|
|
||
|
#ifndef ICIEL
|
||
|
#ifdef NOINLINEICEIL
|
||
|
#define ICEIL(x) ((int)ceil(x))
|
||
|
#else
|
||
|
#ifdef __GNUC__
|
||
|
#define ICEIL ICIEL
|
||
|
static __inline int ICEIL(x)
|
||
|
double x;
|
||
|
{
|
||
|
int _cTmp = x;
|
||
|
return ((x == _cTmp) || (x < 0.0)) ? _cTmp : _cTmp+1;
|
||
|
}
|
||
|
#else
|
||
|
#define ICEIL(x) ((((x) == (_cTmp = (x))) || ((x) < 0.0)) ? _cTmp : _cTmp+1)
|
||
|
#define ICEILTEMPDECL static int _cTmp;
|
||
|
#endif
|
||
|
#endif
|
||
|
#endif
|
||
|
|
||
|
/* Point with sub-pixel positioning. In this case we use doubles, but
|
||
|
* see mifpolycon.c for other suggestions
|
||
|
*/
|
||
|
typedef struct _SppPoint {
|
||
|
double x, y;
|
||
|
} SppPointRec, *SppPointPtr;
|
||
|
|
||
|
typedef struct _SppArc {
|
||
|
double x, y, width, height;
|
||
|
double angle1, angle2;
|
||
|
} SppArcRec, *SppArcPtr;
|
||
|
|
||
|
/* mifpolycon.c */
|
||
|
|
||
|
extern void miFillSppPoly(
|
||
|
#if NeedFunctionPrototypes
|
||
|
GdkDrawable* /*dst*/,
|
||
|
GdkGC* /*pgc*/,
|
||
|
int /*count*/,
|
||
|
SppPointPtr /*ptsIn*/,
|
||
|
int /*xTrans*/,
|
||
|
int /*yTrans*/,
|
||
|
double /*xFtrans*/,
|
||
|
double /*yFtrans*/
|
||
|
#endif
|
||
|
);
|
||
|
|
||
|
#endif /* MIFPOLY_H */
|