2012-06-25 19:41:59 +01:00
|
|
|
/**
|
|
|
|
******************************************************************************
|
|
|
|
*
|
|
|
|
* @file modeluavproxy.cpp
|
2012-08-20 16:10:17 +01:00
|
|
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2012.
|
2012-06-25 19:41:59 +01:00
|
|
|
* @addtogroup GCSPlugins GCS Plugins
|
|
|
|
* @{
|
|
|
|
* @addtogroup OPMapPlugin OpenPilot Map Plugin
|
|
|
|
* @{
|
|
|
|
* @brief The OpenPilot Map plugin
|
|
|
|
*****************************************************************************/
|
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
*/
|
2012-06-17 20:09:21 +01:00
|
|
|
#include "modeluavoproxy.h"
|
2012-06-20 15:00:15 +01:00
|
|
|
#include "extensionsystem/pluginmanager.h"
|
2014-01-09 00:09:51 +01:00
|
|
|
|
2012-06-24 20:04:13 +01:00
|
|
|
#include <math.h>
|
2013-11-19 22:03:03 +01:00
|
|
|
|
|
|
|
ModelUavoProxy::ModelUavoProxy(QObject *parent, flightDataModel *model) : QObject(parent), myModel(model)
|
2012-06-20 15:00:15 +01:00
|
|
|
{
|
|
|
|
ExtensionSystem::PluginManager *pm = ExtensionSystem::PluginManager::instance();
|
|
|
|
Q_ASSERT(pm != NULL);
|
2013-12-01 19:38:23 +01:00
|
|
|
|
2014-01-09 00:09:51 +01:00
|
|
|
objMngr = pm->getObject<UAVObjectManager>();
|
|
|
|
Q_ASSERT(objMngr != NULL);
|
2014-01-12 19:42:12 +01:00
|
|
|
|
|
|
|
completionCountdown = 0;
|
|
|
|
successCountdown = 0;
|
2013-12-01 19:38:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void ModelUavoProxy::sendFlightPlan()
|
|
|
|
{
|
|
|
|
modelToObjects();
|
|
|
|
|
2014-01-12 15:20:22 +01:00
|
|
|
FlightPlan *flightPlan = FlightPlan::GetInstance(objMngr, 0);
|
2014-01-12 19:42:12 +01:00
|
|
|
connect(flightPlan, SIGNAL(transactionCompleted(UAVObject *, bool)),
|
|
|
|
this, SLOT(flightPlanElementSent(UAVObject *, bool)), Qt::UniqueConnection);
|
2014-01-09 00:09:51 +01:00
|
|
|
|
|
|
|
Waypoint *waypoint = Waypoint::GetInstance(objMngr, 0);
|
2014-01-12 19:42:12 +01:00
|
|
|
connect(waypoint, SIGNAL(transactionCompleted(UAVObject *, bool)),
|
|
|
|
this, SLOT(flightPlanElementSent(UAVObject *, bool)), Qt::UniqueConnection);
|
2013-12-01 19:38:23 +01:00
|
|
|
|
2014-01-09 00:09:51 +01:00
|
|
|
PathAction *action = PathAction::GetInstance(objMngr, 0);
|
2014-01-12 19:42:12 +01:00
|
|
|
connect(action, SIGNAL(transactionCompleted(UAVObject *, bool)),
|
|
|
|
this, SLOT(flightPlanElementSent(UAVObject *, bool)), Qt::UniqueConnection);
|
2013-12-01 19:38:23 +01:00
|
|
|
|
2014-01-12 19:42:12 +01:00
|
|
|
// we will start 3 update all
|
|
|
|
completionCountdown = 3;
|
|
|
|
successCountdown = completionCountdown;
|
2013-12-01 19:38:23 +01:00
|
|
|
|
2014-01-09 00:09:51 +01:00
|
|
|
flightPlan->updated();
|
2013-12-01 19:38:23 +01:00
|
|
|
waypoint->updatedAll();
|
|
|
|
action->updatedAll();
|
|
|
|
}
|
|
|
|
|
2014-01-09 00:09:51 +01:00
|
|
|
void ModelUavoProxy::flightPlanElementSent(UAVObject *obj, bool success)
|
2013-12-01 19:38:23 +01:00
|
|
|
{
|
|
|
|
obj->disconnect(this);
|
|
|
|
|
2014-01-12 19:42:12 +01:00
|
|
|
completionCountdown--;
|
|
|
|
successCountdown -= success ? 1 : 0;
|
2013-12-01 19:38:23 +01:00
|
|
|
|
2014-01-12 19:42:12 +01:00
|
|
|
if (completionCountdown == 0) {
|
|
|
|
qDebug() << "ModelUavoProxy::flightPlanSent - completed" << (successCountdown == 0);
|
|
|
|
if (successCountdown == 0) {
|
2013-12-11 23:13:32 +01:00
|
|
|
QMessageBox::information(NULL, tr("Flight Plan Upload Successful"), tr("Flight plan upload was successful."));
|
2013-12-01 19:38:23 +01:00
|
|
|
}
|
|
|
|
else {
|
2014-01-12 19:42:12 +01:00
|
|
|
QMessageBox::critical(NULL, tr("Flight Plan Upload Failed"), tr("Failed to upload the flight plan !"));
|
2013-12-01 19:38:23 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void ModelUavoProxy::receiveFlightPlan()
|
|
|
|
{
|
2014-01-12 15:20:22 +01:00
|
|
|
FlightPlan *flightPlan = FlightPlan::GetInstance(objMngr, 0);
|
2014-01-09 00:09:51 +01:00
|
|
|
connect(flightPlan, SIGNAL(transactionCompleted(UAVObject *, bool)), this, SLOT(flightPlanElementReceived(UAVObject *, bool)));
|
2013-12-01 19:38:23 +01:00
|
|
|
|
2014-01-09 00:09:51 +01:00
|
|
|
Waypoint *waypoint = Waypoint::GetInstance(objMngr, 0);
|
|
|
|
connect(waypoint, SIGNAL(transactionCompleted(UAVObject *, bool)), this, SLOT(flightPlanElementReceived(UAVObject *, bool)));
|
|
|
|
|
|
|
|
PathAction *action = PathAction::GetInstance(objMngr, 0);
|
|
|
|
connect(action, SIGNAL(transactionCompleted(UAVObject *, bool)), this, SLOT(flightPlanElementReceived(UAVObject *, bool)));
|
2013-12-01 19:38:23 +01:00
|
|
|
|
2014-01-12 19:42:12 +01:00
|
|
|
// we will start 3 update requests
|
|
|
|
completionCountdown = 3;
|
|
|
|
successCountdown = completionCountdown;
|
2013-12-01 19:38:23 +01:00
|
|
|
|
2014-01-09 00:09:51 +01:00
|
|
|
flightPlan->requestUpdate();
|
2013-12-01 19:38:23 +01:00
|
|
|
waypoint->requestUpdateAll();
|
|
|
|
action->requestUpdateAll();
|
|
|
|
}
|
|
|
|
|
2014-01-09 00:09:51 +01:00
|
|
|
void ModelUavoProxy::flightPlanElementReceived(UAVObject *obj, bool success)
|
2013-12-01 19:38:23 +01:00
|
|
|
{
|
|
|
|
obj->disconnect(this);
|
|
|
|
|
2014-01-12 19:42:12 +01:00
|
|
|
completionCountdown--;
|
|
|
|
successCountdown -= success ? 1 : 0;
|
2013-12-01 19:38:23 +01:00
|
|
|
|
2014-01-12 19:42:12 +01:00
|
|
|
if (completionCountdown == 0) {
|
|
|
|
qDebug() << "ModelUavoProxy::flightPlanReceived - completed" << (successCountdown == 0);
|
|
|
|
if (successCountdown == 0) {
|
|
|
|
if (objectsToModel()) {
|
|
|
|
QMessageBox::information(NULL, tr("Flight Plan Download Successful"), tr("Flight plan download was successful."));
|
|
|
|
}
|
2013-12-01 19:38:23 +01:00
|
|
|
}
|
|
|
|
else {
|
2014-01-12 19:42:12 +01:00
|
|
|
QMessageBox::critical(NULL, tr("Flight Plan Download Failed"), tr("Failed to download the flight plan !"));
|
2013-12-01 19:38:23 +01:00
|
|
|
}
|
|
|
|
}
|
2012-06-20 15:00:15 +01:00
|
|
|
}
|
2013-11-19 22:03:03 +01:00
|
|
|
|
2014-01-09 00:09:51 +01:00
|
|
|
// update waypoint and path actions UAV objects
|
|
|
|
//
|
|
|
|
// waypoints are unique and each waypoint has an entry in the UAV waypoint list
|
|
|
|
//
|
|
|
|
// a path action can be referenced by multiple waypoints
|
|
|
|
// waypoints reference path action by their index in the UAV path action list
|
|
|
|
// the compression of path actions happens here.
|
|
|
|
// (compression consists in keeping only one instance of similar path actions)
|
|
|
|
//
|
|
|
|
// the UAV waypoint list and path action list are probably not empty, so we try to reuse existing instances
|
2014-01-12 19:42:12 +01:00
|
|
|
bool ModelUavoProxy::modelToObjects()
|
2012-06-20 15:00:15 +01:00
|
|
|
{
|
2013-11-19 22:03:03 +01:00
|
|
|
qDebug() << "ModelUAVProxy::modelToObjects";
|
|
|
|
|
|
|
|
// track number of path actions
|
|
|
|
int actionCount = 0;
|
|
|
|
|
|
|
|
// iterate over waypoints
|
2014-01-09 00:09:51 +01:00
|
|
|
int waypointCount = myModel->rowCount();
|
|
|
|
for (int i = 0; i < waypointCount; ++i) {
|
2013-11-19 22:03:03 +01:00
|
|
|
|
|
|
|
// Path Actions
|
|
|
|
|
|
|
|
// create action to use as a search criteria
|
|
|
|
// this object does not need to be deleted as it will either be added to the managed list or deleted later
|
|
|
|
PathAction *action = new PathAction;
|
|
|
|
|
|
|
|
// get model data
|
|
|
|
PathAction::DataFields actionData = action->getData();
|
|
|
|
modelToPathAction(i, actionData);
|
|
|
|
|
|
|
|
// see if that path action has already been added in this run
|
|
|
|
PathAction *foundAction = findPathAction(actionData, actionCount);
|
|
|
|
// TODO this test needs a consistency check as it is unsafe.
|
|
|
|
// if the find method is buggy and returns false positives then the flight plan sent to the uav is broken!
|
|
|
|
// the find method should do a "binary" compare instead of a field by field compare
|
|
|
|
// if a field is added everywhere and not in the compare method then you can start having false positives
|
|
|
|
if (!foundAction) {
|
|
|
|
// create or reuse an action instance
|
|
|
|
action = createPathAction(actionCount, action);
|
|
|
|
actionCount++;
|
|
|
|
|
2013-12-01 19:38:23 +01:00
|
|
|
// update UAVObject
|
2013-11-19 22:03:03 +01:00
|
|
|
action->setData(actionData);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
action->deleteLater();
|
|
|
|
action = foundAction;
|
|
|
|
qDebug() << "ModelUAVProxy::modelToObjects - found action instance :" << action->getInstID();
|
2012-06-24 20:04:13 +01:00
|
|
|
}
|
2013-05-19 17:37:30 +03:00
|
|
|
|
2013-11-19 22:03:03 +01:00
|
|
|
// Waypoints
|
2012-06-20 15:00:15 +01:00
|
|
|
|
2013-11-19 22:03:03 +01:00
|
|
|
// create or reuse a waypoint instance
|
|
|
|
Waypoint *waypoint = createWaypoint(i, NULL);
|
|
|
|
Q_ASSERT(waypoint);
|
2013-05-19 17:37:30 +03:00
|
|
|
|
2013-11-19 22:03:03 +01:00
|
|
|
// get model data
|
|
|
|
Waypoint::DataFields waypointData = waypoint->getData();
|
|
|
|
modelToWaypoint(i, waypointData);
|
2013-05-19 17:37:30 +03:00
|
|
|
|
2013-11-19 22:03:03 +01:00
|
|
|
// connect waypoint to path action
|
|
|
|
waypointData.Action = action->getInstID();
|
|
|
|
|
2013-12-01 19:38:23 +01:00
|
|
|
// update UAVObject
|
2013-11-19 22:03:03 +01:00
|
|
|
waypoint->setData(waypointData);
|
|
|
|
}
|
2014-01-12 19:42:12 +01:00
|
|
|
|
|
|
|
// Put "safe" values in unused waypoint and path action objects
|
2014-01-09 00:09:51 +01:00
|
|
|
if (waypointCount < objMngr->getNumInstances(Waypoint::OBJID)) {
|
|
|
|
for (int i = waypointCount; i < objMngr->getNumInstances(Waypoint::OBJID); ++i) {
|
|
|
|
// TODO
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (actionCount < objMngr->getNumInstances(PathAction::OBJID)) {
|
|
|
|
for (int i = actionCount; i < objMngr->getNumInstances(PathAction::OBJID); ++i) {
|
|
|
|
// TODO
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-01-12 15:20:22 +01:00
|
|
|
// Update FlightPlan
|
|
|
|
FlightPlan *flightPlan = FlightPlan::GetInstance(objMngr);
|
|
|
|
FlightPlan::DataFields flightPlanData = flightPlan->getData();
|
2014-01-09 00:09:51 +01:00
|
|
|
|
|
|
|
flightPlanData.WaypointCount = waypointCount;
|
|
|
|
flightPlanData.PathActionCount = actionCount;
|
2014-01-12 19:42:12 +01:00
|
|
|
flightPlanData.Crc = computeFlightPlanCrc(waypointCount, actionCount);
|
2014-01-09 00:09:51 +01:00
|
|
|
|
|
|
|
flightPlan->setData(flightPlanData);
|
2014-01-12 19:42:12 +01:00
|
|
|
|
|
|
|
return true;
|
2013-11-19 22:03:03 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
Waypoint *ModelUavoProxy::createWaypoint(int index, Waypoint *newWaypoint) {
|
|
|
|
Waypoint *waypoint = NULL;
|
2014-01-09 00:09:51 +01:00
|
|
|
int count = objMngr->getNumInstances(Waypoint::OBJID);
|
2013-11-19 22:03:03 +01:00
|
|
|
if (index < count) {
|
|
|
|
// reuse object
|
|
|
|
qDebug() << "ModelUAVProxy::createWaypoint - reused waypoint instance :" << index << "/" << count;
|
2014-01-09 00:09:51 +01:00
|
|
|
waypoint = Waypoint::GetInstance(objMngr, index);
|
2013-11-19 22:03:03 +01:00
|
|
|
if (newWaypoint) {
|
|
|
|
newWaypoint->deleteLater();
|
|
|
|
}
|
|
|
|
} else if (index < count + 1) {
|
|
|
|
// create "next" object
|
|
|
|
qDebug() << "ModelUAVProxy::createWaypoint - created waypoint instance :" << index;
|
|
|
|
// TODO is there a limit to the number of wp?
|
|
|
|
waypoint = newWaypoint ? newWaypoint : new Waypoint;
|
|
|
|
waypoint->initialize(index, waypoint->getMetaObject());
|
2014-01-09 00:09:51 +01:00
|
|
|
objMngr->registerObject(waypoint);
|
2013-11-19 22:03:03 +01:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
// we can only create the "next" object
|
|
|
|
// TODO fail in a clean way :(
|
|
|
|
}
|
|
|
|
return waypoint;
|
|
|
|
}
|
|
|
|
|
|
|
|
PathAction *ModelUavoProxy::createPathAction(int index, PathAction *newAction) {
|
|
|
|
PathAction *action = NULL;
|
2014-01-09 00:09:51 +01:00
|
|
|
int count = objMngr->getNumInstances(PathAction::OBJID);
|
2013-11-19 22:03:03 +01:00
|
|
|
if (index < count) {
|
|
|
|
// reuse object
|
|
|
|
qDebug() << "ModelUAVProxy::createPathAction - reused action instance :" << index << "/" << count;
|
2014-01-09 00:09:51 +01:00
|
|
|
action = PathAction::GetInstance(objMngr, index);
|
2013-11-19 22:03:03 +01:00
|
|
|
if (newAction) {
|
|
|
|
newAction->deleteLater();
|
|
|
|
}
|
|
|
|
} else if (index < count + 1) {
|
|
|
|
// create "next" object
|
|
|
|
qDebug() << "ModelUAVProxy::createPathAction - created action instance :" << index;
|
|
|
|
// TODO is there a limit to the number of path actions?
|
|
|
|
action = newAction ? newAction : new PathAction;
|
|
|
|
action->initialize(index, action->getMetaObject());
|
2014-01-09 00:09:51 +01:00
|
|
|
objMngr->registerObject(action);
|
2013-11-19 22:03:03 +01:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
// we can only create the "next" object
|
|
|
|
// TODO fail in a clean way :(
|
|
|
|
}
|
|
|
|
return action;
|
|
|
|
}
|
2013-05-19 17:37:30 +03:00
|
|
|
|
2013-11-20 22:25:19 +01:00
|
|
|
PathAction *ModelUavoProxy::findPathAction(const PathAction::DataFields &actionData, int actionCount) {
|
2014-01-09 00:09:51 +01:00
|
|
|
int instancesCount = objMngr->getNumInstances(PathAction::OBJID);
|
2013-11-19 22:03:03 +01:00
|
|
|
int count = actionCount <= instancesCount ? actionCount : instancesCount;
|
|
|
|
for (int i = 0; i < count; ++i) {
|
2014-01-09 00:09:51 +01:00
|
|
|
PathAction *action = PathAction::GetInstance(objMngr, i);
|
2013-11-19 22:03:03 +01:00
|
|
|
Q_ASSERT(action);
|
|
|
|
if (!action) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
PathAction::DataFields fields = action->getData();
|
|
|
|
if (fields.Command == actionData.Command
|
|
|
|
&& fields.ConditionParameters[0] == actionData.ConditionParameters[0]
|
|
|
|
&& fields.ConditionParameters[1] == actionData.ConditionParameters[1]
|
|
|
|
&& fields.ConditionParameters[2] == actionData.ConditionParameters[2]
|
|
|
|
&& fields.EndCondition == actionData.EndCondition
|
|
|
|
&& fields.ErrorDestination == actionData.ErrorDestination
|
|
|
|
&& fields.JumpDestination == actionData.JumpDestination && fields.Mode == actionData.Mode
|
|
|
|
&& fields.ModeParameters[0] == actionData.ModeParameters[0]
|
|
|
|
&& fields.ModeParameters[1] == actionData.ModeParameters[1]
|
|
|
|
&& fields.ModeParameters[2] == actionData.ModeParameters[2]) {
|
|
|
|
return action;
|
2013-05-19 17:37:30 +03:00
|
|
|
}
|
2012-06-20 15:00:15 +01:00
|
|
|
}
|
2013-11-19 22:03:03 +01:00
|
|
|
return NULL;
|
2012-06-20 15:00:15 +01:00
|
|
|
}
|
|
|
|
|
2014-01-12 19:42:12 +01:00
|
|
|
bool ModelUavoProxy::objectsToModel()
|
2012-06-17 20:09:21 +01:00
|
|
|
{
|
2013-12-11 23:13:32 +01:00
|
|
|
// build model from uav objects
|
|
|
|
// the list of objects can end with "garbage" instances due to previous flightpath
|
|
|
|
// they need to be ignored
|
|
|
|
|
2014-01-12 15:20:22 +01:00
|
|
|
FlightPlan *flightPlan = FlightPlan::GetInstance(objMngr);
|
|
|
|
FlightPlan::DataFields flightPlanData = flightPlan->getData();
|
2014-01-09 00:09:51 +01:00
|
|
|
|
|
|
|
int waypointCount = flightPlanData.WaypointCount;
|
2014-01-12 19:42:12 +01:00
|
|
|
int actionCount = flightPlanData.PathActionCount;
|
2014-01-09 00:09:51 +01:00
|
|
|
|
2014-01-12 19:42:12 +01:00
|
|
|
// consistency check
|
|
|
|
if (waypointCount > objMngr->getNumInstances(Waypoint::OBJID)) {
|
|
|
|
QMessageBox::critical(NULL, tr("Flight Plan Download Failed"), tr("Flight plan way point count error !"));
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (actionCount > objMngr->getNumInstances(PathAction::OBJID)) {
|
|
|
|
QMessageBox::critical(NULL, tr("Flight Plan Download Failed"), tr("Flight plan path action count error !"));
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (flightPlanData.Crc != computeFlightPlanCrc(waypointCount, actionCount)) {
|
|
|
|
QMessageBox::critical(NULL, tr("Flight Plan Upload Failed"), tr("Flight plan CRC error !"));
|
|
|
|
return false;
|
|
|
|
}
|
2013-12-01 19:38:23 +01:00
|
|
|
|
|
|
|
int rowCount = myModel->rowCount();
|
2014-01-09 00:09:51 +01:00
|
|
|
if (waypointCount < rowCount) {
|
|
|
|
myModel->removeRows(waypointCount, rowCount - waypointCount);
|
2013-12-01 19:38:23 +01:00
|
|
|
}
|
2014-01-09 00:09:51 +01:00
|
|
|
else if (waypointCount > rowCount) {
|
|
|
|
myModel->insertRows(rowCount, waypointCount - rowCount);
|
2013-12-01 19:38:23 +01:00
|
|
|
}
|
2013-11-20 22:25:19 +01:00
|
|
|
|
2014-01-09 00:09:51 +01:00
|
|
|
for (int i = 0; i < waypointCount; ++i) {
|
|
|
|
Waypoint *waypoint = Waypoint::GetInstance(objMngr, i);
|
2013-11-20 22:25:19 +01:00
|
|
|
Q_ASSERT(waypoint);
|
|
|
|
if (!waypoint) {
|
2012-06-24 20:04:13 +01:00
|
|
|
continue;
|
2013-05-19 17:37:30 +03:00
|
|
|
}
|
2013-11-20 22:25:19 +01:00
|
|
|
|
|
|
|
Waypoint::DataFields waypointData = waypoint->getData();
|
|
|
|
waypointToModel(i, waypointData);
|
|
|
|
|
2014-01-09 00:09:51 +01:00
|
|
|
PathAction *action = PathAction::GetInstance(objMngr, waypoint->getAction());
|
2012-06-24 20:04:13 +01:00
|
|
|
Q_ASSERT(action);
|
2013-05-19 17:37:30 +03:00
|
|
|
if (!action) {
|
2012-06-24 20:04:13 +01:00
|
|
|
continue;
|
2013-05-19 17:37:30 +03:00
|
|
|
}
|
2013-11-20 22:25:19 +01:00
|
|
|
|
|
|
|
PathAction::DataFields actionData = action->getData();
|
|
|
|
pathActionToModel(i, actionData);
|
2012-06-24 20:04:13 +01:00
|
|
|
}
|
2014-01-12 19:42:12 +01:00
|
|
|
return true;
|
2012-06-24 20:04:13 +01:00
|
|
|
}
|
2013-05-19 17:37:30 +03:00
|
|
|
|
2013-11-20 22:25:19 +01:00
|
|
|
void ModelUavoProxy::modelToWaypoint(int i, Waypoint::DataFields &data) {
|
|
|
|
double distance, bearing, altitude, velocity;
|
|
|
|
|
|
|
|
QModelIndex index = myModel->index(i, flightDataModel::DISRELATIVE);
|
|
|
|
distance = myModel->data(index).toDouble();
|
|
|
|
index = myModel->index(i, flightDataModel::BEARELATIVE);
|
|
|
|
bearing = myModel->data(index).toDouble();
|
|
|
|
index = myModel->index(i, flightDataModel::ALTITUDERELATIVE);
|
|
|
|
altitude = myModel->data(index).toFloat();
|
|
|
|
index = myModel->index(i, flightDataModel::VELOCITY);
|
|
|
|
velocity = myModel->data(index).toFloat();
|
|
|
|
|
2013-12-01 19:38:23 +01:00
|
|
|
data.Position[Waypoint::POSITION_NORTH] = distance * cos(bearing / 180 * M_PI);
|
|
|
|
data.Position[Waypoint::POSITION_EAST] = distance * sin(bearing / 180 * M_PI);
|
2013-11-20 22:25:19 +01:00
|
|
|
data.Position[Waypoint::POSITION_DOWN] = -altitude;
|
|
|
|
data.Velocity = velocity;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ModelUavoProxy::waypointToModel(int i, Waypoint::DataFields &data) {
|
|
|
|
|
|
|
|
double distance = sqrt(data.Position[Waypoint::POSITION_NORTH] * data.Position[Waypoint::POSITION_NORTH] +
|
|
|
|
data.Position[Waypoint::POSITION_EAST] * data.Position[Waypoint::POSITION_EAST]);
|
|
|
|
|
2013-12-01 19:38:23 +01:00
|
|
|
double bearing = atan2(data.Position[Waypoint::POSITION_EAST], data.Position[Waypoint::POSITION_NORTH]) * 180 / M_PI;
|
2013-11-20 22:25:19 +01:00
|
|
|
if (bearing != bearing) {
|
|
|
|
bearing = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
double altitude = -data.Position[Waypoint::POSITION_DOWN];
|
|
|
|
|
|
|
|
QModelIndex index = myModel->index(i, flightDataModel::VELOCITY);
|
|
|
|
myModel->setData(index, data.Velocity);
|
|
|
|
index = myModel->index(i, flightDataModel::DISRELATIVE);
|
|
|
|
myModel->setData(index, distance);
|
|
|
|
index = myModel->index(i, flightDataModel::BEARELATIVE);
|
|
|
|
myModel->setData(index, bearing);
|
|
|
|
index = myModel->index(i, flightDataModel::ALTITUDERELATIVE);
|
|
|
|
myModel->setData(index, altitude);
|
|
|
|
}
|
|
|
|
|
2013-11-19 22:03:03 +01:00
|
|
|
void ModelUavoProxy::modelToPathAction(int i, PathAction::DataFields &data) {
|
|
|
|
QModelIndex index = myModel->index(i, flightDataModel::MODE);
|
|
|
|
data.Mode = myModel->data(index).toInt();
|
|
|
|
index = myModel->index(i, flightDataModel::MODE_PARAMS0);
|
|
|
|
data.ModeParameters[0] = myModel->data(index).toFloat();
|
|
|
|
index = myModel->index(i, flightDataModel::MODE_PARAMS1);
|
|
|
|
data.ModeParameters[1] = myModel->data(index).toFloat();
|
|
|
|
index = myModel->index(i, flightDataModel::MODE_PARAMS2);
|
|
|
|
data.ModeParameters[2] = myModel->data(index).toFloat();
|
|
|
|
index = myModel->index(i, flightDataModel::MODE_PARAMS3);
|
|
|
|
data.ModeParameters[3] = myModel->data(index).toFloat();
|
|
|
|
index = myModel->index(i, flightDataModel::CONDITION);
|
|
|
|
data.EndCondition = myModel->data(index).toInt();
|
|
|
|
index = myModel->index(i, flightDataModel::CONDITION_PARAMS0);
|
|
|
|
data.ConditionParameters[0] = myModel->data(index).toFloat();
|
|
|
|
index = myModel->index(i, flightDataModel::CONDITION_PARAMS1);
|
|
|
|
data.ConditionParameters[1] = myModel->data(index).toFloat();
|
|
|
|
index = myModel->index(i, flightDataModel::CONDITION_PARAMS2);
|
|
|
|
data.ConditionParameters[2] = myModel->data(index).toFloat();
|
|
|
|
index = myModel->index(i, flightDataModel::CONDITION_PARAMS3);
|
|
|
|
data.ConditionParameters[3] = myModel->data(index).toFloat();
|
|
|
|
index = myModel->index(i, flightDataModel::COMMAND);
|
|
|
|
data.Command = myModel->data(index).toInt();
|
|
|
|
index = myModel->index(i, flightDataModel::JUMPDESTINATION);
|
|
|
|
data.JumpDestination = myModel->data(index).toInt() - 1;
|
|
|
|
index = myModel->index(i, flightDataModel::ERRORDESTINATION);
|
|
|
|
data.ErrorDestination = myModel->data(index).toInt() - 1;
|
2012-06-17 20:09:21 +01:00
|
|
|
}
|
2013-11-19 22:03:03 +01:00
|
|
|
|
2013-11-20 22:25:19 +01:00
|
|
|
void ModelUavoProxy::pathActionToModel(int i, PathAction::DataFields &data) {
|
|
|
|
QModelIndex index = myModel->index(i, flightDataModel::ISRELATIVE);
|
|
|
|
myModel->setData(index, true);
|
2013-11-19 22:03:03 +01:00
|
|
|
|
2013-11-20 22:25:19 +01:00
|
|
|
index = myModel->index(i, flightDataModel::COMMAND);
|
|
|
|
myModel->setData(index, data.Command);
|
2013-11-19 22:03:03 +01:00
|
|
|
|
2013-11-20 22:25:19 +01:00
|
|
|
index = myModel->index(i, flightDataModel::CONDITION_PARAMS0);
|
|
|
|
myModel->setData(index, data.ConditionParameters[0]);
|
|
|
|
index = myModel->index(i, flightDataModel::CONDITION_PARAMS1);
|
|
|
|
myModel->setData(index, data.ConditionParameters[1]);
|
|
|
|
index = myModel->index(i, flightDataModel::CONDITION_PARAMS2);
|
|
|
|
myModel->setData(index, data.ConditionParameters[2]);
|
|
|
|
index = myModel->index(i, flightDataModel::CONDITION_PARAMS3);
|
|
|
|
myModel->setData(index, data.ConditionParameters[3]);
|
|
|
|
|
|
|
|
index = myModel->index(i, flightDataModel::CONDITION);
|
|
|
|
myModel->setData(index, data.EndCondition);
|
|
|
|
|
|
|
|
index = myModel->index(i, flightDataModel::ERRORDESTINATION);
|
|
|
|
myModel->setData(index, data.ErrorDestination + 1);
|
2013-11-19 22:03:03 +01:00
|
|
|
|
2013-11-20 22:25:19 +01:00
|
|
|
index = myModel->index(i, flightDataModel::JUMPDESTINATION);
|
|
|
|
myModel->setData(index, data.JumpDestination + 1);
|
|
|
|
|
|
|
|
index = myModel->index(i, flightDataModel::MODE);
|
|
|
|
myModel->setData(index, data.Mode);
|
|
|
|
|
|
|
|
index = myModel->index(i, flightDataModel::MODE_PARAMS0);
|
|
|
|
myModel->setData(index, data.ModeParameters[0]);
|
|
|
|
index = myModel->index(i, flightDataModel::MODE_PARAMS1);
|
|
|
|
myModel->setData(index, data.ModeParameters[1]);
|
|
|
|
index = myModel->index(i, flightDataModel::MODE_PARAMS2);
|
|
|
|
myModel->setData(index, data.ModeParameters[2]);
|
|
|
|
index = myModel->index(i, flightDataModel::MODE_PARAMS3);
|
|
|
|
myModel->setData(index, data.ModeParameters[3]);
|
|
|
|
}
|
2014-01-12 19:42:12 +01:00
|
|
|
|
|
|
|
quint8 ModelUavoProxy::computeFlightPlanCrc(int waypointCount, int actionCount) {
|
|
|
|
quint8 crc = 0;
|
|
|
|
for (int i = 0; i < waypointCount; ++i) {
|
|
|
|
Waypoint* waypoint = Waypoint::GetInstance(objMngr, i);
|
|
|
|
crc = waypoint->updateCRC(crc);
|
|
|
|
}
|
|
|
|
for (int i = 0; i < actionCount; ++i) {
|
|
|
|
PathAction* action = PathAction::GetInstance(objMngr, i);
|
|
|
|
crc = action->updateCRC(crc);
|
|
|
|
}
|
|
|
|
return crc;
|
|
|
|
}
|
|
|
|
|