mifpoly.h revision 05b261ec
105b261ecSmrg/*********************************************************** 205b261ecSmrg 305b261ecSmrgCopyright 1987, 1998 The Open Group 405b261ecSmrg 505b261ecSmrgPermission to use, copy, modify, distribute, and sell this software and its 605b261ecSmrgdocumentation for any purpose is hereby granted without fee, provided that 705b261ecSmrgthe above copyright notice appear in all copies and that both that 805b261ecSmrgcopyright notice and this permission notice appear in supporting 905b261ecSmrgdocumentation. 1005b261ecSmrg 1105b261ecSmrgThe above copyright notice and this permission notice shall be included in 1205b261ecSmrgall copies or substantial portions of the Software. 1305b261ecSmrg 1405b261ecSmrgTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 1505b261ecSmrgIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 1605b261ecSmrgFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 1705b261ecSmrgOPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN 1805b261ecSmrgAN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 1905b261ecSmrgCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 2005b261ecSmrg 2105b261ecSmrgExcept as contained in this notice, the name of The Open Group shall not be 2205b261ecSmrgused in advertising or otherwise to promote the sale, use or other dealings 2305b261ecSmrgin this Software without prior written authorization from The Open Group. 2405b261ecSmrg 2505b261ecSmrg 2605b261ecSmrgCopyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts. 2705b261ecSmrg 2805b261ecSmrg All Rights Reserved 2905b261ecSmrg 3005b261ecSmrgPermission to use, copy, modify, and distribute this software and its 3105b261ecSmrgdocumentation for any purpose and without fee is hereby granted, 3205b261ecSmrgprovided that the above copyright notice appear in all copies and that 3305b261ecSmrgboth that copyright notice and this permission notice appear in 3405b261ecSmrgsupporting documentation, and that the name of Digital not be 3505b261ecSmrgused in advertising or publicity pertaining to distribution of the 3605b261ecSmrgsoftware without specific, written prior permission. 3705b261ecSmrg 3805b261ecSmrgDIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING 3905b261ecSmrgALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL 4005b261ecSmrgDIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR 4105b261ecSmrgANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, 4205b261ecSmrgWHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, 4305b261ecSmrgARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS 4405b261ecSmrgSOFTWARE. 4505b261ecSmrg 4605b261ecSmrg******************************************************************/ 4705b261ecSmrg 4805b261ecSmrg#ifndef __MIFPOLY_H__ 4905b261ecSmrg#define __MIFPOLY_H__ 5005b261ecSmrg 5105b261ecSmrg#include <X11/Xfuncproto.h> 5205b261ecSmrg 5305b261ecSmrg#define EPSILON 0.000001 5405b261ecSmrg#define ISEQUAL(a,b) (Fabs((a) - (b)) <= EPSILON) 5505b261ecSmrg#define UNEQUAL(a,b) (Fabs((a) - (b)) > EPSILON) 5605b261ecSmrg#define WITHINHALF(a, b) (((a) - (b) > 0.0) ? (a) - (b) < 0.5 : \ 5705b261ecSmrg (b) - (a) <= 0.5) 5805b261ecSmrg#define ROUNDTOINT(x) ((int) (((x) > 0.0) ? ((x) + 0.5) : ((x) - 0.5))) 5905b261ecSmrg#define ISZERO(x) (Fabs((x)) <= EPSILON) 6005b261ecSmrg#define PTISEQUAL(a,b) (ISEQUAL(a.x,b.x) && ISEQUAL(a.y,b.y)) 6105b261ecSmrg#define PTUNEQUAL(a,b) (UNEQUAL(a.x,b.x) || UNEQUAL(a.y,b.y)) 6205b261ecSmrg#define PtEqual(a, b) (((a).x == (b).x) && ((a).y == (b).y)) 6305b261ecSmrg 6405b261ecSmrg#define NotEnd 0 6505b261ecSmrg#define FirstEnd 1 6605b261ecSmrg#define SecondEnd 2 6705b261ecSmrg 6805b261ecSmrg#define SQSECANT 108.856472512142 /* 1/sin^2(11/2) - for 11o miter cutoff */ 6905b261ecSmrg#define D2SECANT 5.21671526231167 /* 1/2*sin(11/2) - max extension per width */ 7005b261ecSmrg 7105b261ecSmrgstatic _X_INLINE int ICEIL(double x) 7205b261ecSmrg{ 7305b261ecSmrg int _cTmp = x; 7405b261ecSmrg return ((x == _cTmp) || (x < 0.0)) ? _cTmp : _cTmp+1; 7505b261ecSmrg} 7605b261ecSmrg 7705b261ecSmrg/* Point with sub-pixel positioning. In this case we use doubles, but 7805b261ecSmrg * see mifpolycon.c for other suggestions 7905b261ecSmrg */ 8005b261ecSmrgtypedef struct _SppPoint { 8105b261ecSmrg double x, y; 8205b261ecSmrg} SppPointRec, *SppPointPtr; 8305b261ecSmrg 8405b261ecSmrgtypedef struct _SppArc { 8505b261ecSmrg double x, y, width, height; 8605b261ecSmrg double angle1, angle2; 8705b261ecSmrg} SppArcRec, *SppArcPtr; 8805b261ecSmrg 8905b261ecSmrg/* mifpolycon.c */ 9005b261ecSmrg 9105b261ecSmrgextern void miFillSppPoly( 9205b261ecSmrg DrawablePtr /*dst*/, 9305b261ecSmrg GCPtr /*pgc*/, 9405b261ecSmrg int /*count*/, 9505b261ecSmrg SppPointPtr /*ptsIn*/, 9605b261ecSmrg int /*xTrans*/, 9705b261ecSmrg int /*yTrans*/, 9805b261ecSmrg double /*xFtrans*/, 9905b261ecSmrg double /*yFtrans*/ 10005b261ecSmrg); 10105b261ecSmrg 10205b261ecSmrg#endif /* __MIFPOLY_H__ */ 103