00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef _CONSTELLATION_HPP_
00021 #define _CONSTELLATION_HPP_
00022
00023 #include <vector>
00024 #include <boost/intrusive_ptr.hpp>
00025 #include <QString>
00026
00027 #include "StelObject.hpp"
00028 #include "StelUtils.hpp"
00029 #include "StelFader.hpp"
00030 #include "StelTextureTypes.hpp"
00031
00032 class StarMgr;
00033 class StelFont;
00034 class StelPainter;
00035
00041 class Constellation : public StelObject
00042 {
00043 friend class ConstellationMgr;
00044 private:
00045 Constellation();
00046 ~Constellation();
00047
00048
00055 virtual QString getInfoString(const StelCore* core, const InfoStringGroup& flags) const
00056 {
00057 if (flags&Name) return getNameI18n() + "(" + getShortName() + ")";
00058 else return "";
00059 }
00060
00063 virtual QString getType(void) const {return "Constellation";}
00064
00066 virtual Vec3d getJ2000EquatorialPos(const StelNavigator *nav) const {return XYZname;}
00067
00068 virtual double getAngularSize(const StelCore* core) const {Q_ASSERT(0); return 0;};
00069
00077 bool read(const QString& record, StarMgr *starMgr);
00078
00080 void drawName(StelFont * constfont, const StelPainter& sPainter) const;
00082 void drawArt(const StelProjectorP& prj, const StelNavigator* nav) const;
00084 void drawBoundaryOptim(const StelProjectorP& prj) const;
00085
00091 const Constellation* isStarIn(const StelObject*) const;
00092
00097 StelObjectP getBrightestStarInConstellation(void) const;
00098
00100 QString getNameI18n(void) const {return nameI18;}
00102 QString getEnglishName(void) const {return abbreviation;}
00104 QString getShortName(void) const {return abbreviation;}
00108 void drawOptim(const StelProjectorP& prj) const;
00110 void drawArtOptim(const StelProjectorP& prj, const StelNavigator* nav) const;
00112 void update(int deltaTime);
00115 void setFlagLines(bool b) {lineFader=b;}
00118 void setFlagBoundaries(bool b) {boundaryFader=b;}
00121 void setFlagName(bool b) {nameFader=b;}
00124 void setFlagArt(bool b) {artFader=b;}
00127 bool getFlagLines(void) const {return lineFader;}
00130 bool getFlagBoundaries(void) const {return boundaryFader;}
00133 bool getFlagName(void) const {return nameFader;}
00136 bool getFlagArt(void) const {return artFader;}
00137
00139 QString nameI18;
00141 QString englishName;
00143 QString nativeName;
00145 QString abbreviation;
00147 Vec3f XYZname;
00148 Vec3d XYname;
00150 unsigned int numberOfSegments;
00152 StelObjectP* asterism;
00153 StelTextureSP artTexture;
00154 Vec3d artVertex[9];
00155
00157 LinearFader artFader, lineFader, nameFader, boundaryFader;
00158 std::vector<std::vector<Vec3f> *> isolatedBoundarySegments;
00159 std::vector<std::vector<Vec3f> *> sharedBoundarySegments;
00160
00162 static Vec3f lineColor;
00163 static Vec3f labelColor;
00164 static Vec3f boundaryColor;
00165
00166 static bool singleSelected;
00167 };
00168
00169 #endif // _CONSTELLATION_HPP_