1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2025-01-22 07:52:12 +01:00

125 lines
4.6 KiB
C++

/**
******************************************************************************
*
* @file telemetryparser.cpp
* @author Edouard Lafargue & the OpenPilot team Copyright (C) 2010.
* @addtogroup GCSPlugins GCS Plugins
* @{
* @addtogroup GPSGadgetPlugin GPS Gadget Plugin
* @{
* @brief A gadget that displays GPS status and enables basic configuration
*****************************************************************************/
/*
* 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, write to the Free Software Foundation, Inc.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#include "telemetryparser.h"
#include <math.h>
#include <QDebug>
#include <QStringList>
/**
* Initialize the parser
*/
TelemetryParser::TelemetryParser(QObject *parent) : GPSParser(parent)
{
ExtensionSystem::PluginManager *pm = ExtensionSystem::PluginManager::instance();
UAVObjectManager *objManager = pm->getObject<UAVObjectManager>();
UAVDataObject *gpsObj = dynamic_cast<UAVDataObject *>(objManager->getObject("GPSPosition"));
if (gpsObj != NULL) {
connect(gpsObj, SIGNAL(objectUpdated(UAVObject *)), this, SLOT(updateGPS(UAVObject *)));
} else {
qDebug() << "Error: Object is unknown (GPSPosition).";
}
gpsObj = dynamic_cast<UAVDataObject *>(objManager->getObject("GPSTime"));
if (gpsObj != NULL) {
connect(gpsObj, SIGNAL(objectUpdated(UAVObject *)), this, SLOT(updateTime(UAVObject *)));
} else {
qDebug() << "Error: Object is unknown (GPSTime).";
}
gpsObj = dynamic_cast<UAVDataObject *>(objManager->getObject("GPSSatellites"));
if (gpsObj != NULL) {
connect(gpsObj, SIGNAL(objectUpdated(UAVObject *)), this, SLOT(updateSats(UAVObject *)));
}
}
TelemetryParser::~TelemetryParser()
{}
void TelemetryParser::updateGPS(UAVObject *object1)
{
UAVObjectField *field = object1->getField(QString("Satellites"));
emit sv(field->getValue().toInt());
double lat = object1->getField(QString("Latitude"))->getDouble();
double lon = object1->getField(QString("Longitude"))->getDouble();
double alt = object1->getField(QString("Altitude"))->getDouble();
lat *= 1E-7;
lon *= 1E-7;
emit position(lat, lon, alt);
double hdg = object1->getField(QString("Heading"))->getDouble();
double spd = object1->getField(QString("Groundspeed"))->getDouble();
emit speedheading(spd, hdg);
QString fix = object1->getField(QString("Status"))->getValue().toString();
emit fixtype(fix);
double hdop = object1->getField(QString("HDOP"))->getDouble();
double vdop = object1->getField(QString("VDOP"))->getDouble();
double pdop = object1->getField(QString("PDOP"))->getDouble();
emit dop(hdop, vdop, pdop);
}
void TelemetryParser::updateTime(UAVObject *object1)
{
double hour = object1->getField(QString("Hour"))->getDouble();
double minute = object1->getField(QString("Minute"))->getDouble();
double second = object1->getField(QString("Second"))->getDouble();
double time = second + minute * 100 + hour * 10000;
double year = object1->getField(QString("Year"))->getDouble();
double month = object1->getField(QString("Month"))->getDouble();
double day = object1->getField(QString("Day"))->getDouble();
double date = day + month * 100 + year * 10000;
emit datetime(date, time);
}
/**
Updates the satellite constellation.
Not really optimized for now, we should only send updates for the stas
which have changed instead of updating everything... That said, Qt is supposed
to be able to optimize redraws anyway.
*/
void TelemetryParser::updateSats(UAVObject *object1)
{
UAVObjectField *prn = object1->getField(QString("PRN"));
UAVObjectField *elevation = object1->getField(QString("Elevation"));
UAVObjectField *azimuth = object1->getField(QString("Azimuth"));
UAVObjectField *snr = object1->getField(QString("SNR"));
for (unsigned int i = 0; i < prn->getNumElements(); i++) {
emit satellite(i, prn->getValue(i).toInt(), elevation->getValue(i).toInt(),
azimuth->getValue(i).toInt(), snr->getValue(i).toInt());
}
}