#ifndef __glumapdesc_h_ #define __glumapdesc_h_ /************************************************************************** * * * Copyright (C) 1992, Silicon Graphics, Inc. * * * * These coded instructions, statements, and computer programs contain * * unpublished proprietary information of Silicon Graphics, Inc., and * * are protected by Federal copyright law. They may not be disclosed * * to third parties or copied or duplicated in any form, in whole or * * in part, without the prior written consent of Silicon Graphics, Inc. * * * **************************************************************************/ /* * mapdesc.h - $Revision: 1.1 $ */ #include "mystdio.h" #include "types.h" #include "defines.h" #include "bufpool.h" #include "nurbscon.h" typedef REAL Maxmatrix[MAXCOORDS][MAXCOORDS]; class Backend; class Mapdesc : public PooledObj { friend class Maplist; public: Mapdesc( long, int, int, Backend & ); int isProperty( long ); REAL getProperty( long ); void setProperty( long, REAL ); int isConstantSampling( void ); int isDomainSampling( void ); int isRangeSampling( void ); int isSampling( void ); int isParametricDistanceSampling( void ); int isSurfaceAreaSampling( void ); int isPathLengthSampling( void ); int isCulling( void ); int isBboxSubdividing( void ); long getType( void ); /* curve routines */ void subdivide( REAL *, REAL *, REAL, int, int ); int cullCheck( REAL *, int, int ); void xformBounding( REAL *, int, int, REAL *, int ); void xformCulling( REAL *, int, int, REAL *, int ); void xformSampling( REAL *, int, int, REAL *, int ); void xformMat( Maxmatrix, REAL *, int, int, REAL *, int ); REAL calcPartialVelocity ( REAL *, int, int, int, REAL ); int project( REAL *, int, REAL *, int, int ); REAL calcVelocityRational( REAL *, int, int ); REAL calcVelocityNonrational( REAL *, int, int ); /* surface routines */ void subdivide( REAL *, REAL *, REAL, int, int, int, int ); int cullCheck( REAL *, int, int, int, int ); void xformBounding( REAL *, int, int, int, int, REAL *, int, int ); void xformCulling( REAL *, int, int, int, int, REAL *, int, int ); void xformSampling( REAL *, int, int, int, int, REAL *, int, int ); void xformMat( Maxmatrix, REAL *, int, int, int, int, REAL *, int, int ); REAL calcPartialVelocity ( REAL *, REAL *, int, int, int, int, int, int, REAL, REAL, int ); int project( REAL *, int, int, REAL *, int, int, int, int); void surfbbox( REAL bb[2][MAXCOORDS] ); int bboxTooBig( REAL *, int, int, int, int, REAL [2][MAXCOORDS] ); int xformAndCullCheck( REAL *, int, int, int, int ); void identify( REAL[MAXCOORDS][MAXCOORDS] ); void setBboxsize( INREAL *); inline void setBmat( INREAL*, long, long ); inline void setCmat( INREAL*, long, long ); inline void setSmat( INREAL*, long, long ); inline int isRational( void ); inline int getNcoords( void ); REAL pixel_tolerance; /* pathlength sampling tolerance */ REAL error_tolerance; /* parametric error sampling tolerance*/ REAL clampfactor; REAL minsavings; REAL maxrate; REAL maxsrate; REAL maxtrate; REAL bboxsize[MAXCOORDS]; private: long type; int isrational; int ncoords; int hcoords; int inhcoords; #ifdef NT unsigned int mask; #else int mask; #endif Maxmatrix bmat; Maxmatrix cmat; Maxmatrix smat; REAL s_steps; /* max samples in s direction */ REAL t_steps; /* max samples in t direction */ REAL sampling_method; REAL culling_method; /* check for culling */ REAL bbox_subdividing; Mapdesc * next; Backend & backend; void bbox( REAL [2][MAXCOORDS], REAL *, int, int, int, int ); REAL maxDifference( int, REAL *, int ); static void copy( Maxmatrix, long, INREAL *, long, long ); /* individual control point routines */ static void transform4d( float[4], float[4], float[4][4] ); static void multmatrix4d ( float[4][4], float[4][4], float[4][4] ); void copyPt( REAL *, REAL * ); void sumPt( REAL *, REAL *, REAL *, REAL, REAL ); void xformSampling( REAL *, REAL * ); void xformCulling( REAL *, REAL * ); void xformRational( Maxmatrix, REAL *, REAL * ); void xformNonrational( Maxmatrix, REAL *, REAL * ); unsigned int clipbits( REAL * ); }; inline void Mapdesc::setBmat( INREAL *mat, long rstride, long cstride ) { copy( bmat, hcoords, mat, rstride, cstride ); } inline void Mapdesc::setCmat( INREAL *mat, long rstride, long cstride ) { copy( cmat, hcoords, mat, rstride, cstride ); } inline void Mapdesc::setSmat( INREAL *mat, long rstride, long cstride ) { copy( smat, hcoords, mat, rstride, cstride ); } inline long Mapdesc::getType( void ) { return type; } inline void Mapdesc::xformCulling( REAL *d, REAL *s ) { if( isrational ) xformRational( cmat, d, s ); else xformNonrational( cmat, d, s ); } inline void Mapdesc::xformSampling( REAL *d, REAL *s ) { if( isrational ) xformRational( smat, d, s ); else xformNonrational( smat, d, s ); } inline int Mapdesc::isRational( void ) { return isrational ? 1 : 0; } inline int Mapdesc::getNcoords( void ) { return ncoords; } inline int Mapdesc::isConstantSampling( void ) { return ((sampling_method == N_FIXEDRATE) ? 1 : 0); } inline int Mapdesc::isDomainSampling( void ) { return ((sampling_method == N_DOMAINDISTANCE) ? 1 : 0); } inline int Mapdesc::isParametricDistanceSampling( void ) { return ((sampling_method == N_PARAMETRICDISTANCE) ? 1 : 0); } inline int Mapdesc::isSurfaceAreaSampling( void ) { return ((sampling_method == N_SURFACEAREA) ? 1 : 0); } inline int Mapdesc::isPathLengthSampling( void ) { return ((sampling_method == N_PATHLENGTH) ? 1 : 0); } inline int Mapdesc::isRangeSampling( void ) { return ( isParametricDistanceSampling() || isPathLengthSampling() || isSurfaceAreaSampling() ); } inline int Mapdesc::isSampling( void ) { return isRangeSampling() || isConstantSampling() || isDomainSampling(); } inline int Mapdesc::isCulling( void ) { return ((culling_method != N_NOCULLING) ? 1 : 0); } inline int Mapdesc::isBboxSubdividing( void ) { return ((bbox_subdividing != N_NOBBOXSUBDIVISION) ? 1 : 0); } #endif /* __glumapdesc_h_ */