Pixhawk3DWidget.h 4.75 KB
Newer Older
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 30 31 32 33 34 35 36
///*=====================================================================
//
//QGroundControl Open Source Ground Control Station
//
//(c) 2009, 2010 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
//
//This file is part of the QGROUNDCONTROL project
//
//    QGROUNDCONTROL 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.
//
//    QGROUNDCONTROL 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 QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.
//
//======================================================================*/

/**
 * @file
 *   @brief Definition of the class Pixhawk3DWidget.
 *
 *   @author Lionel Heng <hengli@student.ethz.ch>
 *
 */

#ifndef PIXHAWK3DWIDGET_H
#define PIXHAWK3DWIDGET_H

#include <osgText/Text>

37
#include "Imagery.h"
38
#include "ImageWindowGeode.h"
39

40 41 42 43
#ifdef QGC_LIBFREENECT_ENABLED
#include "Freenect.h"
#endif

44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
#include "Q3DWidget.h"

class UASInterface;

/**
 * @brief A 3D View widget which displays vehicle-centric information.
 **/
class Pixhawk3DWidget : public Q3DWidget
{
    Q_OBJECT

public:
    explicit Pixhawk3DWidget(QWidget* parent = 0);
    ~Pixhawk3DWidget();

public slots:
    void setActiveUAS(UASInterface* uas);

private slots:
    void showGrid(int state);
    void showTrail(int state);
65
    void showWaypoints(int state);
66
    void selectMapSource(int index);
67
    void selectVehicleModel(int index);
68
    void recenter(void);
69
    void toggleFollowCamera(int state);
70

71 72 73 74 75 76 77
    void insertWaypoint(void);
    void moveWaypoint(void);
    void setWaypoint(void);
    void deleteWaypoint(void);
    void setWaypointAltitude(void);
    void clearAllWaypoints(void);

78
protected:
79 80
    QVector< osg::ref_ptr<osg::Node> > findVehicleModels(void);
    void buildLayout(void);
81
    virtual void display(void);
82
    virtual void keyPressEvent(QKeyEvent* event);
83 84
    virtual void mousePressEvent(QMouseEvent* event);

85 86 87 88 89
    UASInterface* uas;

private:
    osg::ref_ptr<osg::Geode> createGrid(void);
    osg::ref_ptr<osg::Geode> createTrail(void);
90
    osg::ref_ptr<Imagery> createMap(void);
91
    osg::ref_ptr<osg::Node> createTarget(void);
92
    osg::ref_ptr<osg::Group> createWaypoints(void);
93
    osg::ref_ptr<osg::Geode> createRGBD3D(void);
94

95
    void setupHUD(void);
96
    void resizeHUD(void);
97

98 99 100
    void updateHUD(double robotX, double robotY, double robotZ,
                   double robotRoll, double robotPitch, double robotYaw);
    void updateTrail(double robotX, double robotY, double robotZ);
101
    void updateImagery(double originX, double originY, const QString& zone);
102
    void updateTarget(void);
103
    void updateWaypoints(void);
104 105 106
#ifdef QGC_LIBFREENECT_ENABLED
    void updateRGBD(void);
#endif
107

108 109
    void markTarget(void);

110 111 112 113 114 115 116 117 118 119 120
    int findWaypoint(int mouseX, int mouseY);
    void showInsertWaypointMenu(const QPoint& cursorPos);
    void showEditWaypointMenu(const QPoint& cursorPos);

    enum Mode {
        DEFAULT_MODE,
        MOVE_WAYPOINT_MODE
    };
    Mode mode;
    int selectedWpIndex;

121 122
    bool displayGrid;
    bool displayTrail;
123
    bool displayImagery;
124 125
    bool displayTarget;
    bool displayWaypoints;
126 127
    bool displayRGBD2D;
    bool displayRGBD3D;
128
    bool enableRGBDColor;
129

130
    bool followCamera;
131

132 133
    osg::ref_ptr<osg::Vec3dArray> trailVertices;
    QVarLengthArray<osg::Vec3d, 10000> trail;
134

135
    osg::ref_ptr<osg::Node> vehicleModel;
136 137
    osg::ref_ptr<osg::Geometry> hudBackgroundGeometry;
    osg::ref_ptr<osgText::Text> statusText;
138 139 140 141
    osg::ref_ptr<ImageWindowGeode> rgb2DGeode;
    osg::ref_ptr<ImageWindowGeode> depth2DGeode;
    osg::ref_ptr<osg::Image> rgbImage;
    osg::ref_ptr<osg::Image> depthImage;
142 143 144 145
    osg::ref_ptr<osg::Geode> gridNode;
    osg::ref_ptr<osg::Geode> trailNode;
    osg::ref_ptr<osg::Geometry> trailGeometry;
    osg::ref_ptr<osg::DrawArrays> trailDrawArrays;
146
    osg::ref_ptr<Imagery> mapNode;
147 148
    osg::ref_ptr<osg::Geode> targetNode;
    osg::ref_ptr<osg::PositionAttitudeTransform> targetPosition;
149
    osg::ref_ptr<osg::Group> waypointsNode;
150
    osg::ref_ptr<osg::Geode> rgbd3DNode;
151 152
#ifdef QGC_LIBFREENECT_ENABLED
    QScopedPointer<Freenect> freenect;
153
    QVector<Freenect::Vector6D> pointCloud;
154
#endif
155
    bool enableFreenect;
156
    QSharedPointer<QByteArray> rgb;
157 158 159
    QSharedPointer<QByteArray> coloredDepth;

    QVector< osg::ref_ptr<osg::Node> > vehicleModels;
160 161

    QPushButton* targetButton;
162

163
    double lastRobotX, lastRobotY, lastRobotZ;
164 165 166
};

#endif // PIXHAWK3DWIDGET_H