Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/g4tools/include/tools/curve

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

  1 // Copyright (C) 2010, Guy Barrand. All rights reserved.
  2 // See the file tools.license for terms.
  3 
  4 #ifndef tools_curve
  5 #define tools_curve
  6 
  7 #include "scast"
  8 #include "S_STRING"
  9 
 10 #ifdef TOOLS_MEM
 11 #include "mem"
 12 #endif
 13 
 14 #include "lina/vec3f"
 15 #include "lina/mat4f"
 16 
 17 namespace tools {
 18 
 19 class curve {
 20 public:
 21   TOOLS_SCLASS(tools::curve)
 22   virtual void* cast(const std::string& a_class) const {
 23     if(void* p = cmp_cast<curve>(this,a_class)) {return p;}
 24     return 0;
 25   }
 26 public:
 27   virtual void copy(curve*&) const = 0;
 28 public:
 29   virtual bool pos_tan_nor(float a_s,
 30                            vec3f& a_pos,
 31                            vec3f& a_tan,
 32                            vec3f& a_nor) const = 0;
 33 public:
 34   curve(){
 35 #ifdef TOOLS_MEM
 36     mem::increment(s_class().c_str());
 37 #endif
 38     m_model.set_identity();
 39   }
 40   virtual ~curve(){
 41 #ifdef TOOLS_MEM
 42     mem::decrement(s_class().c_str());
 43 #endif
 44   }
 45 public:
 46   curve(const curve& a_from):m_model(a_from.m_model){
 47 #ifdef TOOLS_MEM
 48     mem::increment(s_class().c_str());
 49 #endif
 50   }
 51   curve& operator=(const curve& a_from){
 52     m_model = a_from.m_model;
 53     return *this;
 54   }
 55 public:
 56   void set_model_matrix(const mat4f& a_m) {m_model = a_m;}
 57 protected:
 58   mat4f m_model;
 59 };
 60 
 61 }
 62 
 63 #endif