/////////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2021 Jon Beniston, M7RCE // // Copyright (C) 2020 Edouard Griffiths, F4EXB // // // // 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 as 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 V3 for more details. // // // // You should have received a copy of the GNU General Public License // // along with this program. If not, see . // /////////////////////////////////////////////////////////////////////////////////// #include #include "util/simpleserializer.h" #include "settings/serializable.h" #include "startrackersettings.h" const QStringList StarTrackerSettings::m_pipeTypes = { QStringLiteral("RadioAstronomy") }; const QStringList StarTrackerSettings::m_pipeURIs = { QStringLiteral("sdrangel.channel.radioastronomy") }; StarTrackerSettings::StarTrackerSettings() { resetToDefaults(); } void StarTrackerSettings::resetToDefaults() { m_ra = ""; m_dec = ""; m_latitude = 0.0; m_longitude = 0.0; m_target = "Sun"; m_dateTime = ""; m_refraction = "Positional Astronomy Library"; m_pressure = 1010; m_temperature = 10; m_humidity = 80.0; m_heightAboveSeaLevel = 0.0; m_temperatureLapseRate = 6.49; m_frequency = 432000000; m_beamwidth = 25.0; m_enableServer = true; m_serverPort = 10001; m_azElUnits = DM; m_solarFluxData = DRAO_2800; m_solarFluxUnits = SFU; m_updatePeriod = 1.0; m_jnow = false; m_drawSunOnMap = true; m_drawMoonOnMap = true; m_drawStarOnMap = true; m_chartsDarkTheme = true; m_title = "Star Tracker"; m_rgbColor = QColor(225, 25, 99).rgb(); m_useReverseAPI = false; m_reverseAPIAddress = "127.0.0.1"; m_reverseAPIPort = 8888; m_reverseAPIFeatureSetIndex = 0; m_reverseAPIFeatureIndex = 0; m_az = 0.0; m_el = 0.0; m_l = 0.0; m_b = 0.0; m_azOffset = 0.0; m_elOffset = 0.0; m_link = false; m_owmAPIKey = ""; m_weatherUpdatePeriod = 60; m_drawSunOnSkyTempChart = true; m_drawMoonOnSkyTempChart = true; } QByteArray StarTrackerSettings::serialize() const { SimpleSerializer s(1); s.writeString(1, m_ra); s.writeString(2, m_dec); s.writeDouble(3, m_latitude); s.writeDouble(4, m_longitude); s.writeString(5, m_target); s.writeString(6, m_dateTime); s.writeU32(7, m_enableServer); s.writeU32(8, m_serverPort); s.writeS32(9, m_azElUnits); s.writeFloat(10, m_updatePeriod); s.writeBool(11, m_jnow); s.writeString(12, m_refraction); s.writeDouble(13, m_pressure); s.writeDouble(14, m_temperature); s.writeDouble(15, m_humidity); s.writeDouble(16, m_heightAboveSeaLevel); s.writeDouble(17, m_temperatureLapseRate); s.writeDouble(18, m_frequency); s.writeBool(19, m_drawSunOnMap); s.writeBool(20, m_drawMoonOnMap); s.writeBool(21, m_drawStarOnMap); s.writeString(22, m_title); s.writeU32(23, m_rgbColor); s.writeBool(24, m_useReverseAPI); s.writeString(25, m_reverseAPIAddress); s.writeU32(26, m_reverseAPIPort); s.writeU32(27, m_reverseAPIFeatureSetIndex); s.writeU32(28, m_reverseAPIFeatureIndex); s.writeU32(29, m_solarFluxUnits); s.writeDouble(30, m_beamwidth); s.writeU32(31, m_solarFluxData); s.writeBool(32, m_chartsDarkTheme); s.writeDouble(33, m_az); s.writeDouble(34, m_el); s.writeDouble(35, m_l); s.writeDouble(36, m_b); s.writeBool(37, m_link); s.writeString(38, m_owmAPIKey); s.writeS32(39, m_weatherUpdatePeriod); s.writeDouble(40, m_azOffset); s.writeDouble(41, m_elOffset); s.writeBool(42, m_drawSunOnSkyTempChart); s.writeBool(43, m_drawMoonOnSkyTempChart); s.writeBlob(44, m_rollupState); return s.final(); } bool StarTrackerSettings::deserialize(const QByteArray& data) { SimpleDeserializer d(data); if (!d.isValid()) { resetToDefaults(); return false; } if (d.getVersion() == 1) { QByteArray bytetmp; uint32_t utmp; QString strtmp; d.readString(1, &m_ra, ""); d.readString(2, &m_dec, ""); d.readDouble(3, &m_latitude, 0.0); d.readDouble(4, &m_longitude, 0.0); d.readString(5, &m_target, "Sun"); d.readString(6, &m_dateTime, ""); d.readBool(7, &m_enableServer, true); d.readU32(8, &utmp, 0); if ((utmp > 1023) && (utmp < 65535)) { m_serverPort = utmp; } else { m_serverPort = 10001; } d.readS32(9, (qint32 *)&m_azElUnits, DM); d.readFloat(10, &m_updatePeriod, 1.0f); d.readBool(11, &m_jnow, false); d.readString(12, &m_refraction, "Positional Astronomy Library"); d.readDouble(13, &m_pressure, 1010); d.readDouble(14, &m_temperature, 10); d.readDouble(15, &m_humidity, 10); d.readDouble(16, &m_heightAboveSeaLevel, 80); d.readDouble(17, &m_temperatureLapseRate, 6.49); d.readDouble(18, &m_frequency, 435000000.0); d.readBool(19, &m_drawSunOnMap, true); d.readBool(20, &m_drawMoonOnMap, true); d.readBool(21, &m_drawStarOnMap, true); d.readString(22, &m_title, "Star Tracker"); d.readU32(23, &m_rgbColor, QColor(225, 25, 99).rgb()); d.readBool(24, &m_useReverseAPI, false); d.readString(25, &m_reverseAPIAddress, "127.0.0.1"); d.readU32(26, &utmp, 0); if ((utmp > 1023) && (utmp < 65535)) { m_reverseAPIPort = utmp; } else { m_reverseAPIPort = 8888; } d.readU32(27, &utmp, 0); m_reverseAPIFeatureSetIndex = utmp > 99 ? 99 : utmp; d.readU32(28, &utmp, 0); m_reverseAPIFeatureIndex = utmp > 99 ? 99 : utmp; d.readU32(29, (quint32 *)&m_solarFluxUnits, SFU); d.readDouble(30, &m_beamwidth, 25.0); d.readU32(31, (quint32 *)&m_solarFluxData, DRAO_2800); d.readBool(32, &m_chartsDarkTheme, true); d.readDouble(33, &m_az, 0.0); d.readDouble(34, &m_el, 0.0); d.readDouble(35, &m_l, 0.0); d.readDouble(36, &m_b, 0.0); d.readBool(37, &m_link, false); d.readString(38, &m_owmAPIKey, ""); d.readS32(39, &m_weatherUpdatePeriod, 60); d.readDouble(40, &m_azOffset, 0.0); d.readDouble(41, &m_elOffset, 0.0); d.readBool(42, &m_drawSunOnSkyTempChart, true); d.readBool(43, &m_drawMoonOnSkyTempChart, true); d.readBlob(44, &m_rollupState); return true; } else { resetToDefaults(); return false; } }