WaypointList.cc 11.8 KB
Newer Older
pixhawk's avatar
pixhawk committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
/*=====================================================================

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>
30
 *   @author Petri Tanskanen <mavteam@student.ethz.ch>
pixhawk's avatar
pixhawk committed
31 32 33 34 35 36 37 38 39 40 41 42 43
 *
 */

#include "WaypointList.h"
#include "ui_WaypointList.h"
#include <UASInterface.h>
#include <UASManager.h>
#include <QDebug>
#include <QFileDialog>

WaypointList::WaypointList(QWidget *parent, UASInterface* uas) :
        QWidget(parent),
        uas(NULL),
44 45 46 47
        mavX(0.0),
        mavY(0.0),
        mavZ(0.0),
        mavYaw(0.0),
pixhawk's avatar
pixhawk committed
48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
        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);

    this->uas = NULL;

    // 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()));

65 66 67
    // ADD WAYPOINT AT CURRENT POSITION
    connect(m_ui->positionAddButton, SIGNAL(clicked()), this, SLOT(addCurrentPositonWaypoint()));

pixhawk's avatar
pixhawk committed
68 69 70
    // SEND WAYPOINTS
    connect(m_ui->transmitButton, SIGNAL(clicked()), this, SLOT(transmit()));

71
    // REQUEST WAYPOINTS
72
    connect(m_ui->readButton, SIGNAL(clicked()), this, SLOT(read()));
73

pixhawk's avatar
pixhawk committed
74 75 76 77 78 79
    // 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*)));

80 81


pixhawk's avatar
pixhawk committed
82 83
    // SET UAS AFTER ALL SIGNALS/SLOTS ARE CONNECTED
    setUAS(uas);
84 85 86

    // STATUS LABEL
    updateStatusLabel("");
87 88

    this->setVisible(false);
pixhawk's avatar
pixhawk committed
89 90 91 92 93 94 95
}

WaypointList::~WaypointList()
{
    delete m_ui;
}

96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
void WaypointList::updateLocalPosition(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
114 115 116 117 118
void WaypointList::setUAS(UASInterface* uas)
{
    if (this->uas == NULL && uas != NULL)
    {
        this->uas = uas;
pixhawk's avatar
pixhawk committed
119

120 121
        connect(uas, SIGNAL(localPositionChanged(UASInterface*,double,double,double,quint64)),  this, SLOT(updateLocalPosition(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
122

123 124 125
        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(currentWaypointChanged(quint16)),            this, SLOT(currentWaypointChanged(quint16)));
pixhawk's avatar
pixhawk committed
126 127 128
    }
}

pixhawk's avatar
pixhawk committed
129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182
void WaypointList::saveWaypoints()
{
    if (uas)
    {
        QString fileName = QFileDialog::getSaveFileName(this, tr("Save File"), "./waypoints.txt", tr("Waypoint File (*.txt)"));
        uas->getWaypointManager().localSaveWaypoints(fileName);
    }
}

void WaypointList::loadWaypoints()
{
    if (uas)
    {
        QString fileName = QFileDialog::getOpenFileName(this, tr("Load File"), ".", tr("Waypoint File (*.txt)"));
        uas->getWaypointManager().localLoadWaypoints(fileName);
    }
}

void WaypointList::transmit()
{
    if (uas)
    {
        uas->getWaypointManager().writeWaypoints();
    }
}

void WaypointList::read()
{
    if (uas)
    {
        uas->getWaypointManager().readWaypoints();
    }
}

void WaypointList::add()
{
    if (uas)
    {
        const QVector<Waypoint *> &waypoints = uas->getWaypointManager().getWaypointList();
        if (waypoints.size() > 0)
        {
            Waypoint *last = waypoints.at(waypoints.size()-1);
            Waypoint *wp = new Waypoint(0, last->getX(), last->getY(), last->getZ(), last->getYaw(), last->getAutoContinue(), false, last->getOrbit(), last->getHoldTime());
            uas->getWaypointManager().localAddWaypoint(wp);
        }
        else
        {
            Waypoint *wp = new Waypoint(0, 1.1, 1.1, -0.8, 0.0, true, true, 0.15, 2000);
            uas->getWaypointManager().localAddWaypoint(wp);
        }
    }
}

void WaypointList::addCurrentPositonWaypoint()
pixhawk's avatar
pixhawk committed
183
{
pixhawk's avatar
pixhawk committed
184
    if (uas)
pixhawk's avatar
pixhawk committed
185
    {
pixhawk's avatar
pixhawk committed
186 187 188 189 190 191 192 193 194 195 196 197
        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());
            uas->getWaypointManager().localAddWaypoint(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);
            uas->getWaypointManager().localAddWaypoint(wp);
        }
pixhawk's avatar
pixhawk committed
198 199 200
    }
}

pixhawk's avatar
pixhawk committed
201 202 203 204 205
void WaypointList::updateStatusLabel(const QString &string)
{
    m_ui->statusLabel->setText(string);
}

206
void WaypointList::changeCurrentWaypoint(quint16 seq)
pixhawk's avatar
pixhawk committed
207
{
pixhawk's avatar
pixhawk committed
208
    if (uas)
209
    {
210
        uas->getWaypointManager().setCurrentWaypoint(seq);
211
    }
pixhawk's avatar
pixhawk committed
212 213
}

214
void WaypointList::currentWaypointChanged(quint16 seq)
215
{
pixhawk's avatar
pixhawk committed
216
    if (uas)
217
    {
218
        const QVector<Waypoint *> &waypoints = uas->getWaypointManager().getWaypointList();
219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238

        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);
                }
            }
        }
    }
}

