QQuickWidget Class

The QQuickWidget class provides a widget for displaying a Qt Quick user interface. More...

Header: #include <QQuickWidget>
qmake: QT += quickwidgets
Since: Qt 5.3
Inherits: QWidget

Public Types

enum ResizeMode { SizeViewToRootObject, SizeRootObjectToView }
enum Status { Null, Ready, Loading, Error }

Properties

  • 58 properties inherited from QWidget

Public Functions

QQuickWidget(QWidget *parent = Q_NULLPTR)
QQuickWidget(QQmlEngine *engine, QWidget *parent)
QQuickWidget(const QUrl &source, QWidget *parent = Q_NULLPTR)
virtual ~QQuickWidget()
QQmlEngine *engine() const
QList<QQmlError> errors() const
QSurfaceFormat format() const
QImage grabFramebuffer() const
QSize initialSize() const
QQuickWindow *quickWindow() const
ResizeMode resizeMode() const
QQmlContext *rootContext() const
QQuickItem *rootObject() const
void setClearColor(const QColor &color)
void setFormat(const QSurfaceFormat &format)
void setResizeMode(ResizeMode)
QUrl source() const
Status status() const
  • 213 public functions inherited from QWidget

Public Slots

void setSource(const QUrl &url)
  • 19 public slots inherited from QWidget

Signals

void sceneGraphError(QQuickWindow::SceneGraphError error, const QString &message)
void statusChanged(QQuickWidget::Status status)

Protected Functions

bool event(QEvent *e)

Reimplemented Protected Functions

virtual void dragEnterEvent(QDragEnterEvent *e)
virtual void dragLeaveEvent(QDragLeaveEvent *e)
virtual void dragMoveEvent(QDragMoveEvent *e)
virtual void dropEvent(QDropEvent *e)
virtual void focusInEvent(QFocusEvent *event)
virtual void focusOutEvent(QFocusEvent *event)
virtual void hideEvent(QHideEvent *)
virtual void keyPressEvent(QKeyEvent *e)
virtual void keyReleaseEvent(QKeyEvent *e)
virtual void mouseDoubleClickEvent(QMouseEvent *e)
virtual void mouseMoveEvent(QMouseEvent *e)
virtual void mousePressEvent(QMouseEvent *e)
virtual void mouseReleaseEvent(QMouseEvent *e)
virtual void showEvent(QShowEvent *)
virtual void wheelEvent(QWheelEvent *e)
  • 35 protected functions inherited from QWidget

Additional Inherited Members

  • 5 static public members inherited from QWidget
  • 1 protected slot inherited from QWidget

Detailed Description

The QQuickWidget class provides a widget for displaying a Qt Quick user interface.

This is a convenience wrapper for QQuickWindow which will automatically load and display a QML scene when given the URL of the main source file. Alternatively, you can instantiate your own objects using QQmlComponent and place them in a manually set up QQuickWidget.

Typical usage:


  QQuickWidget *view = new QQuickWidget;
  view->setSource(QUrl::fromLocalFile("myqmlfile.qml"));
  view->show();

To receive errors related to loading and executing QML with QQuickWidget, you can connect to the statusChanged() signal and monitor for QQuickWidget::Error. The errors are available via QQuickWidget::errors().

QQuickWidget also manages sizing of the view and root object. By default, the resizeMode is SizeViewToRootObject, which will load the component and resize it to the size of the view. Alternatively the resizeMode may be set to SizeRootObjectToView which will resize the view to the size of the root object.

Note: QQuickWidget is an alternative to using QQuickView and QWidget::createWindowContainer(). The restrictions on stacking order do not apply, making QQuickWidget the more flexible alternative, behaving more like an ordinary widget. This comes at the expense of performance. Unlike QQuickWindow and QQuickView, QQuickWidget involves rendering into OpenGL framebuffer objects. This will naturally carry a minor performance hit.

Note: Using QQuickWidget disables the threaded render loop on all platforms. This means that some of the benefits of threaded rendering, for example Animator classes and vsync driven animations, will not be available.

Note: Avoid calling winId() on a QQuickWidget. This function triggers the creation of a native window, resulting in reduced performance and possibly rendering glitches. The entire purpose of QQuickWidget is to render Quick scenes without a separate native window, hence making it a native widget should always be avoided.

Limitations

Putting other widgets underneath and making the QQuickWidget transparent will not lead to the expected results: the widgets underneath will not be visible. This is because in practice the QQuickWidget is drawn before all other regular, non-OpenGL widgets, and so see-through types of solutions are not feasible. Other type of layouts, like having widgets on top of the QQuickWidget, will function as expected.

