| [544] | 1 | // Classe traceur de StarList               97-99 | 
|---|
|  | 2 | // CEA-DAPNIA      LAL-IN2P3/CNRS | 
|---|
|  | 3 |  | 
|---|
| [165] | 4 | #include <stdio.h> | 
|---|
| [2615] | 5 | #include "sopnamsp.h" | 
|---|
| [165] | 6 | #include "pistlist.h" | 
|---|
|  | 7 |  | 
|---|
| [544] | 8 | //++ | 
|---|
|  | 9 | // Class        PIStarList | 
|---|
|  | 10 | // Lib          PIext | 
|---|
|  | 11 | // include      pistlist.h | 
|---|
|  | 12 | // | 
|---|
|  | 13 | //      Classe traceur d'objets de la classe *StarList* | 
|---|
|  | 14 | //-- | 
|---|
|  | 15 | //++ | 
|---|
|  | 16 | // Links        Parents | 
|---|
|  | 17 | // PIDrawer | 
|---|
|  | 18 | //-- | 
|---|
|  | 19 | //++ | 
|---|
|  | 20 | // Titre        Constructeur | 
|---|
|  | 21 | //-- | 
|---|
|  | 22 |  | 
|---|
|  | 23 | //++ | 
|---|
|  | 24 | //  PIStarList(StarList* stl, bool ad) | 
|---|
|  | 25 | //      Constructeur. Si "ad == true", l'objet "stl" est détruit par | 
|---|
|  | 26 | //      le destructeur de l'objet "PIStarList" | 
|---|
|  | 27 | //      Note : "stl" doit être créé par new | 
|---|
|  | 28 | //-- | 
|---|
|  | 29 |  | 
|---|
| [165] | 30 | /* --Methode-- */ | 
|---|
|  | 31 | PIStarList::PIStarList(StarList* stl, bool ad) | 
|---|
|  | 32 | : PIDrawer(), mStL(stl) | 
|---|
|  | 33 | { | 
|---|
|  | 34 | mAdDO = ad; | 
|---|
|  | 35 | if (stl == NULL) return; | 
|---|
|  | 36 | SetFluxLimits(1., -1.); | 
|---|
|  | 37 | } | 
|---|
|  | 38 |  | 
|---|
|  | 39 | PIStarList::~PIStarList() | 
|---|
|  | 40 | { | 
|---|
|  | 41 | if (mAdDO && mStL)  delete mStL; | 
|---|
|  | 42 | } | 
|---|
|  | 43 |  | 
|---|
| [544] | 44 | //++ | 
|---|
|  | 45 | // Titre        Méthodes | 
|---|
|  | 46 | //-- | 
|---|
|  | 47 | //++ | 
|---|
|  | 48 | //  void  SetFluxLimits(float min=1., float max=-1., int nl=5, bool dispflx=false, bool refr=false) | 
|---|
|  | 49 | //      Modifie les paramètres de visualisation (limites en flux). Si "dispflx==true" | 
|---|
|  | 50 | //      les valeurs de flux sont affichées pour chaque étoile. | 
|---|
|  | 51 | //  StarList*  StList() | 
|---|
|  | 52 | //      Retourne l'objet "StarList" associé. | 
|---|
|  | 53 | //  float FluxMin() | 
|---|
|  | 54 | //      Retourne le paramètre de visualisation flux minimum | 
|---|
|  | 55 | //  float FluxMax() | 
|---|
|  | 56 | //      Retourne le paramètre de visualisation flux maximum | 
|---|
|  | 57 | //-- | 
|---|
|  | 58 |  | 
|---|
| [165] | 59 | /* --Methode-- */ | 
|---|
|  | 60 | void  PIStarList::SetFluxLimits(float fmin, float fmax, int nl, bool dispflx, bool refr) | 
|---|
|  | 61 | { | 
|---|
|  | 62 | if (!mStL)  return; | 
|---|
|  | 63 | if (fmin < fmax)  { mFmin = fmin;  mFmax = fmax; } | 
|---|
|  | 64 | else mStL->CalcFluxLimits(mFmin, mFmax); | 
|---|
|  | 65 | if (mFmin < 1.e-10)  mFmin = 1.e-10; | 
|---|
|  | 66 | if (mFmax <= mFmin)  mFmax = 1.5*mFmin; | 
|---|
|  | 67 | mDLgF = log10((double)mFmax/(double)mFmin); | 
|---|
|  | 68 | if (mDLgF < 1.e-10)  mDLgF = 1.e-10; | 
|---|
|  | 69 | mF0 = mFmin; | 
|---|
|  | 70 | if (nl < 1)  nl = 1; | 
|---|
|  | 71 | if (nl > 20)  nl = 20; | 
|---|
|  | 72 | mNLev = nl; | 
|---|
|  | 73 | mDspFV = dispflx; | 
|---|
|  | 74 | if (refr)  Refresh(); | 
|---|
|  | 75 | return; | 
|---|
|  | 76 | } | 
|---|
|  | 77 |  | 
|---|
|  | 78 |  | 
|---|
|  | 79 | /* --Methode-- */ | 
|---|
|  | 80 | void PIStarList::UpdateLimits() | 
|---|
|  | 81 | { | 
|---|
|  | 82 | if (!mStL) return; | 
|---|
|  | 83 |  | 
|---|
|  | 84 | // Commencer par trouver nos limites | 
|---|
| [2115] | 85 | double x1,x2,y1,y2; | 
|---|
| [165] | 86 | mStL->CalcXYLimits(x1, x2, y1, y2); | 
|---|
| [2115] | 87 | PIAxes::ReSizeMinMax(isLogScaleX(),x1,x2); | 
|---|
|  | 88 | PIAxes::ReSizeMinMax(isLogScaleY(),y1,y2); | 
|---|
|  | 89 | SetLimits(x1,x2,y1,y2); | 
|---|
| [165] | 90 | SetAxesFlags(kBoxAxes | kExtTicks | kLabels); | 
|---|
|  | 91 | } | 
|---|
|  | 92 |  | 
|---|
|  | 93 |  | 
|---|
|  | 94 | /* --Methode-- */ | 
|---|
| [205] | 95 | void PIStarList::Draw(PIGraphicUC* g, double xmin, double ymin, double xmax, double ymax) | 
|---|
| [165] | 96 | { | 
|---|
|  | 97 | BStar *sti; | 
|---|
| [205] | 98 | double xp,yp; | 
|---|
|  | 99 | float flx; | 
|---|
| [165] | 100 | int sz; | 
|---|
|  | 101 | char buff[128]; | 
|---|
|  | 102 | int nok, nl2; | 
|---|
|  | 103 |  | 
|---|
|  | 104 | if (!mStL) return; | 
|---|
|  | 105 |  | 
|---|
| [685] | 106 | PIGrCoord uxmin, uxmax, uymin, uymax; | 
|---|
|  | 107 | g->GetGrSpace(uxmin, uxmax, uymin, uymax); | 
|---|
|  | 108 | double xmin2 = uxmin; | 
|---|
|  | 109 | double ymin2 = uymin; | 
|---|
|  | 110 | double xmax2 = uxmax; | 
|---|
|  | 111 | double ymax2 = uymax; | 
|---|
|  | 112 |  | 
|---|
| [1920] | 113 | // int msz = mMSz; //OP | 
|---|
|  | 114 | int  msz = GetGraphicAtt().GetMarkerSz(); | 
|---|
|  | 115 |  | 
|---|
| [165] | 116 | if (msz < 1) msz = 1; | 
|---|
| [1920] | 117 | //PIMarker mrk = (mMrk != PI_NotDefMarker) ? mMrk : PI_FCircleMarker; //OP | 
|---|
|  | 118 | PIMarker mmrk = GetGraphicAtt().GetMarker(); | 
|---|
|  | 119 | PIMarker mrk = (mmrk != PI_NotDefMarker) ? mmrk : PI_FCircleMarker; | 
|---|
|  | 120 |  | 
|---|
| [165] | 121 | // g->SelFont(); | 
|---|
|  | 122 | nok = 0;  nl2 = mNLev*2-1; | 
|---|
|  | 123 | for (int i=0; i<mStL->NbStars(); i++) { | 
|---|
|  | 124 | sti = mStL->Star(i); | 
|---|
|  | 125 | if ( !(sti->Nice(BStar::flagOK)) )  continue; | 
|---|
|  | 126 | flx = sti->Flux(); | 
|---|
|  | 127 | if ( (flx < mFmin) || (flx > mFmax) )  continue; | 
|---|
|  | 128 | xp = sti->PosX();   yp = sti->PosY(); | 
|---|
| [685] | 129 | if ( (xp < xmin2) || (xp > xmax2) || (yp < ymin2) || (yp > ymax2) )  continue; | 
|---|
| [165] | 130 | nok++; | 
|---|
| [686] | 131 | if ( (xp < xmin) || (xp > xmax) || (yp < ymin) || (yp > ymax) )  continue; | 
|---|
| [165] | 132 | sz = (int)((log10((double)flx/mF0))/mDLgF*(double)nl2-0.01) + msz; | 
|---|
|  | 133 | if (sz < 2)  g->SelMarker(sz, PI_DotMarker); | 
|---|
|  | 134 | else g->SelMarker(sz, mrk); | 
|---|
|  | 135 | g->DrawMarker((double)xp,(double)yp ); | 
|---|
|  | 136 | if (mDspFV) { | 
|---|
|  | 137 | sprintf(buff," F=%g", flx); | 
|---|
| [205] | 138 | double dx,dy; | 
|---|
| [165] | 139 | g->DGrC2UC(sz, 4, dx, dy); | 
|---|
|  | 140 | g->DrawString(xp+dx, yp-dy, buff); | 
|---|
|  | 141 | } | 
|---|
|  | 142 | } | 
|---|
|  | 143 |  | 
|---|
|  | 144 | /* | 
|---|
|  | 145 | sprintf(buff, "StarList:  NbStars= %d  NDisp= %d", (int)mStL->NbStars(), nok); | 
|---|
|  | 146 | g->BaseGraphic()->DrawString(15,15,buff); | 
|---|
|  | 147 | sprintf(buff, "FMin= %g  FMax= %g Nl= %d Sz0= %d", mFmin, mFmax, mNLev, mMSz0); | 
|---|
|  | 148 | g->BaseGraphic()->DrawString(15,30,buff); | 
|---|
|  | 149 | */ | 
|---|
|  | 150 |  | 
|---|
|  | 151 | } | 
|---|
|  | 152 |  | 
|---|
| [344] | 153 | /* --Methode-- */ | 
|---|
|  | 154 | void PIStarList::AppendTextInfo(string& info, double xmin, double ymin, double xmax, double ymax) | 
|---|
|  | 155 | { | 
|---|
|  | 156 | BStar *sti; | 
|---|
|  | 157 | double xp,yp; | 
|---|
|  | 158 | double flx,fnd; | 
|---|
|  | 159 | char buff[128]; | 
|---|
|  | 160 | int ncnt = 0; | 
|---|
| [685] | 161 | sprintf(buff,"PIStarList: NStars %d \n", mStL->NbStars() ); | 
|---|
| [344] | 162 | info += buff; | 
|---|
| [2185] | 163 | info += "  Num:     XPos     YPos     Flux     Fond \n"; | 
|---|
| [344] | 164 | for (int i=0; i<mStL->NbStars(); i++) { | 
|---|
|  | 165 | sti = mStL->Star(i); | 
|---|
|  | 166 | if ( !(sti->Nice(BStar::flagOK)) )  continue; | 
|---|
|  | 167 | flx = sti->Flux(); | 
|---|
| [2185] | 168 | fnd = sti->Fond(); | 
|---|
| [344] | 169 | if ( (flx < mFmin) || (flx > mFmax) )  continue; | 
|---|
|  | 170 | xp = sti->PosX();   yp = sti->PosY(); | 
|---|
|  | 171 | if ( (xp < xmin) || (xp > xmax) || (yp < ymin) || (yp > ymax) )  continue; | 
|---|
|  | 172 | ncnt++; | 
|---|
|  | 173 | if (ncnt > 101) continue; | 
|---|
|  | 174 | fnd = sti->Fond(); | 
|---|
|  | 175 | sprintf(buff,"%6d: %8.3g %8.3g %8.3g %8.3g \n", i, xp, yp, flx, fnd); | 
|---|
|  | 176 | info += buff; | 
|---|
|  | 177 | } | 
|---|
|  | 178 | if (ncnt >= 101) info += " .... \n"; | 
|---|
|  | 179 | sprintf(buff," %d stars inside selected region \n", ncnt); | 
|---|
|  | 180 | info += buff; | 
|---|
|  | 181 | return; | 
|---|
|  | 182 | } | 
|---|