由 Qt Quick 提供的 C++ 扩展点

All QML applications can be extended from C++ in order to use additional functionality implemented in C++ code or to provide a C++ based QML plugin. This topic of extending QML from C++ is covered in the 采用 C++ 编写 QML 扩展 文档编制。

Additionally, the Qt Quick module provides several extension and integration points for C++ developers, specific to this module. In particular, it allows C++ developers to create and register custom QQuickItem -derived types which can be rendered by Qt Quick. It also provides several scene graph-related classes which allow developers to define their own rendering primitives.

用户定义 QQuickItem 派生类型

While the Qt Quick module already provides a rich library of visual item types for use in a QML application, some developers may wish to define their own item-derived types in C++ and expose them to the QML type system. The easiest way to do this is to subclass QQuickItem , which is the base type for all visual types in the Qt Quick module. See the QQuickItem 文档编制了解更多细节。

Qt Quick 2 makes use of a dedicated scene graph based on graphics APIs such as OpenGL ES, OpenGL, Vulkan, Metal, or Direct 3D for its rendering. Using a scene graph for graphics rather than the traditional imperative painting systems ( QPainter and similar), means the scene to be rendered can be retained between frames and the complete set of primitives to render is known before rendering starts. This opens up for a number of optimizations, such as batching the OpenGL draw calls to minimize state changes or discarding obscured primitives. The Qt Quick C++ API provides various classes to enable custom nodes to be created in C++. See the Qt Quick 场景图形 文档编制了解细节。

像素图和线程图像支持

While the QML engine allows QML application to load images from filesystem or network resources, some applications may require the additional option of loading images from C++ based processes. This can be implemented through the QQuickImageProvider class, which provides support for pixmap loading and threaded image requests for QML applications. Any QML application that requests an image through the special "image:" URL scheme will be directed to an appropriate image provider to load the image.

更多信息,见 QQuickImageProvider 文档编制。