When absolutely necessary, this limitation can be overcome by setting the Qt::WA_AlwaysStackOnTop attribute on the QQuickWidget. Be aware, however that this breaks stacking order. For example it will not be possible to have other widgets on top of the QQuickWidget, so it should only be used in situations where a semi-transparent QQuickWidget with other widgets visible underneath is required.

This limitation only applies when there are other widgets underneath the QQuickWidget inside the same window. Making the window semi-transparent, with other applications and the desktop visible in the background, is done in the traditional way: Set Qt::WA_TranslucentBackground on the top-level window, request an alpha channel, and change the Qt Quick Scenegraph's clear color to Qt::transparent via setClearColor().

See also Exposing Attributes of C++ Types to QML, Qt Quick Widgets Example, and QQuickView.

Member Type Documentation

enum QQuickWidget::ResizeMode

This enum specifies how to resize the view.

ConstantValueDescription
QQuickWidget::SizeViewToRootObject0The view resizes with the root item in the QML.
QQuickWidget::SizeRootObjectToView1The view will automatically resize the root item to the size of the view.

enum QQuickWidget::Status

Specifies the loading status of the QQuickWidget.

ConstantValueDescription
QQuickWidget::Null0This QQuickWidget has no source set.
QQuickWidget::Ready1This QQuickWidget has loaded and created the QML component.
QQuickWidget::Loading2This QQuickWidget is loading network data.
QQuickWidget::Error3One or more errors occurred. Call errors() to retrieve a list of errors.

Property Documentation

resizeMode : ResizeMode

This property determines whether the view should resize the window contents.

If this property is set to SizeViewToRootObject (the default), the view resizes to the size of the root item in the QML.

If this property is set to SizeRootObjectToView, the view will automatically resize the root item to the size of the view.

Regardless of this property, the sizeHint of the view is the initial size of the root item. Note though that since QML may load dynamically, that size may change.

Access functions:

ResizeMode resizeMode() const
void setResizeMode(ResizeMode)

See also initialSize().

source : QUrl

This property holds the URL of the source of the QML component.

Ensure that the URL provided is full and correct, in particular, use QUrl::fromLocalFile() when loading a file from the local filesystem.

Note: Setting a source URL will result in the QML component being instantiated, even if the URL is unchanged from the current value.

Access functions:

QUrl source() const
void setSource(const QUrl &url)

status : const Status

The component's current status.

Access functions:

Status status() const

Notifier signal:

void statusChanged(QQuickWidget::Status status)

Member Function Documentation

QQuickWidget::QQuickWidget(QWidget *parent = Q_NULLPTR)

Constructs a QQuickWidget with the given parent. The default value of parent is 0.

QQuickWidget::QQuickWidget(QQmlEngine *engine, QWidget *parent)

Constructs a QQuickWidget with the given QML engine and parent.

Note: In this case, the QQuickWidget does not own the given engine object; it is the caller's responsibility to destroy the engine. If the engine is deleted before the view, status() will return QQuickWidget::Error.

See also Status, status(), and errors().

QQuickWidget::QQuickWidget(const QUrl &source, QWidget *parent = Q_NULLPTR)

Constructs a QQuickWidget with the given QML source and parent. The default value of parent is 0.

[virtual] QQuickWidget::~QQuickWidget()

Destroys the QQuickWidget.

[virtual protected] void QQuickWidget::dragEnterEvent(QDragEnterEvent *e)

Reimplemented from QWidget::dragEnterEvent().

[virtual protected] void QQuickWidget::dragLeaveEvent(QDragLeaveEvent *e)

Reimplemented from QWidget::dragLeaveEvent().

[virtual protected] void QQuickWidget::dragMoveEvent(QDragMoveEvent *e)

Reimplemented from QWidget::dragMoveEvent().

[virtual protected] void QQuickWidget::dropEvent(QDropEvent *e)

Reimplemented from QWidget::dropEvent().

QQmlEngine *QQuickWidget::engine() const

Returns a pointer to the QQmlEngine used for instantiating QML Components.

QList<QQmlError> QQuickWidget::errors() const

Return the list of errors that occurred during the last compile or create operation. When the status is not Error, an empty list is returned.

See also status.

[protected] bool QQuickWidget::event(QEvent *e)

[virtual protected] void QQuickWidget::focusInEvent(QFocusEvent *event)

Reimplemented from QWidget::focusInEvent().

[virtual protected] void QQuickWidget::focusOutEvent(QFocusEvent *event)

Reimplemented from QWidget::focusOutEvent().

