ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/REPOS_ERICCA/magic/lib/step/src/stellipse.h
Revision: 5
Committed: Tue Jun 12 20:26:34 2007 UTC (17 years, 11 months ago)
Content type: text/plain
Original Path: magic/lib/step/step/src/stellipse.h
File size: 2612 byte(s)
Log Message:

File Contents

# User Rev Content
1 5 //------------------------------------------------------------
2     //------------------------------------------------------------
3     // MAGiC
4     // Jean Christophe Cuillière et Vincent FRANCOIS
5     // Département de Génie Mécanique - UQTR
6     //------------------------------------------------------------
7     // Le projet MAGIC est un projet de recherche du département
8     // de génie mécanique de l'Université du Québec à
9     // Trois Rivières
10     // Les librairies ne peuvent être utilisées sans l'accord
11     // des auteurs (contact : francois@uqtr.ca)
12     //------------------------------------------------------------
13     //------------------------------------------------------------
14     //
15     // stellipse.h
16     //
17     //------------------------------------------------------------
18     //------------------------------------------------------------
19     // COPYRIGHT 2000
20     // Version du 02/03/2006 à 11H24
21     //------------------------------------------------------------
22     //------------------------------------------------------------
23     #ifndef _HEADER_STELLIPSE_
24     #define _HEADER_STELLIPSE_
25    
26     #ifdef WINDOWS_VERSION
27     #ifdef BUILT_DLL_STEPLIB
28     #define DLLPORTSTEP __declspec(dllexport)
29     #else
30     #define DLLPORTSTEP __declspec(dllimport)
31     #endif
32     #else
33     #define DLLPORTSTEP
34     #endif
35    
36    
37     #include "st_courbe.h"
38     #include "ot_mathematique.h"
39     #include "tpl_liste_entite.h"
40    
41    
42    
43     class DLLPORTSTEP ST_ELLIPSE : public ST_COURBE
44     {
45     public :
46     ST_ELLIPSE(long LigneCourante,std::string idori,long axis2d,double a,double b);
47     ST_ELLIPSE(double *xyz,double *dirz,double *dirx,double a,double b);
48    
49    
50     virtual long get_id_axis2_placement_3d(void) ;
51     virtual double get_a(void);
52     virtual double get_b(void);
53     virtual void evaluer(double t,double *xyz) ;
54     virtual void deriver(double t,double *xyz) ;
55     virtual void deriver_seconde(double t,double *ddxyz,double* dxyz = NULL,double* xyz = NULL);
56     virtual void inverser(double& t,double *xyz,double precision=1e-6) ;
57     virtual double get_tmin();
58     virtual double get_tmax();
59     virtual double get_longueur(double t1,double t2,double precis=1e6);
60     virtual int est_periodique(void);
61     virtual double get_periode(void);
62     virtual void initialiser(class ST_GESTIONNAIRE* gest);
63     virtual void initialiser(double *xyz,double *dirz,double *dirx);
64    
65    
66     virtual int get_type_geometrique(TPL_LISTE_ENTITE<double> &param);
67     virtual void get_param_NURBS(TPL_LISTE_ENTITE<double> &param);
68     virtual void est_util(class ST_GESTIONNAIRE* gest);
69    
70     private:
71     long id_axis2_placement_3d;
72     double a;
73     double b;
74     OT_MATRICE_3D repere;
75     OT_VECTEUR_3D origine;
76     };
77    
78    
79     #endif