Skip to content
SnakeThread.h 1.68 KiB
Newer Older
#pragma once

#include <QGeoCoordinate>
#include <QList>
#include <QObject>
#include <QThread>

#include "QNemoProgress.h"
#include "SnakeTiles.h"
Valentin Platzgummer's avatar
Valentin Platzgummer committed
#include "SnakeTilesLocal.h"
#include <boost/units/systems/si.hpp>

using namespace boost::units;
using Length = quantity<si::length>;
using Area = quantity<si::area>;

Valentin Platzgummer's avatar
Valentin Platzgummer committed
class SnakeThread : public QThread {
Valentin Platzgummer's avatar
Valentin Platzgummer committed
  class Impl;
  using PImpl = std::unique_ptr<Impl>;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
  SnakeThread(QObject *parent = nullptr);
  ~SnakeThread() override;
  void setMeasurementArea(const QList<QGeoCoordinate> &measurementArea);
  void setServiceArea(const QList<QGeoCoordinate> &serviceArea);
  void setCorridor(const QList<QGeoCoordinate> &corridor);
Valentin Platzgummer's avatar
Valentin Platzgummer committed
  void setProgress(const QVector<int> &progress);
Valentin Platzgummer's avatar
Valentin Platzgummer committed
  SnakeTiles tiles() const;
  SnakeTilesLocal tilesENU() const;
  QGeoCoordinate ENUOrigin() const;
  QVariantList tileCenterPoints() const;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
  QVector<int> progress() const;
  bool calcInProgress() const;
  QString errorMessage() const;
  bool success() const;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
  bool tilesUpdated();
  bool waypointsUpdated();
  bool progressUpdated();

  QVector<QGeoCoordinate> waypoints() const;
  QVector<QGeoCoordinate> arrivalPath() const;
  QVector<QGeoCoordinate> returnPath() const;
  Length lineDistance() const;
  void setLineDistance(Length lineDistance);
  Length minTransectLength() const;
  void setMinTransectLength(Length minTransectLength);
  Area minTileArea() const;
  void setMinTileArea(Area minTileArea);
  Length tileHeight() const;
  void setTileHeight(Length tileHeight);
  Length tileWidth() const;
  void setTileWidth(Length tileWidth);
signals:
  void calcInProgressChanged(bool inProgress);

protected:
  void run() override;

private:
Valentin Platzgummer's avatar
Valentin Platzgummer committed
  PImpl pImpl;