2001-10-04 23:12:57 +08:00
|
|
|
//C++ header - Open Scene Graph - Copyright (C) 1998-2001 Robert Osfield
|
|
|
|
//Distributed under the terms of the GNU Library General Public License (LGPL)
|
|
|
|
//as published by the Free Software Foundation.
|
|
|
|
|
2001-09-20 05:19:47 +08:00
|
|
|
#ifndef OSGUTIL_Tesselator
|
|
|
|
#define OSGUTIL_Tesselator
|
|
|
|
|
2002-06-29 06:42:02 +08:00
|
|
|
#include <osg/Geometry>
|
2001-09-20 05:19:47 +08:00
|
|
|
|
|
|
|
#include <osgUtil/Export>
|
|
|
|
|
2002-06-29 06:42:02 +08:00
|
|
|
#include <osg/GLU>
|
|
|
|
|
2001-09-20 05:19:47 +08:00
|
|
|
#include <vector>
|
|
|
|
|
2002-06-29 06:42:02 +08:00
|
|
|
/* Win32 calling conventions. (or a least thats what the GLUT example tess.c uses.)*/
|
|
|
|
#ifndef CALLBACK
|
|
|
|
#define CALLBACK
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2001-09-20 05:19:47 +08:00
|
|
|
namespace osgUtil {
|
|
|
|
|
2001-09-28 20:36:40 +08:00
|
|
|
/** A simple class for tessellating a single polygon boundary.
|
|
|
|
* Currently uses old style glu tessellation functions for portability.
|
|
|
|
* It be nice to use the modern glu tessellation functions or to find
|
2001-09-20 05:19:47 +08:00
|
|
|
* a small set of code for doing this job better.*/
|
|
|
|
class OSGUTIL_EXPORT Tesselator
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
Tesselator();
|
|
|
|
~Tesselator();
|
|
|
|
|
|
|
|
enum InputBoundaryDirection
|
|
|
|
{
|
|
|
|
CLOCK_WISE,
|
|
|
|
COUNTER_CLOCK_WISE
|
|
|
|
};
|
|
|
|
|
2002-06-29 06:42:02 +08:00
|
|
|
typedef std::vector<osg::Vec3*> VertexPointList;
|
2001-09-20 05:19:47 +08:00
|
|
|
|
2002-06-29 06:42:02 +08:00
|
|
|
struct Prim : public osg::Referenced
|
|
|
|
{
|
|
|
|
Prim(GLenum mode):_mode(mode) {}
|
|
|
|
|
|
|
|
typedef std::vector<osg::Vec3*> VecList;
|
2001-09-20 05:19:47 +08:00
|
|
|
|
2002-06-29 06:42:02 +08:00
|
|
|
GLenum _mode;
|
|
|
|
VecList _vertices;
|
|
|
|
};
|
|
|
|
|
|
|
|
void beginTesselation();
|
|
|
|
|
|
|
|
void beginContour();
|
|
|
|
void addVertex(osg::Vec3* vertex);
|
|
|
|
void endContour();
|
|
|
|
|
|
|
|
void endTesselation();
|
2001-09-20 05:19:47 +08:00
|
|
|
|
2002-06-29 06:42:02 +08:00
|
|
|
typedef std::vector< osg::ref_ptr<Prim> > PrimList;
|
|
|
|
|
|
|
|
PrimList& getPrimList() { return _primList; }
|
|
|
|
|
|
|
|
void retesselatePolygons(osg::Geometry& geom);
|
|
|
|
|
|
|
|
void reset();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
void begin(GLenum mode);
|
|
|
|
void vertex(osg::Vec3* vertex);
|
|
|
|
void combine(osg::Vec3* vertex);
|
|
|
|
void end();
|
|
|
|
void error(GLenum errorCode);
|
2001-09-20 05:19:47 +08:00
|
|
|
|
|
|
|
|
2002-06-29 06:42:02 +08:00
|
|
|
static void beginCallback(GLenum which, void* userData);
|
|
|
|
static void vertexCallback(GLvoid *data, void* userData);
|
|
|
|
static void combineCallback(GLdouble coords[3], void* vertex_data[4],
|
|
|
|
GLfloat weight[4], void** outData,
|
|
|
|
void* useData);
|
|
|
|
static void endCallback(void* userData);
|
|
|
|
static void errorCallback(GLenum errorCode, void* userData);
|
|
|
|
|
|
|
|
|
|
|
|
struct Vec3d
|
2001-09-20 05:19:47 +08:00
|
|
|
{
|
2002-06-29 06:42:02 +08:00
|
|
|
double _v[3];
|
2001-09-20 05:19:47 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2002-06-29 06:42:02 +08:00
|
|
|
typedef std::vector<Vec3d*> Vec3dList;
|
2001-09-20 05:19:47 +08:00
|
|
|
|
2002-06-29 06:42:02 +08:00
|
|
|
GLUtesselator* _tobj;
|
|
|
|
PrimList _primList;
|
|
|
|
Vec3dList _coordData;
|
|
|
|
GLenum _errorCode;
|
2001-09-20 05:19:47 +08:00
|
|
|
|
|
|
|
};
|
|
|
|
|
2002-02-03 20:33:41 +08:00
|
|
|
}
|
2001-09-20 05:19:47 +08:00
|
|
|
|
|
|
|
#endif
|