/***************************************************************************************** * * * OpenSpace * * * * Copyright (c) 2014-2020 * * * * Permission is hereby granted, free of charge, to any person obtaining a copy of this * * software and associated documentation files (the "Software"), to deal in the Software * * without restriction, including without limitation the rights to use, copy, modify, * * merge, publish, distribute, sublicense, and/or sell copies of the Software, and to * * permit persons to whom the Software is furnished to do so, subject to the following * * conditions: * * * * The above copyright notice and this permission notice shall be included in all copies * * or substantial portions of the Software. * * * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, * * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A * * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT * * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF * * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE * * OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * ****************************************************************************************/ #ifndef __OPENSPACE_MODULE_SPACE___RENDERABLEORBITALKEPLER___H__ #define __OPENSPACE_MODULE_SPACE___RENDERABLEORBITALKEPLER___H__ #include #include #include #include #include #include #include #include namespace openspace { const std::vector LeapYears = { 1956, 1960, 1964, 1968, 1972, 1976, 1980, 1984, 1988, 1992, 1996, 2000, 2004, 2008, 2012, 2016, 2020, 2024, 2028, 2032, 2036, 2040, 2044, 2048, 2052, 2056 }; int countDays(int year); int countLeapSeconds(int year, int dayOfYear); double calculateSemiMajorAxis(double meanMotion); double epochFromSubstring(const std::string& epochString); class RenderableOrbitalKepler : public Renderable { public: RenderableOrbitalKepler(const ghoul::Dictionary& dictionary); void initializeGL() override; void deinitializeGL() override; bool isReady() const override; void render(const RenderData& data, RendererTasks& rendererTask) override; static documentation::Documentation Documentation(); /** * Reads the provided data file and calls the KeplerTranslation::setKeplerElments * method with the correct values. If \p filename is a valid data file but contains * disallowed values (see KeplerTranslation::setKeplerElements), a * KeplerTranslation::RangeError is thrown. * * \param filename The path to the file that contains the data file. * * \throw ghoul::RuntimeError if the data file does not exist or there is a * problem with its format. * \pre The \p filename must exist */ virtual void readDataFile(const std::string& filename) = 0; private: struct Vertex { glm::vec3 position = glm::vec3(0.f); glm::vec3 color = glm::vec3(0.f); glm::vec2 texcoord = glm::vec2(0.f); }; struct KeplerParameters { double inclination = 0.0; double semiMajorAxis = 0.0; double ascendingNode = 0.0; double eccentricity = 0.0; double argumentOfPeriapsis = 0.0; double meanAnomaly = 0.0; double meanMotion = 0.0; double epoch = 0.0; double period = 0.0; }; /// The layout of the VBOs struct TrailVBOLayout { float x = 0.f; float y = 0.f; float z = 0.f; float time = 0.f; double epoch = 0.0; double period = 0.0; }; KeplerTranslation _keplerTranslator; std::vector _data; /// The backend storage for the vertex buffer object containing all points for this /// trail. std::vector _vertexBufferData; GLuint _vertexArray; GLuint _vertexBuffer; GLuint _indexBuffer; //GLuint _vaoTest; // vertexArrayObject //GLuint _vboTest; // vertextBufferObject //GLuint _eboTest; // elementBufferObject/ indexBufferObject void updateBuffers(); ghoul::opengl::ProgramObject* _programObject; properties::StringProperty _path; properties::UIntProperty _nSegments; properties::UIntProperty _upperLimit; RenderableTrail::Appearance _appearance; glm::vec3 _position = glm::vec3(0.f); UniformCache(modelView, projection, lineFade, inGameTime, color, opacity, numberOfSegments) _uniformCache; }; } // namespace openspace #endif // __OPENSPACE_MODULE_SPACE___RENDERABLEORBITALKEPLER___H__