Skip to content
Snippets Groups Projects
WaypointList.cc 15.2 KiB
Newer Older
  • Learn to ignore specific revisions
  • pixhawk's avatar
    pixhawk committed
    /*=====================================================================
    
    PIXHAWK Micro Air Vehicle Flying Robotics Toolkit
    
    (c) 2009, 2010 PIXHAWK PROJECT  <http://pixhawk.ethz.ch>
    
    This file is part of the PIXHAWK project
    
        PIXHAWK 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.
    
        PIXHAWK 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 PIXHAWK. If not, see <http://www.gnu.org/licenses/>.
    
    ======================================================================*/
    
    /**
     * @file
     *   @brief Waypoint list widget
     *
     *   @author Lorenz Meier <mavteam@student.ethz.ch>
     *   @author Benjamin Knecht <mavteam@student.ethz.ch>
    
     *   @author Petri Tanskanen <mavteam@student.ethz.ch>
    
    pixhawk's avatar
    pixhawk committed
     *
     */
    
    #include "WaypointList.h"
    #include "ui_WaypointList.h"
    #include <UASInterface.h>
    #include <UASManager.h>
    #include <QDebug>
    #include <QFileDialog>
    
    pixhawk's avatar
    pixhawk committed
    
    WaypointList::WaypointList(QWidget *parent, UASInterface* uas) :
            QWidget(parent),
            uas(NULL),
    
            mavX(0.0),
            mavY(0.0),
            mavZ(0.0),
            mavYaw(0.0),
    
    pixhawk's avatar
    pixhawk committed
            m_ui(new Ui::WaypointList)
    {
        m_ui->setupUi(this);
    
        listLayout = new QVBoxLayout(m_ui->listWidget);
        listLayout->setSpacing(6);
        listLayout->setMargin(0);
        listLayout->setAlignment(Qt::AlignTop);
        m_ui->listWidget->setLayout(listLayout);
    
        // ADD WAYPOINT
        // Connect add action, set right button icon and connect action to this class
        connect(m_ui->addButton, SIGNAL(clicked()), m_ui->actionAddWaypoint, SIGNAL(triggered()));
        connect(m_ui->actionAddWaypoint, SIGNAL(triggered()), this, SLOT(add()));
    
    
        // ADD WAYPOINT AT CURRENT POSITION
        connect(m_ui->positionAddButton, SIGNAL(clicked()), this, SLOT(addCurrentPositonWaypoint()));
    
    
    pixhawk's avatar
    pixhawk committed
        // SEND WAYPOINTS
        connect(m_ui->transmitButton, SIGNAL(clicked()), this, SLOT(transmit()));
    
    
        // REQUEST WAYPOINTS
    
        connect(m_ui->readButton, SIGNAL(clicked()), this, SLOT(read()));
    
    pixhawk's avatar
    pixhawk committed
        // SAVE/LOAD WAYPOINTS
        connect(m_ui->saveButton, SIGNAL(clicked()), this, SLOT(saveWaypoints()));
        connect(m_ui->loadButton, SIGNAL(clicked()), this, SLOT(loadWaypoints()));
    
    
        //connect(UASManager::instance(), SIGNAL(activeUASSet(UASInterface*)), this, SLOT(setUAS(UASInterface*)));
    
    pixhawk's avatar
    pixhawk committed
    
    
    pixhawk's avatar
    pixhawk committed
        // SET UAS AFTER ALL SIGNALS/SLOTS ARE CONNECTED
        setUAS(uas);
    
    
        // STATUS LABEL
        updateStatusLabel("");
    
        loadFileGlobalWP = false;
    
        readGlobalWP = false;
    
        centerMapCoordinate.setX(0.0);
        centerMapCoordinate.setY(0.0);
    
    
    pixhawk's avatar
    pixhawk committed
    }
    
    WaypointList::~WaypointList()
    {
        delete m_ui;
    }
    
    
    void WaypointList::updatePosition(UASInterface* uas, double x, double y, double z, quint64 usec)
    
    {
        Q_UNUSED(uas);
        Q_UNUSED(usec);
        mavX = x;
        mavY = y;
        mavZ = z;
    }
    
    void WaypointList::updateAttitude(UASInterface* uas, double roll, double pitch, double yaw, quint64 usec)
    {
        Q_UNUSED(uas);
        Q_UNUSED(usec);
        Q_UNUSED(roll);
        Q_UNUSED(pitch);
        mavYaw = yaw;
    }
    
    
    pixhawk's avatar
    pixhawk committed
    void WaypointList::setUAS(UASInterface* uas)
    {
        if (this->uas == NULL && uas != NULL)
        {
            this->uas = uas;
    
    pixhawk's avatar
    pixhawk committed
    
    
            connect(uas, SIGNAL(localPositionChanged(UASInterface*,double,double,double,quint64)),  this, SLOT(updatePosition(UASInterface*,double,double,double,quint64)));
    
            connect(uas, SIGNAL(attitudeChanged(UASInterface*,double,double,double,quint64)),       this, SLOT(updateAttitude(UASInterface*,double,double,double,quint64)));
    
    pixhawk's avatar
    pixhawk committed
    
    
    pixhawk's avatar
    pixhawk committed
            connect(uas->getWaypointManager(), SIGNAL(updateStatusString(const QString &)),        this, SLOT(updateStatusLabel(const QString &)));
            connect(uas->getWaypointManager(), SIGNAL(waypointListChanged(void)),                  this, SLOT(waypointListChanged(void)));
    
            connect(uas->getWaypointManager(), SIGNAL(waypointChanged(int,Waypoint*)), this, SLOT(updateWaypoint(int,Waypoint*)));
    
    pixhawk's avatar
    pixhawk committed
            connect(uas->getWaypointManager(), SIGNAL(currentWaypointChanged(quint16)),            this, SLOT(currentWaypointChanged(quint16)));
            connect(uas->getWaypointManager(),SIGNAL(loadWPFile()),this,SLOT(setIsLoadFileWP()));
            connect(uas->getWaypointManager(),SIGNAL(readGlobalWPFromUAS(bool)),this,SLOT(setIsReadGlobalWP(bool)));
    
    pixhawk's avatar
    pixhawk committed
        }
    }
    
    
    pixhawk's avatar
    pixhawk committed
    void WaypointList::saveWaypoints()
    {
        if (uas)
        {
            QString fileName = QFileDialog::getSaveFileName(this, tr("Save File"), "./waypoints.txt", tr("Waypoint File (*.txt)"));
    
    pixhawk's avatar
    pixhawk committed
            uas->getWaypointManager()->saveWaypoints(fileName);
    
    pixhawk's avatar
    pixhawk committed
        }
    }
    
    void WaypointList::loadWaypoints()
    {
        if (uas)
        {
    
    pixhawk's avatar
    pixhawk committed
            QString fileName = QFileDialog::getOpenFileName(this, tr("Load File"), ".", tr("Waypoint File (*.txt)"));
    
    pixhawk's avatar
    pixhawk committed
            uas->getWaypointManager()->loadWaypoints(fileName);
    
    pixhawk's avatar
    pixhawk committed
    }
    
    void WaypointList::transmit()
    {
        if (uas)
        {
    
    pixhawk's avatar
    pixhawk committed
            uas->getWaypointManager()->writeWaypoints();
    
    pixhawk's avatar
    pixhawk committed
        }
    }
    
    void WaypointList::read()
    {
        if (uas)
        {
    
    pixhawk's avatar
    pixhawk committed
            uas->getWaypointManager()->readWaypoints();
    
    pixhawk's avatar
    pixhawk committed
        }
    }
    
    void WaypointList::add()
    {
        if (uas)
        {
    
    //        if(isGlobalWP)
    //        {
    
    pixhawk's avatar
    pixhawk committed
    //            const QVector<Waypoint *> &waypoints = uas->getWaypointManager()->getWaypointList();
    
    //            if (waypoints.size() > 0)
    //            {
    //                Waypoint *last = waypoints.at(waypoints.size()-1);
    //                Waypoint *wp = new Waypoint(0, centerMapCoordinate.x(), centerMapCoordinate.y(), last->getZ(), last->getYaw(), last->getAutoContinue(), false, last->getOrbit(), last->getHoldTime());
    
    pixhawk's avatar
    pixhawk committed
    //                uas->getWaypointManager()->addWaypoint(wp);
    
    //            }
    //            else
    //            {
    //                Waypoint *wp = new Waypoint(0, centerMapCoordinate.x(), centerMapCoordinate.y(), -0.8, 0.0, true, true, 0.15, 2000);
    
    pixhawk's avatar
    pixhawk committed
    //                uas->getWaypointManager()->addWaypoint(wp);
    
    //            }
    //
    //            emit createWaypointAtMap(centerMapCoordinate);
    //        }
    //        else
    
    pixhawk's avatar
    pixhawk committed
                const QVector<Waypoint *> &waypoints = uas->getWaypointManager()->getWaypointList();
    
                    // Create waypoint with last frame
    
                    Waypoint *last = waypoints.at(waypoints.size()-1);
    
                    wp = new Waypoint(0, last->getX(), last->getY(), last->getZ(), last->getYaw(), last->getAutoContinue(), false, last->getOrbit(),
    
                                                last->getHoldTime(), last->getFrame(), last->getAction());
    
    pixhawk's avatar
    pixhawk committed
                    uas->getWaypointManager()->addWaypoint(wp);
    
                        // Create global frame waypoint per default
    
                        wp = new Waypoint(0, uas->getLongitude(), uas->getLatitude(), uas->getAltitude(), 0.0, true, true, 0.15, 0, MAV_FRAME_GLOBAL, MAV_ACTION_NAVIGATE);
    
    pixhawk's avatar
    pixhawk committed
                        uas->getWaypointManager()->addWaypoint(wp);
    
    //            if (wp->getFrame() == MAV_FRAME_GLOBAL)
    //            {
    //                emit createWaypointAtMap(QPointF(wp->getX(), wp->getY()));
    //            }
    
    pixhawk's avatar
    pixhawk committed
        }
    }
    
    void WaypointList::addCurrentPositonWaypoint()
    
    pixhawk's avatar
    pixhawk committed
    {
    
        /* TODO: implement with new waypoint structure
    
    pixhawk's avatar
    pixhawk committed
        if (uas)
    
    pixhawk's avatar
    pixhawk committed
        {
    
            //if(isGlobalWP)
            //{
                //isLocalWP = false;
            //}
            //else
    
    pixhawk's avatar
    pixhawk committed
            {
    
    pixhawk's avatar
    pixhawk committed
                const QVector<Waypoint *> &waypoints = uas->getWaypointManager()->getWaypointList();
    
                if (waypoints.size() > 0)
                {
                    Waypoint *last = waypoints.at(waypoints.size()-1);
                    Waypoint *wp = new Waypoint(0, (qRound(mavX*100))/100., (qRound(mavY*100))/100., (qRound(mavZ*100))/100., (qRound(mavYaw*100))/100., last->getAutoContinue(), false, last->getOrbit(), last->getHoldTime());
    
    pixhawk's avatar
    pixhawk committed
                    uas->getWaypointManager()->addWaypoint(wp);
    
                }
                else
                {
                    Waypoint *wp = new Waypoint(0, (qRound(mavX*100))/100., (qRound(mavY*100))/100., (qRound(mavZ*100))/100., (qRound(mavYaw*100))/100., true, true, 0.15, 2000);
    
    pixhawk's avatar
    pixhawk committed
                    uas->getWaypointManager()->addWaypoint(wp);
    
                 //isLocalWP = true;
    
    pixhawk's avatar
    pixhawk committed
            }
    
    pixhawk's avatar
    pixhawk committed
        }
    
    pixhawk's avatar
    pixhawk committed
    }
    
    
    pixhawk's avatar
    pixhawk committed
    void WaypointList::updateStatusLabel(const QString &string)
    {
        m_ui->statusLabel->setText(string);
    
    pixhawk's avatar
    pixhawk committed
    }
    
    
    void WaypointList::changeCurrentWaypoint(quint16 seq)
    
    pixhawk's avatar
    pixhawk committed
    {
    
    pixhawk's avatar
    pixhawk committed
        if (uas)
    
    pixhawk's avatar
    pixhawk committed
            uas->getWaypointManager()->setCurrentWaypoint(seq);
    
    pixhawk's avatar
    pixhawk committed
    }
    
    
    void WaypointList::currentWaypointChanged(quint16 seq)
    
    pixhawk's avatar
    pixhawk committed
        if (uas)
    
    pixhawk's avatar
    pixhawk committed
            const QVector<Waypoint *> &waypoints = uas->getWaypointManager()->getWaypointList();
    
    
            if (seq < waypoints.size())
            {
                for(int i = 0; i < waypoints.size(); i++)
                {
                    WaypointView* widget = wpViews.find(waypoints[i]).value();
    
                    if (waypoints[i]->getId() == seq)
                    {
                        widget->setCurrent(true);
                    }
                    else
                    {
                        widget->setCurrent(false);
                    }
                }
            }
        }
    }
    
    
    void WaypointList::updateWaypoint(int uas, Waypoint* wp)
    {
        Q_UNUSED(uas);
        WaypointView *wpv = wpViews.value(wp);
        wpv->updateValues();
    }
    
    
    void WaypointList::waypointListChanged()
    
    pixhawk's avatar
    pixhawk committed
    {
    
    pixhawk's avatar
    pixhawk committed
        if (uas)
    
    pixhawk's avatar
    pixhawk committed
        {
    
    pixhawk's avatar
    pixhawk committed
            // Prevent updates to prevent visual flicker
            this->setUpdatesEnabled(false);
            const QVector<Waypoint *> &waypoints = uas->getWaypointManager()->getWaypointList();
    
                if (!wpViews.empty())
    
    pixhawk's avatar
    pixhawk committed
                    QMapIterator<Waypoint*,WaypointView*> viewIt(wpViews);
                    viewIt.toFront();
                    while(viewIt.hasNext())
    
    pixhawk's avatar
    pixhawk committed
                        viewIt.next();
                        Waypoint *cur = viewIt.key();
                        int i;
                        for (i = 0; i < waypoints.size(); i++)
    
    pixhawk's avatar
    pixhawk committed
                            if (waypoints[i] == cur)
    
    pixhawk's avatar
    pixhawk committed
                                break;
    
    pixhawk's avatar
    pixhawk committed
                        if (i == waypoints.size())
                        {
                            WaypointView* widget = wpViews.find(cur).value();
                            widget->hide();
                            listLayout->removeWidget(widget);
                            wpViews.remove(cur);
                        }
    
    pixhawk's avatar
    pixhawk committed
                }
    
    pixhawk's avatar
    pixhawk committed
                // then add/update the views for each waypoint in the list
                for(int i = 0; i < waypoints.size(); i++)
                {
                    Waypoint *wp = waypoints[i];
                    if (!wpViews.contains(wp))
    
    pixhawk's avatar
    pixhawk committed
                        WaypointView* wpview = new WaypointView(wp, this);
                        wpViews.insert(wp, wpview);
                        connect(wpview, SIGNAL(moveDownWaypoint(Waypoint*)),    this, SLOT(moveDown(Waypoint*)));
                        connect(wpview, SIGNAL(moveUpWaypoint(Waypoint*)),      this, SLOT(moveUp(Waypoint*)));
                        connect(wpview, SIGNAL(removeWaypoint(Waypoint*)),      this, SLOT(removeWaypoint(Waypoint*)));
                        connect(wpview, SIGNAL(currentWaypointChanged(quint16)), this, SLOT(currentWaypointChanged(quint16)));
                        connect(wpview, SIGNAL(changeCurrentWaypoint(quint16)), this, SLOT(changeCurrentWaypoint(quint16)));
                    }
    
                    WaypointView *wpv = wpViews.value(wp);
                    wpv->updateValues();    // update the values of the ui elements in the view
                    listLayout->addWidget(wpv);
    
                }
    
    pixhawk's avatar
    pixhawk committed
                        this->setUpdatesEnabled(true);
    
    pixhawk's avatar
    pixhawk committed
            }
    
    pixhawk's avatar
    pixhawk committed
            loadFileGlobalWP = false;
    
    pixhawk's avatar
    pixhawk committed
    }
    
    
    void WaypointList::moveUp(Waypoint* wp)
    
    pixhawk's avatar
    pixhawk committed
    {
    
    pixhawk's avatar
    pixhawk committed
        {
    
    pixhawk's avatar
    pixhawk committed
            const QVector<Waypoint *> &waypoints = uas->getWaypointManager()->getWaypointList();
    
    
            //get the current position of wp in the local storage
            int i;
            for (i = 0; i < waypoints.size(); i++)
    
            // if wp was found and its not the first entry, move it
            if (i < waypoints.size() && i > 0)
    
    pixhawk's avatar
    pixhawk committed
            {
    
    pixhawk's avatar
    pixhawk committed
                uas->getWaypointManager()->moveWaypoint(i, i-1);
    
    pixhawk's avatar
    pixhawk committed
            }
        }
    }
    
    
    void WaypointList::moveDown(Waypoint* wp)
    
    pixhawk's avatar
    pixhawk committed
    {
    
    pixhawk's avatar
    pixhawk committed
        {
    
    pixhawk's avatar
    pixhawk committed
            const QVector<Waypoint *> &waypoints = uas->getWaypointManager()->getWaypointList();
    
            //get the current position of wp in the local storage
            int i;
            for (i = 0; i < waypoints.size(); i++)
    
    pixhawk's avatar
    pixhawk committed
            {
    
    pixhawk's avatar
    pixhawk committed
            }
    
    
            // if wp was found and its not the last entry, move it
            if (i < waypoints.size()-1)
    
    pixhawk's avatar
    pixhawk committed
            {
    
    pixhawk's avatar
    pixhawk committed
                uas->getWaypointManager()->moveWaypoint(i, i+1);
    
    pixhawk's avatar
    pixhawk committed
            }
        }
    }
    
    void WaypointList::removeWaypoint(Waypoint* wp)
    {
    
    pixhawk's avatar
    pixhawk committed
        {
    
    pixhawk's avatar
    pixhawk committed
            uas->getWaypointManager()->removeWaypoint(wp->getId());
    
    pixhawk's avatar
    pixhawk committed
        }
    }
    
    void WaypointList::changeEvent(QEvent *e)
    {
        switch (e->type()) {
        case QEvent::LanguageChange:
            m_ui->retranslateUi(this);
            break;
        default:
            break;
        }
    }
    
    
    
    
    void WaypointList::on_clearWPListButton_clicked()
    {
    
    tecnosapiens's avatar
    tecnosapiens committed
               emit clearPathclicked();
    
    pixhawk's avatar
    pixhawk committed
              const QVector<Waypoint *> &waypoints = uas->getWaypointManager()->getWaypointList();
    
                while(!waypoints.isEmpty())//for(int i = 0; i <= waypoints.size(); i++)
                {
                    WaypointView* widget = wpViews.find(waypoints[0]).value();
                    widget->remove();
    
    tecnosapiens's avatar
    tecnosapiens committed
        else
        {
    
    /** @brief The MapWidget informs that a waypoint global was changed on the map */
    
    void WaypointList::waypointGlobalChanged(QPointF coordinate, int indexWP)
    {
        if (uas)
        {
    
    pixhawk's avatar
    pixhawk committed
            const QVector<Waypoint *> &waypoints = uas->getWaypointManager()->getWaypointList();
    
            if (waypoints.size() > 0)
            {
                Waypoint *temp = waypoints.at(indexWP);
    
                temp->setX(coordinate.x());
                temp->setY(coordinate.y());
    
    
                //WaypointGlobalView* widget = wpGlobalViews.find(waypoints[indexWP]).value();
                //widget->updateValues();
    
    ///** @brief The MapWidget informs that a waypoint global was changed on the map */
    
    //void WaypointList::waypointGlobalPositionChanged(Waypoint* wp)
    //{
    //    QPointF coordinate;
    //    coordinate.setX(wp->getX());
    //    coordinate.setY(wp->getY());
    
    //   emit ChangeWaypointGlobalPosition(wp->getId(), coordinate);
    
    
    //}
    
    
    void WaypointList::clearWPWidget()
    
    pixhawk's avatar
    pixhawk committed
        const QVector<Waypoint *> &waypoints = uas->getWaypointManager()->getWaypointList();
    
          while(!waypoints.isEmpty())//for(int i = 0; i <= waypoints.size(); i++)
          {
              WaypointView* widget = wpViews.find(waypoints[0]).value();
              widget->remove();
          }
      }
    
        //emit changePositionWPBySpinBox(wp->getId(), wp->getY(), wp->getX());
    
    
    void WaypointList::setIsLoadFileWP()
    {
        loadFileGlobalWP = true;
    }
    
    
    void WaypointList::setIsReadGlobalWP(bool value)
    {
    
    pixhawk's avatar
    pixhawk committed
        // FIXME James Check this
        Q_UNUSED(value);
        // readGlobalWP = value;