1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2024-12-14 21:23:52 +01:00
LibrePilot/ground/openpilotgcs/src/plugins/antennatrack/telemetryparser.cpp

83 lines
2.8 KiB
C++
Raw Normal View History

2013-04-05 22:46:56 +02:00
/**
******************************************************************************
*
* @file telemetryparser.cpp
* @author Sami Korhonen & the OpenPilot team Copyright (C) 2010.
* @addtogroup GCSPlugins GCS Plugins
* @{
* @addtogroup AntennaTrackGadgetPlugin Antenna Track Gadget Plugin
* @{
* @brief A gadget that communicates with antenna tracker 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>();
2013-05-22 21:45:06 +02:00
UAVDataObject *gpsObj = dynamic_cast<UAVDataObject *>(objManager->getObject("GPSPositionSensor"));
2013-04-05 22:46:56 +02:00
if (gpsObj != NULL) {
connect(gpsObj, SIGNAL(objectUpdated(UAVObject *)), this, SLOT(updateGPS(UAVObject *)));
2013-04-05 22:46:56 +02:00
} else {
2013-05-22 21:45:06 +02:00
qDebug() << "Error: Object is unknown (GPSPositionSensor).";
2013-04-05 22:46:56 +02:00
}
gpsObj = dynamic_cast<UAVDataObject *>(objManager->getObject("HomeLocation"));
2013-04-05 22:46:56 +02:00
if (gpsObj != NULL) {
connect(gpsObj, SIGNAL(objectUpdated(UAVObject *)), this, SLOT(updateHome(UAVObject *)));
2013-04-05 22:46:56 +02:00
} else {
qDebug() << "Error: Object is unknown (HomeLocation).";
}
}
TelemetryParser::~TelemetryParser()
{}
2013-04-05 22:46:56 +02:00
void TelemetryParser::updateHome(UAVObject *object1)
{
2013-04-05 22:46:56 +02:00
double lat = object1->getField(QString("Latitude"))->getDouble();
double lon = object1->getField(QString("Longitude"))->getDouble();
double alt = object1->getField(QString("Altitude"))->getDouble();
2013-04-05 22:46:56 +02:00
lat *= 1E-7;
lon *= 1E-7;
emit home(lat, lon, alt);
2013-04-05 22:46:56 +02:00
}
void TelemetryParser::updateGPS(UAVObject *object1)
{
2013-04-05 22:46:56 +02:00
double lat = object1->getField(QString("Latitude"))->getDouble();
double lon = object1->getField(QString("Longitude"))->getDouble();
double alt = object1->getField(QString("Altitude"))->getDouble();
2013-04-05 22:46:56 +02:00
lat *= 1E-7;
lon *= 1E-7;
emit position(lat, lon, alt);
2013-04-05 22:46:56 +02:00
}