| 1 | // This may look like C code, but it is really -*- C++ -*- | 
|---|
| 2 | // Classe de gestion d objets nommes pour piapp | 
|---|
| 3 | // Reza      Aout 97 , Juillet,Aout 98 | 
|---|
| 4 | // CEA-DAPNIA      LAL-IN2P3/CNRS | 
|---|
| 5 |  | 
|---|
| 6 | #ifndef NOBJMGR_H_SEEN | 
|---|
| 7 | #define NOBJMGR_H_SEEN | 
|---|
| 8 |  | 
|---|
| 9 | #include "ppersist.h" | 
|---|
| 10 | #include "dlftypes.h" | 
|---|
| 11 |  | 
|---|
| 12 | class PIStdImgApp; | 
|---|
| 13 | class Services2NObjMgr; | 
|---|
| 14 |  | 
|---|
| 15 | class NamedObjMgr { | 
|---|
| 16 | public: | 
|---|
| 17 | NamedObjMgr(); | 
|---|
| 18 | virtual               ~NamedObjMgr(); | 
|---|
| 19 |  | 
|---|
| 20 | virtual void          SetImgApp(PIStdImgApp* app); | 
|---|
| 21 |  | 
|---|
| 22 |  | 
|---|
| 23 | //  Pour ajouter, supprimer et acceder aux objets PPersist | 
|---|
| 24 | virtual void          AddObj(PPersist* obj, string& nom); | 
|---|
| 25 | virtual void          DelObj(string const& nom, bool fgd=true); | 
|---|
| 26 | virtual void          DelObjects(string const& patt, bool fgd=true); | 
|---|
| 27 | virtual PPersist*     GetObj(string const& nom); | 
|---|
| 28 | virtual void          RenameObj(string const& nom, string& nomnew); | 
|---|
| 29 | virtual string        LastObjName();  // Renvoie le nom du dernier objet ajoute | 
|---|
| 30 |  | 
|---|
| 31 | //  Lecture et sauvegarde des objets sur fichier | 
|---|
| 32 | virtual void          ReadObj(PInPersist& s, int num=-1); | 
|---|
| 33 | virtual void          ReadObj(string const & nomppf, string nobj=""); | 
|---|
| 34 | virtual void          ReadAll(string const & nomppf); | 
|---|
| 35 | virtual void          ReadFits(string const & flnm, string nobj=""); | 
|---|
| 36 | virtual void          SaveObj(string const& nom, POutPersist& s); | 
|---|
| 37 | virtual void          SaveAll(string const& nomppf); | 
|---|
| 38 | virtual void          SaveFits(string const& nom, string const & flnm); | 
|---|
| 39 |  | 
|---|
| 40 | // Info sur les objets | 
|---|
| 41 | virtual void          ListObjs(); | 
|---|
| 42 | virtual void          PrintObj(string const& nom); | 
|---|
| 43 |  | 
|---|
| 44 | //  Affichage des objets | 
|---|
| 45 | virtual void          DisplayObj(string const& nom, string dopt=""); | 
|---|
| 46 | virtual void          DisplaySurf3D(string const& nom, string dopt=""); | 
|---|
| 47 | virtual void          DisplayNT(string const& nom, string& nmx, string& nmy, string& nmz, | 
|---|
| 48 | string& erx, string& ery, string& erz, string dopt=""); | 
|---|
| 49 | virtual void          DisplayGFD(string const& nom, string& numvarx, string& numvary, string& err, string dopt=""); | 
|---|
| 50 | // virtual void          DisplayImage(string const& nom, string dopt=""); C'est necessaire ?? | 
|---|
| 51 |  | 
|---|
| 52 | virtual void          SetGraphicAttributes(string gratt=""); | 
|---|
| 53 | virtual void          SetGraphicWinZone(int nzx, int nzy, bool fcr=false); | 
|---|
| 54 |  | 
|---|
| 55 |  | 
|---|
| 56 | //  Trace d'expression de NTuple, et d'autres objets | 
|---|
| 57 | virtual void          DisplayPoints2D(string const& nom, string& expx, string& expy, | 
|---|
| 58 | string& experrx, string& experry, | 
|---|
| 59 | string& expcut, string dopt=""); | 
|---|
| 60 | virtual void          DisplayPoints3D(string const& nom, string& expx, string& expy, string& expz, | 
|---|
| 61 | string& expcut, string dopt=""); | 
|---|
| 62 | //  Projection d'expressions dans histogramme (et trace) | 
|---|
| 63 | virtual void          ProjectH1(string const& nom, string& expx, string& expwt, string& expcut, | 
|---|
| 64 | string& nomh1, string dopt=""); | 
|---|
| 65 | virtual void          ProjectH2(string const& nom, string& expx, string& expy, string& expwt, | 
|---|
| 66 | string& expcut, string& nomh2, string dopt=""); | 
|---|
| 67 | virtual void          ProjectHProf(string const& nom, string& expx, string& expy, string& expwt, | 
|---|
| 68 | string& expcut, string& nomprof, string dopt=""); | 
|---|
| 69 | //  Projection d'expression dans vecteurs et dans n-tuple | 
|---|
| 70 | virtual void          FillVect(string const& nom, string& expx, string& expcut, | 
|---|
| 71 | string& nomvec, string dopt=""); | 
|---|
| 72 | virtual void          FillNT(string const& nom, string& expx, string& expy, string& expz, | 
|---|
| 73 | string& expt, string& expcut, string& nomnt); | 
|---|
| 74 | virtual void          FillGFD(string const& nom, string& expx, string& expy, string& expz, | 
|---|
| 75 | string& experr, string& expcut, string& nomgfd); | 
|---|
| 76 |  | 
|---|
| 77 | // Trace de fonctions 1-D , 2-D | 
|---|
| 78 | virtual void          PlotFunc(string& expfunc, float xmin, float xmax, int np=100, string dopt=""); | 
|---|
| 79 | virtual void          PlotFunc2D(string& expfunc, float xmin, float xmax, float ymin, float ymax, | 
|---|
| 80 | int npx=50, int npy=50, string dopt=""); | 
|---|
| 81 | virtual void          PlotFunc(DlFunctionOfX f, float xmin, float xmax, int np=100, string dopt=""); | 
|---|
| 82 | virtual void          PlotFunc2D(DlFunctionOfXY f, float xmin, float xmax, float ymin, float ymax, | 
|---|
| 83 | int npx=50, int npy=50, string dopt=""); | 
|---|
| 84 |  | 
|---|
| 85 | //   Methodes de fit, a rajouter  (pour CMV , deux methodes H1 H2 ou 1 seule ??) ... | 
|---|
| 86 | virtual void          Fit12D(string const& nom, string& func, | 
|---|
| 87 | string par,string step,string min,string max,string opt); | 
|---|
| 88 |  | 
|---|
| 89 | //   Calcul de la transforme de Fourier - A titre d'exemple | 
|---|
| 90 | virtual void          FFT(string const& nom, string dopt); | 
|---|
| 91 |  | 
|---|
| 92 | // Acces au PIApplication et a la classe de service | 
|---|
| 93 | virtual PIStdImgApp*          GetImgApp(); | 
|---|
| 94 | virtual Services2NObjMgr*     GetServiceObj(); | 
|---|
| 95 | }; | 
|---|
| 96 |  | 
|---|
| 97 |  | 
|---|
| 98 | #endif | 
|---|