QSurfaceFormat QQuickWidget::format() const

Returns the actual surface format.

If the widget has not yet been shown, the requested format is returned.

See also setFormat().

QImage QQuickWidget::grabFramebuffer() const

Renders a frame and reads it back into an image.

Note: This is a potentially expensive operation.

[virtual protected] void QQuickWidget::hideEvent(QHideEvent *)

Reimplemented from QWidget::hideEvent().

QSize QQuickWidget::initialSize() const

Returns the initial size of the root object.

If resizeMode is SizeRootObjectToView, the root object will be resized to the size of the view. This function returns the size of the root object before it was resized.

[virtual protected] void QQuickWidget::keyPressEvent(QKeyEvent *e)

Reimplemented from QWidget::keyPressEvent().

[virtual protected] void QQuickWidget::keyReleaseEvent(QKeyEvent *e)

Reimplemented from QWidget::keyReleaseEvent().

[virtual protected] void QQuickWidget::mouseDoubleClickEvent(QMouseEvent *e)

Reimplemented from QWidget::mouseDoubleClickEvent().

[virtual protected] void QQuickWidget::mouseMoveEvent(QMouseEvent *e)

Reimplemented from QWidget::mouseMoveEvent().

[virtual protected] void QQuickWidget::mousePressEvent(QMouseEvent *e)

Reimplemented from QWidget::mousePressEvent().

[virtual protected] void QQuickWidget::mouseReleaseEvent(QMouseEvent *e)

Reimplemented from QWidget::mouseReleaseEvent().

QQuickWindow *QQuickWidget::quickWindow() const

Returns the offscreen QQuickWindow which is used by this widget to drive the Qt Quick rendering. This is useful if you want to use QQuickWindow APIs that are not currently exposed by QQuickWidget, for instance connecting to the QQuickWindow::beforeRendering() signal in order to draw native OpenGL content below Qt Quick's own rendering.

Warning: Use the return value of this function with caution. In particular, do not ever attempt to show the QQuickWindow, and be very careful when using other QWindow-only APIs.

This function was introduced in Qt 5.5.

QQmlContext *QQuickWidget::rootContext() const

This function returns the root of the context hierarchy. Each QML component is instantiated in a QQmlContext. QQmlContext's are essential for passing data to QML components. In QML, contexts are arranged hierarchically and this hierarchy is managed by the QQmlEngine.

QQuickItem *QQuickWidget::rootObject() const

Returns the view's root item. Can be null when setContents/setSource has not been called, if they were called with broken QtQuick code or while the QtQuick contents are being created.

[signal] void QQuickWidget::sceneGraphError(QQuickWindow::SceneGraphError error, const QString &message)

This signal is emitted when an error occurred during scene graph initialization.

Applications should connect to this signal if they wish to handle errors, like OpenGL context creation failures, in a custom way. When no slot is connected to the signal, the behavior will be different: Quick will print the message, or show a message box, and terminate the application.

This signal will be emitted from the gui thread.

See also QQuickWindow::sceneGraphError().

void QQuickWidget::setClearColor(const QColor &color)

Sets the clear color. By default this is an opaque color.

To get a semi-transparent QQuickWidget, call this function with color set to Qt::transparent, set the Qt::WA_TranslucentBackground widget attribute on the top-level window, and request an alpha channel via setFormat().

See also QQuickWindow::setColor().

void QQuickWidget::setFormat(const QSurfaceFormat &format)

Sets the surface format for the context and offscreen surface used by this widget.

Call this function when there is a need to request a context for a given OpenGL version or profile. The sizes for depth, stencil and alpha buffers are taken care of automatically and there is no need to request those explicitly.

See also QWindow::setFormat(), QWindow::format(), and format().

[slot] void QQuickWidget::setSource(const QUrl &url)

Sets the source to the url, loads the QML component and instantiates it.

Ensure that the URL provided is full and correct, in particular, use QUrl::fromLocalFile() when loading a file from the local filesystem.

Calling this method multiple times with the same URL will result in the QML component being reinstantiated.

Note: Setter function for property source.

See also source().

[virtual protected] void QQuickWidget::showEvent(QShowEvent *)

Reimplemented from QWidget::showEvent().

QUrl QQuickWidget::source() const

Returns the source URL, if set.

Note: Getter function for property source.

See also setSource().

[signal] void QQuickWidget::statusChanged(QQuickWidget::Status status)

This signal is emitted when the component's current status changes.

Note: Notifier signal for property status.

[virtual protected] void QQuickWidget::wheelEvent(QWheelEvent *e)

Reimplemented from QWidget::wheelEvent().