1 /*
2 * SGI FREE SOFTWARE LICENSE B (Version 2.0, Sept. 18, 2008)
3 * Copyright (C) 1991-2000 Silicon Graphics, Inc. All Rights Reserved.
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining a
6 * copy of this software and associated documentation files (the "Software"),
7 * to deal in the Software without restriction, including without limitation
8 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9 * and/or sell copies of the Software, and to permit persons to whom the
10 * Software is furnished to do so, subject to the following conditions:
11 *
12 * The above copyright notice including the dates of first publication and
13 * either this permission notice or a reference to
14 * http://oss.sgi.com/projects/FreeB/
15 * shall be included in all copies or substantial portions of the Software.
16 *
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
18 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
20 * SILICON GRAPHICS, INC. BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
21 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF
22 * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23 * SOFTWARE.
24 *
25 * Except as contained in this notice, the name of Silicon Graphics, Inc.
26 * shall not be used in advertising or otherwise to promote the sale, use or
27 * other dealings in this Software without prior written authorization from
28 * Silicon Graphics, Inc.
29 */
30
31 /*
32 * mapdesc.h
33 *
34 */
35
36 #ifndef __glumapdesc_h_
37 #define __glumapdesc_h_
38
39 //#include "mystdio.h"
40 #include "types.h"
41 #include "defines.h"
42 #include "bufpool.h"
43 #include "nurbsconsts.h"
44
45 typedef REAL Maxmatrix[MAXCOORDS][MAXCOORDS];
46
47 class Backend;
48
49 class Mapdesc : public PooledObj {
50 friend class Maplist;
51
52 public:
53 Mapdesc( long, int, int, Backend & );
54 int isProperty( long );
55 REAL getProperty( long );
56 void setProperty( long, REAL );
57 int isConstantSampling( void );
58 int isDomainSampling( void );
59 int isRangeSampling( void );
60 int isSampling( void );
61 int isParametricDistanceSampling( void );
62 int isObjectSpaceParaSampling( void );
63 int isObjectSpacePathSampling( void );
64 int isSurfaceAreaSampling( void );
65 int isPathLengthSampling( void );
66 int isCulling( void );
67 int isBboxSubdividing( void );
68 long getType( void );
69
70 /* curve routines */
71 void subdivide( REAL *, REAL *, REAL, int, int );
72 int cullCheck( REAL *, int, int );
73 void xformBounding( REAL *, int, int, REAL *, int );
74 void xformCulling( REAL *, int, int, REAL *, int );
75 void xformSampling( REAL *, int, int, REAL *, int );
76 void xformMat( Maxmatrix, REAL *, int, int, REAL *, int );
77 REAL calcPartialVelocity ( REAL *, int, int, int, REAL );
78 int project( REAL *, int, REAL *, int, int );
79 REAL calcVelocityRational( REAL *, int, int );
80 REAL calcVelocityNonrational( REAL *, int, int );
81
82 /* surface routines */
83 void subdivide( REAL *, REAL *, REAL, int, int, int, int );
84 int cullCheck( REAL *, int, int, int, int );
85 void xformBounding( REAL *, int, int, int, int, REAL *, int, int );
86 void xformCulling( REAL *, int, int, int, int, REAL *, int, int );
87 void xformSampling( REAL *, int, int, int, int, REAL *, int, int );
88 void xformMat( Maxmatrix, REAL *, int, int, int, int, REAL *, int, int );
89 REAL calcPartialVelocity ( REAL *, REAL *, int, int, int, int, int, int, REAL, REAL, int );
90 int project( REAL *, int, int, REAL *, int, int, int, int);
91 void surfbbox( REAL bb[2][MAXCOORDS] );
92
93 int bboxTooBig( REAL *, int, int, int, int, REAL [2][MAXCOORDS] );
94 int xformAndCullCheck( REAL *, int, int, int, int );
95
96 void identify( REAL[MAXCOORDS][MAXCOORDS] );
97 void setBboxsize( INREAL *);
98 inline void setBmat( INREAL*, long, long );
99 inline void setCmat( INREAL*, long, long );
100 inline void setSmat( INREAL*, long, long );
101 inline int isRational( void );
102 inline int getNcoords( void );
103
104 REAL pixel_tolerance; /* pathlength sampling tolerance */
105 REAL error_tolerance; /* parametric error sampling tolerance*/
106 REAL object_space_error_tolerance; /* object space tess*/
107 REAL clampfactor;
108 REAL minsavings;
109 REAL maxrate;
110 REAL maxsrate;
111 REAL maxtrate;
112 REAL bboxsize[MAXCOORDS];
113
114 private:
115 long type;
116 int isrational;
117 int ncoords;
118 int hcoords;
119 int inhcoords;
120 int mask;
121 Maxmatrix bmat;
122 Maxmatrix cmat;
123 Maxmatrix smat;
124 REAL s_steps; /* max samples in s direction */
125 REAL t_steps; /* max samples in t direction */
126 REAL sampling_method;
127 REAL culling_method; /* check for culling */
128 REAL bbox_subdividing;
129 Mapdesc * next;
130 Backend & backend;
131
132 void bbox( REAL [2][MAXCOORDS], REAL *, int, int, int, int );
133 REAL maxDifference( int, REAL *, int );
134 static void copy( Maxmatrix, long, INREAL *, long, long );
135
136 /* individual control point routines */
137 static void transform4d( float[4], float[4], float[4][4] );
138 static void multmatrix4d ( float[4][4], const float[4][4],
139 const float[4][4] );
140 void copyPt( REAL *, REAL * );
141 void sumPt( REAL *, REAL *, REAL *, REAL, REAL );
142 void xformSampling( REAL *, REAL * );
143 void xformCulling( REAL *, REAL * );
144 void xformRational( Maxmatrix, REAL *, REAL * );
145 void xformNonrational( Maxmatrix, REAL *, REAL * );
146 unsigned int clipbits( REAL * );
147 };
148
149 inline void
setBmat(INREAL * mat,long rstride,long cstride)150 Mapdesc::setBmat( INREAL *mat, long rstride, long cstride )
151 {
152 copy( bmat, hcoords, mat, rstride, cstride );
153 }
154
155 inline void
setCmat(INREAL * mat,long rstride,long cstride)156 Mapdesc::setCmat( INREAL *mat, long rstride, long cstride )
157 {
158 copy( cmat, hcoords, mat, rstride, cstride );
159 }
160
161 inline void
setSmat(INREAL * mat,long rstride,long cstride)162 Mapdesc::setSmat( INREAL *mat, long rstride, long cstride )
163 {
164 copy( smat, hcoords, mat, rstride, cstride );
165 }
166
167 inline long
getType(void)168 Mapdesc::getType( void )
169 {
170 return type;
171 }
172
173 inline void
xformCulling(REAL * d,REAL * s)174 Mapdesc::xformCulling( REAL *d, REAL *s )
175 {
176 if( isrational )
177 xformRational( cmat, d, s );
178 else
179 xformNonrational( cmat, d, s );
180 }
181
182 inline void
xformSampling(REAL * d,REAL * s)183 Mapdesc::xformSampling( REAL *d, REAL *s )
184 {
185 if( isrational )
186 xformRational( smat, d, s );
187 else
188 xformNonrational( smat, d, s );
189 }
190
191 inline int
isRational(void)192 Mapdesc::isRational( void )
193 {
194 return isrational ? 1 : 0;
195 }
196
197 inline int
getNcoords(void)198 Mapdesc::getNcoords( void )
199 {
200 return ncoords;
201 }
202
203 inline int
isConstantSampling(void)204 Mapdesc::isConstantSampling( void )
205 {
206 return ((sampling_method == N_FIXEDRATE) ? 1 : 0);
207 }
208
209 inline int
isDomainSampling(void)210 Mapdesc::isDomainSampling( void )
211 {
212 return ((sampling_method == N_DOMAINDISTANCE) ? 1 : 0);
213 }
214
215 inline int
isParametricDistanceSampling(void)216 Mapdesc::isParametricDistanceSampling( void )
217 {
218 return ((sampling_method == N_PARAMETRICDISTANCE) ? 1 : 0);
219 }
220
221 inline int
isObjectSpaceParaSampling(void)222 Mapdesc::isObjectSpaceParaSampling( void )
223 {
224 return ((sampling_method == N_OBJECTSPACE_PARA) ? 1 : 0);
225 }
226
227 inline int
isObjectSpacePathSampling(void)228 Mapdesc::isObjectSpacePathSampling( void )
229 {
230 return ((sampling_method == N_OBJECTSPACE_PATH) ? 1 : 0);
231 }
232
233 inline int
isSurfaceAreaSampling(void)234 Mapdesc::isSurfaceAreaSampling( void )
235 {
236 return ((sampling_method == N_SURFACEAREA) ? 1 : 0);
237 }
238
239 inline int
isPathLengthSampling(void)240 Mapdesc::isPathLengthSampling( void )
241 {
242 return ((sampling_method == N_PATHLENGTH) ? 1 : 0);
243 }
244
245 inline int
isRangeSampling(void)246 Mapdesc::isRangeSampling( void )
247 {
248 return ( isParametricDistanceSampling() || isPathLengthSampling() ||
249 isSurfaceAreaSampling() ||
250 isObjectSpaceParaSampling() ||
251 isObjectSpacePathSampling());
252 }
253
254 inline int
isSampling(void)255 Mapdesc::isSampling( void )
256 {
257 return isRangeSampling() || isConstantSampling() || isDomainSampling();
258 }
259
260 inline int
isCulling(void)261 Mapdesc::isCulling( void )
262 {
263 return ((culling_method != N_NOCULLING) ? 1 : 0);
264 }
265
266 inline int
isBboxSubdividing(void)267 Mapdesc::isBboxSubdividing( void )
268 {
269 return ((bbox_subdividing != N_NOBBOXSUBDIVISION) ? 1 : 0);
270 }
271 #endif /* __glumapdesc_h_ */
272