1 /*---------------------------------------------------------------------------*\
2 * OpenSG NURBS Library *
5 * Copyright (C) 2001-2006 by the University of Bonn, Computer Graphics Group*
7 * http://cg.cs.uni-bonn.de/ *
9 * contact: edhellon@cs.uni-bonn.de, guthe@cs.uni-bonn.de, rk@cs.uni-bonn.de *
11 \*---------------------------------------------------------------------------*/
12 /*---------------------------------------------------------------------------*\
15 * This library is free software; you can redistribute it and/or modify it *
16 * under the terms of the GNU Library General Public License as published *
17 * by the Free Software Foundation, version 2. *
19 * This library is distributed in the hope that it will be useful, but *
20 * WITHOUT ANY WARRANTY; without even the implied warranty of *
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
22 * Library General Public License for more details. *
24 * You should have received a copy of the GNU Library General Public *
25 * License along with this library; if not, write to the Free Software *
26 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *
28 \*---------------------------------------------------------------------------*/
29 /*---------------------------------------------------------------------------*\
37 \*---------------------------------------------------------------------------*/
38 #ifndef _OSG_BSPLINETRIMMEDSURFACE_H_
39 #define _OSG_BSPLINETRIMMEDSURFACE_H_
44 #include "OSGDrawableDef.h"
45 #include "OSGConfig.h"
48 #include "OSGdctptypes.h"
49 #include "OSGBSplineTensorSurface.h"
50 #include "OSGBSplineCurve2D.h"
57 typedef std::vector
<BSplineCurve2D
> bscvector
;
58 typedef std::vector
<bscvector
> trimmingloop
;
61 class OSG_DRAWABLE_DLLMAPPING BSplineTrimmedSurface
64 // FIXME: proper support for getting/setting stuph
66 inline BSplineTrimmedSurface(void);
67 inline ~BSplineTrimmedSurface(void);
69 // I/O support - FIXME: read( char *fname ) outta be supported , etc
70 int read(std::istream
&infile
);
71 int write(std::ostream
&outfile
);
74 inline BSplineTensorSurface
&getSurface (void );
75 inline trimmingloop
&getTrimmingLoops(void );
76 inline int setSurface (BSplineTensorSurface
&ts
);
77 inline int setTrimmingLoops(trimmingloop
&t
);
83 // file format constants
84 static const char ff_const_1
[];
85 static const char ff_const_2
[];
86 static const char ff_const_3
[];
88 BSplineTensorSurface surf
; // the surface itself
89 trimmingloop trimming
; // the trimming loops. each bscvector contains one trimming loop.
95 #include "OSGBSplineTrimmedSurface.inl"
97 #endif /* _OSG_BSPLINETRIMMEDSURFACE_H_ */