/*===================================================================== PIXHAWK Micro Air Vehicle Flying Robotics Toolkit (c) 2009, 2010 PIXHAWK PROJECT 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 . ======================================================================*/ /** * @file * @brief Definition of of Horizontal Situation Indicator class * * @author Lorenz Meier * */ #ifndef HSIDISPLAY_H #define HSIDISPLAY_H #include #include #include #include #include #include #include #include "HDDisplay.h" #include "MG.h" class HSIDisplay : public HDDisplay { Q_OBJECT public: HSIDisplay(QWidget *parent = 0); // ~HSIDisplay(); public slots: void setActiveUAS(UASInterface* uas); void updateSatellite(int uasid, int satid, float azimuth, float direction, float snr, bool used); void updateAttitudeSetpoints(UASInterface*, double rollDesired, double pitchDesired, double yawDesired, double thrustDesired, quint64 usec); void updatePositionSetpoints(int uasid, float xDesired, float yDesired, float zDesired, float yawDesired, quint64 usec); void updateLocalPosition(UASInterface*, double x, double y, double z, quint64 usec); void updateGlobalPosition(UASInterface*, double lat, double lon, double alt, quint64 usec); void updateSpeed(UASInterface* uas, double vx, double vy, double vz, quint64 time); void paintEvent(QPaintEvent * event); /** @brief Update state from joystick */ void updateJoystick(double roll, double pitch, double yaw, double thrust, int xHat, int yHat); void pressKey(int key); protected slots: void paintDisplay(); void drawGPS(QPainter &painter); void drawObjects(QPainter &painter); void drawPositionDirection(float xRef, float yRef, float radius, const QColor& color, QPainter* painter); void drawAttitudeDirection(float xRef, float yRef, float radius, const QColor& color, QPainter* painter); void drawAltitudeSetpoint(float xRef, float yRef, float radius, const QColor& color, QPainter* painter); void setBodySetpointCoordinateXY(double x, double y); void setBodySetpointCoordinateZ(double z); /** @brief Send the current ui setpoint coordinates as new setpoint to the MAV */ void sendBodySetPointCoordinates(); /** @brief Draw one setpoint */ void drawSetpointXY(float x, float y, float yaw, const QColor &color, QPainter &painter); /** @brief Draw the limiting safety area */ void drawSafetyArea(const QPointF &topLeft, const QPointF &bottomRight, const QColor &color, QPainter &painter); void mouseDoubleClickEvent(QMouseEvent* event); protected: static QColor getColorForSNR(float snr); /** @brief Screen coordinates of widget to metric coordinates in body frame */ QPointF screenToMetricBody(QPointF ref); /** @brief Reference coordinates to metric coordinates */ QPointF refToMetricBody(QPointF &ref); /** @brief Metric coordinates to reference coordinates */ QPointF metricBodyToRefX(QPointF &metric); /** * @brief Private data container class to be used within the HSI widget */ class GPSSatellite { public: GPSSatellite(int id, float elevation, float azimuth, float snr, bool used) : id(id), elevation(elevation), azimuth(azimuth), snr(snr), used(used), lastUpdate(MG::TIME::getGroundTimeNowUsecs()) { } void update(int id, float elevation, float azimuth, float snr, bool used) { this->id = id; this->elevation = elevation; this->azimuth = azimuth; this->snr = snr; this->used = used; this->lastUpdate = MG::TIME::getGroundTimeNowUsecs(); } int id; float elevation; float azimuth; float snr; bool used; quint64 lastUpdate; friend class HSIDisplay; }; QMap gpsSatellites; unsigned int satellitesUsed; // Current controller values float attXSet; float attYSet; float attYawSet; float altitudeSet; float posXSet; float posYSet; float posZSet; // Controller saturation values float attXSaturation; float attYSaturation; float attYawSaturation; float posXSaturation; float posYSaturation; float altitudeSaturation; // Position float lat; float lon; float alt; quint64 globalAvailable; ///< Last global position update time float x; float y; float z; float vx; float vy; float vz; float speed; quint64 localAvailable; ///< Last local position update time float roll; float pitch; float yaw; float bodyXSetCoordinate; ///< X Setpoint coordinate active on the MAV float bodyYSetCoordinate; ///< Y Setpoint coordinate active on the MAV float bodyZSetCoordinate; ///< Z Setpoint coordinate active on the MAV float bodyYawSet; ///< Yaw setpoint coordinate active on the MAV float uiXSetCoordinate; ///< X Setpoint coordinate wanted by the UI float uiYSetCoordinate; ///< Y Setpoint coordinate wanted by the UI float uiZSetCoordinate; ///< Z Setpoint coordinate wanted by the UI float uiYawSet; ///< Yaw Setpoint wanted by the UI float metricWidth; ///< Width the instrument represents in meters (the width of the ground shown by the widget) // float xCenterPos; float yCenterPos; private: }; #endif // HSIDISPLAY_H