00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #ifndef _math_isosurf_isosurf_h
00029 #define _math_isosurf_isosurf_h
00030
00031 #ifdef __GNUC__
00032 #pragma interface
00033 #endif
00034
00035 #include <math/isosurf/surf.h>
00036
00037 namespace sc {
00038
00039 class IsosurfaceGen {
00040 protected:
00041 double _resolution;
00042 public:
00043 IsosurfaceGen();
00044 virtual ~IsosurfaceGen();
00045 virtual void isosurface(double value,
00046 TriangulatedSurface& surf) = 0;
00047 virtual void set_resolution(double);
00048 };
00049
00050 class ImplicitSurfacePolygonizer: public IsosurfaceGen {
00051 private:
00052
00053
00054 static ImplicitSurfacePolygonizer* current;
00055 static int add_triangle_to_current(int,int,int,VERTICES);
00056 static double value_of_current(double x, double y, double z);
00057 protected:
00058 Ref<Volume> _volume;
00059
00060 #ifdef HAVE_STL
00061 std::vector<Ref<Vertex> > _tmp_vertices;
00062 #else
00063 Array<Ref<Vertex> > _tmp_vertices;
00064 #endif
00065 TriangulatedSurface* _surf;
00066 double _value;
00067 public:
00068 ImplicitSurfacePolygonizer(const Ref<Volume>&);
00069 virtual ~ImplicitSurfacePolygonizer();
00070 virtual void isosurface(double value,
00071 TriangulatedSurface& surf);
00072 };
00073
00074 }
00075
00076 #endif
00077
00078
00079
00080
00081