| 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
 | 
|---|