Changeset 7264
- Timestamp:
- 08/05/05 18:13:49 (19 years ago)
- Location:
- trunk/MagicSoft/Mars
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/MagicSoft/Mars/Changelog
r7263 r7264 24 24 - fixed abug which caused problems if now source position was 25 25 defined in the dataset. 26 27 * mastro/MAstroCatalog.[h,cc]: 28 - added new base class TAttMarker 29 - added new data mebers MAttLine for the two line types 30 - some simplification to the atoi/atof stuff 31 - added new helper class MAttLine 32 - increased class version to 2 26 33 27 34 -
trunk/MagicSoft/Mars/NEWS
r7251 r7264 16 16 17 17 - general: MHillas - the case of CorrXY==0 is now handled properly 18 19 - general: implemnetd the possibility to change the line and 20 marker style of a sky-grid drawn by MAstroCatalog 18 21 19 22 - general: Runs in sequences and datasets are now automatically -
trunk/MagicSoft/Mars/mastro/MAstroCatalog.cc
r7181 r7264 17 17 ! 18 18 ! Author(s): Thomas Bretz, 03/2004 <mailto:tbretz@astro.uni-wuerzburg.de> 19 ! Author(s): Robert Wagner, 08/2004 <mailto:rwagner@mppmu.mpg.de>20 19 ! 21 ! Copyright: MAGIC Software Development, 2002-200 420 ! Copyright: MAGIC Software Development, 2002-2005 22 21 ! 23 22 ! … … 121 120 // http://heasarc.gsfc.nasa.gov/W3Browse/star-catalog/ 122 121 // 122 // Class Version 2: 123 // + MAttLine fAttLineSky; // Line Style and color for sky coordinates 124 // + MAttLine fAttLineLocal; // Line Style and color for local coordinates 125 // + added new base class TAttMarker 126 // 123 127 ////////////////////////////////////////////////////////////////////////////// 124 128 #include "MAstroCatalog.h" … … 154 158 #endif 155 159 160 ClassImp(MAttLine); 156 161 ClassImp(MAstroCatalog); 157 162 … … 170 175 171 176 fToolTip = gROOT->IsBatch() || !gClient ? 0 : new TGToolTip(0, "", 0); 177 178 fAttLineSky.SetLineStyle(kDashDotted); 179 fAttLineLocal.SetLineStyle(kDashDotted); 180 181 fAttLineSky.SetLineColor(kRed); 182 fAttLineLocal.SetLineColor(kBlue); 183 184 SetMarkerColor(kBlack); 185 SetMarkerStyle(kCircle); 172 186 } 173 187 … … 221 235 // -------------------------------------------------------------------------- 222 236 // 223 // return int correspoding to TSubString224 //225 Int_t MAstroCatalog::atoi(const TSubString &sub)226 {227 return atoi(TString(sub));228 }229 230 // --------------------------------------------------------------------------231 //232 // return float correspoding to TSubString233 //234 Float_t MAstroCatalog::atof(const TSubString &sub)235 {236 return atof(TString(sub));237 }238 239 // --------------------------------------------------------------------------240 //241 237 // return int correspoding to TString 242 238 // 243 239 Int_t MAstroCatalog::atoi(const TString &s) 244 240 { 245 return std::atoi(s);241 return const_cast<TString&>(s).Atoi(); 246 242 } 247 243 … … 252 248 Float_t MAstroCatalog::atof(const TString &s) 253 249 { 254 return std::atof(s);250 return const_cast<TString&>(s).Atof(); 255 251 } 256 252 … … 678 674 { 679 675 if (gPad) 680 SetRangePad(o);676 SetRangePad(o); 681 677 682 678 if (TestBit(kHasChanged)) … … 748 744 749 745 // draw star on the camera display 750 TMarker *tip=new TMarker(x, y, col<0 ? kDot : kFullDotMedium);; 751 tip->SetMarkerColor(col); 746 TMarker *tip=new TMarker(x, y, kDot); 747 TAttMarker::Copy(*tip); 748 752 749 fMapG.Add(tip, new TString(str)); 753 750 754 if (!resize) 755 return; 756 757 tip->SetMarkerSize((10 - (mag>1 ? mag : 1))/15); 758 tip->SetMarkerStyle(kCircle); 751 if (resize) 752 tip->SetMarkerSize((10 - (mag>1 ? mag : 1))/15); 759 753 } 760 754 … … 870 864 871 865 TLine *line = new TLine(v0.X(), v0.Y(), v1.X(), v1.Y()); 872 line->SetLineStyle(kDashDotted); //kDashed, kDotted, kDashDotted 873 line->SetLineColor(kWhite+type*2); 866 if (type==1) 867 dynamic_cast<TAttLine&>(fAttLineSky).Copy(dynamic_cast<TAttLine&>(*line)); 868 else 869 dynamic_cast<TAttLine&>(fAttLineLocal).Copy(dynamic_cast<TAttLine&>(*line)); 874 870 fMapG.Add(line); 875 871 … … 1152 1148 const Bool_t yellow = o.Contains("yellow", TString::kIgnoreCase) && !white; 1153 1149 1150 if (white) 1151 SetMarkerColor(kWhite); 1152 1154 1153 // X is vice versa, because ra is defined anti-clockwise 1155 1154 mirx || mirror ? ResetBit(kMirrorX) : SetBit(kMirrorX); … … 1208 1207 // -------------------------------------------------------------------------- 1209 1208 // 1210 // First delete all gui elements. 1211 // Set the correct range of the pad. 1212 // Create all gui primitives 1213 // If "this" is not in the current pad add it to the current pad. 1214 // Reset vit kHasChanged 1215 // 1209 // Bends some pointers into the right direction... 1210 // Calls TAttLine::SetLineAttributes and connects some signals 1211 // to the gui to recreate the gui elements if something has changed. 1212 // 1213 void MAstroCatalog::SetLineAttributes(MAttLine &att) 1214 { 1215 if (!gPad) 1216 return; 1217 1218 gPad->SetSelected(&att); 1219 gROOT->SetSelectedPrimitive(&att); 1220 1221 att.SetLineAttributes(); 1222 1223 TQObject::Connect("TGColorSelect", "ColorSelected(Pixel_t)", "MAstroCatalog", this, "ForceUpdate()"); 1224 TQObject::Connect("TGListBox", "Selected(Int_t)", "MAstroCatalog", this, "ForceUpdate()"); 1225 } 1226 1227 // -------------------------------------------------------------------------- 1228 // 1229 // Calls TAttMarker::SetMarkerAttributes and connects some signals 1230 // to the gui to recreate the gui elements if something has changed. 1231 // 1232 void MAstroCatalog::SetMarkerAttributes() 1233 { 1234 if (!gPad) 1235 return; 1236 1237 TAttMarker::SetMarkerAttributes(); 1238 1239 // Make sure that if something is changed the gui elements 1240 // are recreated 1241 TQObject::Connect("TGedMarkerSelect", "MarkerSelected(Style_t)", "MAstroCatalog", this, "ForceUpdate()"); 1242 TQObject::Connect("TGColorSelect", "ColorSelected(Pixel_t)", "MAstroCatalog", this, "ForceUpdate()"); 1243 TQObject::Connect("TGListBox", "Selected(Int_t)", "MAstroCatalog", this, "ForceUpdate()"); 1244 } 1245 1216 1246 void MAstroCatalog::DrawPrimitives(Option_t *o) 1217 1247 { -
trunk/MagicSoft/Mars/mastro/MAstroCatalog.h
r4977 r7264 7 7 #ifndef ROOT_TList 8 8 #include <TList.h> 9 #endif 10 #ifndef ROOT_TAttLine 11 #include <TAttLine.h> 12 #endif 13 #ifndef ROOT_TAttMarker 14 #include <TAttMarker.h> 9 15 #endif 10 16 #ifndef MARS_MGMap … … 17 23 class TGToolTip; 18 24 19 class MAstroCatalog : public TObject 25 class MAttLine : public TObject, public TAttLine 26 { 27 public: 28 MAttLine() { } 29 ClassDef(MAttLine, 1) // Helper class to have a TAttLine derving from TObject (for standalone GED editor) 30 }; 31 32 class MAstroCatalog : public TObject, public TAttMarker 20 33 { 21 34 private: 22 Double_t fLimMag; // [1] Limiting Magnitude23 Double_t fRadiusFOV; // [deg] Radius of Field of View35 Double_t fLimMag; // [1] Limiting Magnitude 36 Double_t fRadiusFOV; // [deg] Radius of Field of View 24 37 25 TGToolTip *fToolTip; //! The tooltip currently displayed 38 TGToolTip *fToolTip; //! The tooltip currently displayed 39 40 MAttLine fAttLineSky; // Line Style and color for sky coordinates 41 MAttLine fAttLineLocal; // Line Style and color for local coordinates 26 42 27 43 void ShowToolTip(Int_t px, Int_t py, const char *txt); 44 void SetLineAttributes(MAttLine &att); 28 45 29 46 TString FindToken(TString &line, Char_t tok=','); 30 47 31 Int_t atoi(const TSubString &sub);32 Float_t atof(const TSubString &sub);33 48 Int_t atoi(const TString &s); 34 49 Float_t atof(const TString &s); 35 50 36 51 //#if ROOT_VERSION_CODE < ROOT_VERSION(4,00,03) 37 Bool_t fPlainScreen; //! Just a dummy!!!! ([Set,Is]Freezed)38 Bool_t fNoToolTips; //! Just a dummy!!!! ([Set,Is]Freezed)52 // Bool_t fPlainScreen; //! Just a dummy!!!! ([Set,Is]Freezed) 53 // Bool_t fNoToolTips; //! Just a dummy!!!! ([Set,Is]Freezed) 39 54 //#endif 40 55 … … 84 99 ~MAstroCatalog(); 85 100 101 void ForceUpdate() { Update(kTRUE); } // Slot for marker handling 102 103 // Setter to control the sky position and behaviour 86 104 void SetTime(const MTime &time); 87 105 void SetObservatory(const MObservatory &obs); … … 109 127 } // Set Radius of FOV using the pixsize [arcsec/pix], width and height [pixel] of image 110 128 111 void SetRaDec(Double_t ra, Double_t dec) { fRaDec.SetRaDec(ra, dec, 1); Update(); }112 void SetRaDec(const TVector3 &v) { fRaDec=v; Update(); }113 void SetGuiActive(Bool_t b=kTRUE) { b ? SetBit(kGuiActive) : ResetBit(kGuiActive); }129 void SetRaDec(Double_t ra, Double_t dec) { fRaDec.SetRaDec(ra, dec, 1); Update(); } 130 void SetRaDec(const TVector3 &v) { fRaDec=v; Update(); } 131 void SetGuiActive(Bool_t b=kTRUE) { b ? SetBit(kGuiActive) : ResetBit(kGuiActive); } 114 132 115 void SetPlainScreen(Bool_t b=kTRUE) { b ? SetBit(kPlainScreen) : ResetBit(kPlainScreen); Update(); } // *TOGGLE* *GETTER=IsPlainScreen116 Bool_t IsPlainScreen() const { return TestBit(kPlainScreen); }133 void SetPlainScreen(Bool_t b=kTRUE) { b ? SetBit(kPlainScreen) : ResetBit(kPlainScreen); Update(); } // *TOGGLE* *GETTER=IsPlainScreen 134 Bool_t IsPlainScreen() const { return TestBit(kPlainScreen); } 117 135 118 void SetNoToolTips(Bool_t b=kTRUE) { b ? SetBit(kNoToolTips) : ResetBit(kNoToolTips); } // *TOGGLE* *GETTER=HasNoToolTips119 Bool_t HasNoToolTips() const { return TestBit(kNoToolTips); }136 void SetNoToolTips(Bool_t b=kTRUE) { b ? SetBit(kNoToolTips) : ResetBit(kNoToolTips); } // *TOGGLE* *GETTER=HasNoToolTips 137 Bool_t HasNoToolTips() const { return TestBit(kNoToolTips); } 120 138 121 139 Double_t GetLimMag() const { return fLimMag; } // Get Limiting Magnitude 122 140 Double_t GetRadiusFOV() const { return fRadiusFOV; } // Get maximum radius of Field Of View 123 141 124 void Delete(Option_t *o="") { fList.Delete(); fMapG.Delete(); } // Delete list of stars 125 126 Int_t ReadXephem(TString catalog = "/usr/X11R6/lib/xephem/catalogs/YBS.edb"); 127 Int_t ReadNGC2000(TString catalog = "ngc2000.dat"); 128 Int_t ReadBSC(TString catalog = "bsc5.dat"); 129 Int_t ReadHeasarcPPM(TString catalog = "heasarc_ppm.tdat", TString fout=""); 130 Int_t ReadCompressed(TString catalog); 142 // Interface to set stars 143 Int_t ReadXephem(TString catalog = "/usr/X11R6/lib/xephem/catalogs/YBS.edb"); 144 Int_t ReadNGC2000(TString catalog = "ngc2000.dat"); 145 Int_t ReadBSC(TString catalog = "bsc5.dat"); 146 Int_t ReadHeasarcPPM(TString catalog = "heasarc_ppm.tdat", TString fout=""); 147 Int_t ReadCompressed(TString catalog); 131 148 Bool_t AddObject(Float_t ra, Float_t dec, Float_t mag, TString name=""); 132 149 133 void Print(Option_t *o="") const { fList.Print(); } // Print all stars 134 150 // Interface to get stars 135 151 TList *GetList() { return &fList; } // Return list of stars 136 152 137 //void PaintImg(Int_t id=0, Option_t *o=""); 138 void PaintImg(unsigned char *buf, int w=768, int h=576, Option_t *o=0); 153 // TObject 154 void Delete(Option_t *o="") { fList.Delete(); fMapG.Delete(); } // Delete list of stars 155 void Print(Option_t *o="") const { fList.Print(); } // Print all stars 139 156 void Draw(Option_t *o=""); 140 157 void SetDrawOption(Option_t *option="") … … 144 161 } //*MENU* 145 162 163 // Interface to Cosy 164 void PaintImg(unsigned char *buf, int w=768, int h=576, Option_t *o=0); 165 166 // Interface to line styles 167 void SetLineAttributesLocal() { SetLineAttributes(fAttLineLocal); } //*MENU* 168 void SetLineAttributesSky() { SetLineAttributes(fAttLineSky); } //*MENU* 169 void SetMarkerAttributes(); //*MENU* 170 146 171 virtual void EventInfo(Int_t event, Int_t px, Int_t py, TObject *selected=0); 147 172 148 ClassDef(MAstroCatalog, 1) // Display class for star catalogs173 ClassDef(MAstroCatalog, 2) // Display class for star catalogs 149 174 }; 150 175
Note:
See TracChangeset
for help on using the changeset viewer.