00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 
00018 
00019 
00020 #ifndef COIN_SOINDEXEDNURBSCURVE_H
00021 #define COIN_SOINDEXEDNURBSCURVE_H
00022 
00023 #include <Inventor/nodes/SoSubNode.h>
00024 #include <Inventor/nodes/SoShape.h>
00025 #include <Inventor/fields/SoSFInt32.h>
00026 #include <Inventor/fields/SoMFInt32.h>
00027 #include <Inventor/fields/SoMFFloat.h>
00028 
00029 
00030 class COIN_DLL_API SoIndexedNurbsCurve : public SoShape {
00031   typedef SoShape inherited;
00032 
00033   SO_NODE_HEADER(SoIndexedNurbsCurve);
00034 
00035 public:
00036   static void initClass(void);
00037   SoIndexedNurbsCurve(void);
00038 
00039   SoSFInt32 numControlPoints;
00040   SoMFInt32 coordIndex;
00041   SoMFFloat knotVector;
00042 
00043   virtual void GLRender(SoGLRenderAction * action);
00044   virtual void rayPick(SoRayPickAction * action);
00045   virtual void getPrimitiveCount(SoGetPrimitiveCountAction * action);
00046   virtual void getBoundingBox(SoGetBoundingBoxAction * action);
00047   void sendPrimitive(SoAction *,  SoPrimitiveVertex *);
00048 
00049 protected:
00050   virtual ~SoIndexedNurbsCurve();
00051 
00052   virtual void generatePrimitives(SoAction * action);
00053   virtual void computeBBox(SoAction * action, SbBox3f & box, SbVec3f & center);
00054   virtual SoDetail * createLineSegmentDetail(SoRayPickAction * action,
00055                                              const SoPrimitiveVertex * v1,
00056                                              const SoPrimitiveVertex * v2,
00057                                              SoPickedPoint * pp);
00058 private:
00059   void * nurbsrenderer;
00060   void doNurbs(SoAction * action, const SbBool glrender, const SbBool drawaspoints);
00061 
00062   static void tessBegin(int type, void * data);
00063   static void tessTexCoord(float * texcoord, void * data);
00064   static void tessNormal(float * normal, void * data);
00065   static void tessVertex(float * vertex, void * data);
00066   static void tessEnd(void * data);
00067 };
00068 
00069 #endif // !COIN_SOINDEXEDNURBSCURVE_H