239
void WaypointList::waypointListChanged()
pixhawk's avatar
pixhawk committed
240
{
pixhawk's avatar
pixhawk committed
241
    if (uas)
pixhawk's avatar
pixhawk committed
242
    {
243
        const QVector<Waypoint *> &waypoints = uas->getWaypointManager().getWaypointList();
pixhawk's avatar
pixhawk committed
244

245 246
        // first remove all views of non existing waypoints
        if (!wpViews.empty())
247
        {
248 249 250
            QMapIterator<Waypoint*,WaypointView*> viewIt(wpViews);
            viewIt.toFront();
            while(viewIt.hasNext())
pixhawk's avatar
pixhawk committed
251
            {
252 253 254 255
                viewIt.next();
                Waypoint *cur = viewIt.key();
                int i;
                for (i = 0; i < waypoints.size(); i++)
256
                {
257 258 259 260
                    if (waypoints[i] == cur)
                    {
                        break;
                    }
261
                }
262
                if (i == waypoints.size())
263
                {
264 265 266 267
                    WaypointView* widget = wpViews.find(cur).value();
                    widget->hide();
                    listLayout->removeWidget(widget);
                    wpViews.remove(cur);
268
                }
pixhawk's avatar
pixhawk committed
269
            }
270 271
        }

pixhawk's avatar
pixhawk committed
272
        // then add/update the views for each waypoint in the list
273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289
        for(int i = 0; i < waypoints.size(); i++)
        {
            Waypoint *wp = waypoints[i];
            if (!wpViews.contains(wp))
            {
                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
290
        }
pixhawk's avatar
pixhawk committed
291
    }
pixhawk's avatar
pixhawk committed
292 293
}

294
void WaypointList::moveUp(Waypoint* wp)
pixhawk's avatar
pixhawk committed
295
{
296
    if (uas)
pixhawk's avatar
pixhawk committed
297
    {
298 299 300 301 302
        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++)
303
        {
304 305
            if (waypoints[i] == wp)
                break;
306 307
        }

308 309
        // if wp was found and its not the first entry, move it
        if (i < waypoints.size() && i > 0)
pixhawk's avatar
pixhawk committed
310
        {
311
            uas->getWaypointManager().localMoveWaypoint(i, i-1);
pixhawk's avatar
pixhawk committed
312 313 314 315
        }
    }
}

316
void WaypointList::moveDown(Waypoint* wp)
pixhawk's avatar
pixhawk committed
317
{
318
    if (uas)
pixhawk's avatar
pixhawk committed
319
    {
320
        const QVector<Waypoint *> &waypoints = uas->getWaypointManager().getWaypointList();
321

322 323 324
        //get the current position of wp in the local storage
        int i;
        for (i = 0; i < waypoints.size(); i++)
pixhawk's avatar
pixhawk committed
325
        {
326 327
            if (waypoints[i] == wp)
                break;
pixhawk's avatar
pixhawk committed
328 329
        }

330 331
        // if wp was found and its not the last entry, move it
        if (i < waypoints.size()-1)
pixhawk's avatar
pixhawk committed
332
        {
333
            uas->getWaypointManager().localMoveWaypoint(i, i+1);
pixhawk's avatar
pixhawk committed
334 335 336 337 338 339
        }
    }
}

void WaypointList::removeWaypoint(Waypoint* wp)
{
340
    if (uas)
pixhawk's avatar
pixhawk committed
341
    {
342
        uas->getWaypointManager().localRemoveWaypoint(wp->getId());
pixhawk's avatar
pixhawk committed
343 344 345 346 347 348 349 350 351 352 353 354 355 356
    }
}

void WaypointList::changeEvent(QEvent *e)
{
    switch (e->type()) {
    case QEvent::LanguageChange:
        m_ui->retranslateUi(this);
        break;
    default:
        break;
    }
}

357 358 359 360


void WaypointList::on_clearWPListButton_clicked()
{
361 362
    emit clearPathclicked();

363 364 365 366 367 368
    if (uas)
    {
        const QVector<Waypoint *> &waypoints = uas->getWaypointManager().getWaypointList();
            while(!waypoints.isEmpty())//for(int i = 0; i <= waypoints.size(); i++)
            {
                //Waypoint *temp = waypoints[i];
369

370
                WaypointView* widget = wpViews.find(waypoints[0]).value();
371

372
                widget->remove();
373

374 375 376
            }

    }
377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397
}

/** @brief Add a waypoint by mouse click over the map */
void WaypointList::addWaypointMouse(QPointF coordinate)
{
    if (uas)
    {
        const QVector<Waypoint *> &waypoints = uas->getWaypointManager().getWaypointList();
        if (waypoints.size() > 0)
        {
            Waypoint *last = waypoints.at(waypoints.size()-1);
            Waypoint *wp = new Waypoint(0, coordinate.x(), coordinate.y(), last->getZ(), last->getYaw(), last->getAutoContinue(), false, last->getOrbit(), last->getHoldTime());
            uas->getWaypointManager().localAddWaypoint(wp);
        }
        else
        {
            Waypoint *wp = new Waypoint(0, coordinate.x(), coordinate.y(), -0.8, 0.0, true, true, 0.15, 2000);
            uas->getWaypointManager().localAddWaypoint(wp);
        }
    }

398
}