12345678910111213141516171819202122232425262728293031323334353637383940414243444546 |
- /*
- *openPilot Log - A FOSS Pilot Logbook Application
- *Copyright (C) 2020 Felix Turowsky
- *
- *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 3 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, see <https://www.gnu.org/licenses/>.
- */
- #ifndef CALC_H
- #define CALC_H
- #include <QDateTime>
- #include <cmath>
- #include <QDebug>
- /*!
- * \brief The calc class provides functionality for various calculations that are performed
- * outside of the database. This includes tasks like converting different units and formats,
- * or functions calculating block time or night time.
- */
- class calc
- {
- public:
- static QTime blocktime(QTime tofb, QTime tonb);
- static QString minutes_to_string(QString blockminutes);
- static int string_to_minutes(QString time);
- static int time_to_minutes(QTime time);
- static double radToDeg(double rad);
- static double degToRad(double deg);
- static double radToNauticalMiles(double rad);
- static double greatCircleDistance(double lat1, double lon1, double lat2, double lon2);
- static QVector<QVector<double>> intermediatePointsOnGreatCircle(double lat1, double lon1, double lat2, double lon2, int tblk);
- static double solarElevation(QDateTime utc_time_point, double lat, double lon);
- static int calculateNightTime(QString dept, QString dest, QDateTime departureTime, int tblk);
- };
- #endif // CALC_H
|