/** ****************************************************************************** * * @file pathcompiler.h * @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2012. * @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 */ #ifndef PATHCOMPILER_H #define PATHCOMPILER_H #include #include #include #include // TODO: Make this a singleton class and separate from map library. Not sure of the proper design pattern in Qt. // factory? static variables? /** * This class is a two way adapter between a visualization of a path and the * UAVObject representation on the flight controller. It also can support multiple * ways of converting a path from what the user clicked to the underlying representation * to achieve the desired end flight trajectory */ class PathCompiler : public QObject { Q_OBJECT public: explicit PathCompiler(QObject *parent = 0); //! This method opens a dialog (if filename is null) and saves the path int savePath(QString filename = NULL); //! This method opens a dialog (if filename is null) and loads the path int loadPath(QString filename = NULL); //! Waypoint representation that is exchanged between visualization struct waypoint { double latitude; double longitude; }; private: //! Helper method to get uavobject manager UAVObjectManager * getObjectManager(); //! Convert a UAVO waypoint to the local structure struct PathCompiler::waypoint UavoToInternal(Waypoint::DataFields); //! Convert a UAVO waypoint to the local structure Waypoint::DataFields InternalToUavo(struct waypoint); signals: /** * Indicates something changed the waypoints and the map should * update the display */ void visualizationChanged(QList); public slots: /** * These are slots that the visualization can call to manipulate the path. * It is an important design detail that the visualiation _not_ attempt to maintain * the list of waypoints itself. This starts the slippery of moving the path logic * into the view. */ /** * add a waypoint * @param waypoint the new waypoint to add * @param position which position to insert it to, defaults to end */ void doAddWaypoint(struct PathCompiler::waypoint, int position = -1); /** * Delete a waypoint * @param index which waypoint to delete */ void doDelWaypoint(int index); public slots: /** * These are slots that the UAV can call to update the path. */ /** * When the UAV waypoints change trigger the pathcompiler to * get the latest version and then update the visualization */ void doUpdateFromUAV(); }; #endif // PATHCOMPILER_H