/* * Stellarium * Copyright (C) 2002 Fabien Chereau * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Suite 500, Boston, MA 02110-1335, USA. */ #ifndef _PLANET_HPP_ #define _PLANET_HPP_ #include "StelObject.hpp" #include "StelProjector.hpp" #include "VecMath.hpp" #include "StelFader.hpp" #include "StelTextureTypes.hpp" #include "StelProjectorType.hpp" #include // The callback type for the external position computation function // The last variable is the userData pointer. typedef void (*posFuncType)(double, double*, void*); typedef void (OsculatingFunctType)(double jd0,double jd,double xyz[3]); // epoch J2000: 12 UT on 1 Jan 2000 #define J2000 2451545.0 #define ORBIT_SEGMENTS 360 class StelFont; class StelPainter; class StelTranslator; class QOpenGLShaderProgram; // Class used to store orbital elements class RotationElements { public: RotationElements(void) : period(1.), offset(0.), epoch(J2000), obliquity(0.), ascendingNode(0.), precessionRate(0.), siderealPeriod(0.) {} float period; // rotation period float offset; // rotation at epoch double epoch; float obliquity; // tilt of rotation axis w.r.t. ecliptic float ascendingNode; // long. of ascending node of equator on the ecliptic float precessionRate; // rate of precession of rotation axis in rads/day double siderealPeriod; // sidereal period (Planet year in earth days) }; // Class to manage rings for planets like saturn class Ring { public: Ring(float radiusMin, float radiusMax,const QString &texname); double getSize(void) const {return radiusMax;} const float radiusMin; const float radiusMax; StelTextureSP tex; }; class Planet : public StelObject { public: friend class SolarSystem; Planet(const QString& englishName, int flagLighting, double radius, double oblateness, Vec3f color, float albedo, const QString& texMapName, const QString& normalMapName, posFuncType _coordFunc, void* userDataPtr, OsculatingFunctType *osculatingFunc, bool closeOrbit, bool hidden, bool hasAtmosphere, bool hasHalo, const QString &pType); virtual ~Planet(); /////////////////////////////////////////////////////////////////////////// // Methods inherited from StelObject //! Get a string with data about the Planet. //! Planets support the following InfoStringGroup flags: //! - Name //! - Magnitude //! - RaDec //! - AltAzi //! - Distance //! - Size //! - PlainText //! - Extra: Heliocentric Ecliptical Coordinates & Observer-planetocentric Ecliptical Coordinates, Phase, illumination, phase angle & elongation from the Sun //! @param core the StelCore object //! @param flags a set of InfoStringGroup items to include in the return value. //! @return a QString containing an HMTL encoded description of the Planet. virtual QString getInfoString(const StelCore *core, const InfoStringGroup& flags) const; virtual double getCloseViewFov(const StelCore* core) const; virtual double getSatellitesFov(const StelCore* core) const; virtual double getParentSatellitesFov(const StelCore* core) const; virtual float getVMagnitude(const StelCore* core) const; virtual float getSelectPriority(const StelCore* core) const; virtual Vec3f getInfoColor(void) const; virtual QString getType(void) const {return "Planet";} virtual Vec3d getJ2000EquatorialPos(const StelCore *core) const; virtual QString getEnglishName(void) const {return englishName;} virtual QString getNameI18n(void) const {return nameI18;} virtual double getAngularSize(const StelCore* core) const; virtual bool hasAtmosphere(void) {return atmosphere;} virtual bool hasHalo(void) {return halo;} /////////////////////////////////////////////////////////////////////////// // Methods of SolarSystem object //! Translate planet name using the passed translator virtual void translateName(const StelTranslator &trans); // Draw the Planet // GZ Made that virtual to allow comets having their own draw(). virtual void draw(StelCore* core, float maxMagLabels, const QFont& planetNameFont); /////////////////////////////////////////////////////////////////////////// // Methods specific to Planet //! Get the radius of the planet in AU. //! @return the radius of the planet in astronomical units. double getRadius(void) const {return radius;} //! Get duration of sidereal day double getSiderealDay(void) const {return re.period;} //! Get duration of sidereal year // GZ: made that virtual for Comets. virtual double getSiderealPeriod(void) const { return re.siderealPeriod; } //! Get duration of mean solar day double getMeanSolarDay(void) const; const QString& getTextMapName() const {return texMapName;} // Compute the z rotation to use from equatorial to geographic coordinates double getSiderealTime(double jd) const; Mat4d getRotEquatorialToVsop87(void) const; void setRotEquatorialToVsop87(const Mat4d &m); const RotationElements &getRotationElements(void) const {return re;} // Compute the position in the parent Planet coordinate system void computePositionWithoutOrbits(const double date); void computePosition(const double date); // Compute the transformation matrix from the local Planet coordinate to the parent Planet coordinate void computeTransMatrix(double date); // Get the phase angle (rad) for an observer at pos obsPos in heliocentric coordinates (in AU) double getPhaseAngle(const Vec3d& obsPos) const; // Get the elongation angle (rad) for an observer at pos obsPos in heliocentric coordinates (in AU) double getElongation(const Vec3d& obsPos) const; // Get the angular size of the spheroid of the planet (i.e. without the rings) double getSpheroidAngularSize(const StelCore* core) const; // Get the planet phase for an observer at pos obsPos in heliocentric coordinates (in AU) float getPhase(const Vec3d& obsPos) const; // Set the orbital elements void setRotationElements(float _period, float _offset, double _epoch, float _obliquity, float _ascendingNode, float _precessionRate, double _siderealPeriod); double getRotAscendingnode(void) const {return re.ascendingNode;} double getRotObliquity(double JDay) const; //! Get the Planet position in the parent Planet ecliptic coordinate in AU Vec3d getEclipticPos() const; // Return the heliocentric ecliptical position Vec3d getHeliocentricEclipticPos() const; // Return the heliocentric transformation for local coordinate Vec3d getHeliocentricPos(Vec3d) const; void setHeliocentricEclipticPos(const Vec3d &pos); // Compute the distance to the given position in heliocentric coordinate (in AU) double computeDistance(const Vec3d& obsHelioPos); double getDistance(void) const {return distance;} void setRings(Ring* r) {rings = r;} void setSphereScale(float s) {sphereScale = s;} float getSphereScale(void) const {return sphereScale;} const QSharedPointer getParent(void) const {return parent;} static void setLabelColor(const Vec3f& lc) {labelColor = lc;} static const Vec3f& getLabelColor(void) {return labelColor;} // update displayed elements. @param deltaTime: ms (?) void update(int deltaTime); void setFlagHints(bool b){hintFader = b;} bool getFlagHints(void) const {return hintFader;} void setFlagLabels(bool b){flagLabels = b;} bool getFlagLabels(void) const {return flagLabels;} /////////////////////////////////////////////////////////////////////////// // DEPRECATED ///// Orbit related code // Should move to an OrbitPath class which works on a SolarSystemObject, not a Planet void setFlagOrbits(bool b){orbitFader = b;} bool getFlagOrbits(void) const {return orbitFader;} LinearFader orbitFader; // draw orbital path of Planet void drawOrbit(const StelCore*); Vec3d orbit[ORBIT_SEGMENTS+1]; // store heliocentric coordinates for drawing the orbit Vec3d orbitP[ORBIT_SEGMENTS+1]; // store local coordinate for orbit double lastOrbitJD; double deltaJD; // time difference between positional updates. double deltaOrbitJD; bool orbitCached; // whether orbit calculations are cached for drawing orbit yet bool closeOrbit; // whether to connect the beginning of the orbit line to // the end: good for elliptical orbits, bad for parabolic // and hyperbolic orbits static Vec3f orbitColor; static void setOrbitColor(const Vec3f& oc) {orbitColor = oc;} static const Vec3f& getOrbitColor() {return orbitColor;} //! Return the list of planets which project some shadow on this planet QVector getCandidatesForShadow() const; protected: static StelTextureSP texEarthShadow; // for lunar eclipses void computeModelMatrix(Mat4d &result) const; // Return the information string "ready to print" :) QString getSkyLabel(const StelCore* core) const; // Draw the 3d model. Call the proper functions if there are rings etc.. void draw3dModel(StelCore* core, StelProjector::ModelViewTranformP transfo, float screenSz, bool drawOnlyRing=false); // Draw the 3D sphere void drawSphere(StelPainter* painter, float screenSz, bool drawOnlyRing=false); // Draw the circle and name of the Planet void drawHints(const StelCore* core, const QFont& planetNameFont); QString englishName; // english planet name QString nameI18; // International translated name QString texMapName; // Texture file path QString normalMapName; // Texture file path int flagLighting; // Set whether light computation has to be proceed RotationElements re; // Rotation param double radius; // Planet radius in AU double oneMinusOblateness; // (polar radius)/(equatorial radius) Vec3d eclipticPos; // Position in AU in the rectangular ecliptic coordinate system // centered on the parent Planet Vec3d screenPos; // Used to store temporarily the 2D position on screen Vec3d previousScreenPos; // The position of this planet in the previous frame. Vec3f color; // exclusively used for drawing the planet halo float albedo; // Planet albedo. Used for magnitude computation (but formula dubious!) Mat4d rotLocalToParent; float axisRotation; // Rotation angle of the Planet on it's axis StelTextureSP texMap; // Planet map texture StelTextureSP normalMap; // Planet normal map texture Ring* rings; // Planet rings double distance; // Temporary variable used to store the distance to a given point // it is used for sorting while drawing float sphereScale; // Artificial scaling for better viewing double lastJD; // caches JD of last positional computation // The callback for the calculation of the equatorial rect heliocentric position at time JD. posFuncType coordFunc; void* userDataPtr; OsculatingFunctType *const osculatingFunc; QSharedPointer parent; // Planet parent i.e. sun for earth QList > satellites; // satellites of the Planet LinearFader hintFader; LinearFader labelsFader; // Store the current state of the label for this planet bool flagLabels; // Define whether labels should be displayed bool hidden; // useful for fake planets used as observation positions - not drawn or labeled bool atmosphere; // Does the planet have an atmosphere? bool halo; // Does the planet have a halo? QString pType; // Type of body static Vec3f labelColor; static StelTextureSP hintCircleTex; // Shader-related variables struct PlanetShaderVars { int projectionMatrix; int texCoord; int unprojectedVertex; int vertex; int texture; int lightDirection; int eyeDirection; int diffuseLight; int ambientLight; int shadowCount; int shadowData; int sunInfo; void initLocations(QOpenGLShaderProgram*); }; static PlanetShaderVars planetShaderVars; static QOpenGLShaderProgram* planetShaderProgram; // Shader-related variables struct RingPlanetShaderVars : public PlanetShaderVars { // Rings-specific variables int isRing; int ring; int outerRadius; int innerRadius; int ringS; }; static RingPlanetShaderVars ringPlanetShaderVars; static QOpenGLShaderProgram* ringPlanetShaderProgram; struct MoonShaderVars : public PlanetShaderVars { // Moon-specific variables int earthShadow; int normalMap; }; static MoonShaderVars moonShaderVars; static QOpenGLShaderProgram* moonShaderProgram; static void initShader(); static void deinitShader(); }; #endif // _PLANET_HPP_