QGCQmlWidgetHolder.h 2.38 KB
Newer Older
Don Gagne's avatar
Don Gagne 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
/*=====================================================================
 
 QGroundControl Open Source Ground Control Station
 
 (c) 2009 - 2014 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/>.
 
 ======================================================================*/

#ifndef QGCQmlWidgetHolder_h
#define QGCQmlWidgetHolder_h

/// @file
///     @author Don Gagne <don@thegagnes.com>

30 31
#include "QGCDockWidget.h"
#include "AutoPilotPlugin.h"
Don Gagne's avatar
Don Gagne committed
32 33 34 35 36 37 38 39 40

#include "ui_QGCQmlWidgetHolder.h"

namespace Ui {
class QGCQmlWidgetHolder;
}

/// This is used to create widgets which are implemented in QML.

41
class QGCQmlWidgetHolder : public QGCDockWidget
Don Gagne's avatar
Don Gagne committed
42 43 44 45
{
    Q_OBJECT

public:
46 47 48 49 50
    // This has a title and action since the base class is QGCDockWidget. In order to use this
    // control as a normal QWidget, not a doc widget just pass in:
    //      title = QString()
    //      action = NULL
    explicit QGCQmlWidgetHolder(const QString& title, QAction* action, QWidget *parent = 0);
Don Gagne's avatar
Don Gagne committed
51 52 53 54 55
    ~QGCQmlWidgetHolder();
    
    /// Sets the UAS into the widget which in turn will load facts into the context
    void setAutoPilot(AutoPilotPlugin* autoPilot);

dogmaphobic's avatar
dogmaphobic committed
56
    /// Get Root Context
57
    QQmlContext* getRootContext(void);
dogmaphobic's avatar
dogmaphobic committed
58

59 60 61
    /// Get Root Object
    QQuickItem* getRootObject(void);
    
62
    /// Sets the QML into the control. Will display errors message box if error occurs loading source.
dogmaphobic's avatar
dogmaphobic committed
63
    /// @return true: source loaded, false: source not loaded, errors occured
Don Gagne's avatar
Don Gagne committed
64
    bool setSource(const QUrl& qmlUrl);
dogmaphobic's avatar
dogmaphobic committed
65

66
    void setContextPropertyObject(const QString& name, QObject* object);
Don Gagne's avatar
Don Gagne committed
67 68 69
    
    /// Sets the resize mode for the QQuickWidget container
    void setResizeMode(QQuickWidget::ResizeMode resizeMode);
Don Gagne's avatar
Don Gagne committed
70 71 72 73 74 75

private:
    Ui::QGCQmlWidgetHolder _ui;
};

#endif