1
0
mirror of https://github.com/f4exb/sdrangel.git synced 2024-11-26 17:58:43 -05:00
sdrangel/plugins/feature/startracker/startrackersettings.cpp

232 lines
7.6 KiB
C++

///////////////////////////////////////////////////////////////////////////////////
// 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 <http://www.gnu.org/licenses/>. //
///////////////////////////////////////////////////////////////////////////////////
#include <QColor>
#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() :
m_rollupState(nullptr)
{
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);
if (m_rollupState) {
s.writeBlob(44, m_rollupState->serialize());
}
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);
if (m_rollupState)
{
d.readBlob(44, &bytetmp);
m_rollupState->deserialize(bytetmp);
}
return true;
}
else
{
resetToDefaults();
return false;
}
}