QSortPolicy Class

class Qt3DRender::QSortPolicy

Provides storage for the sort types to be used. More...

Header: #include <QSortPolicy>
qmake: QT += 3drender
Since: Qt 5.7
Instantiated By: SortPolicy
Inherits: Qt3DRender::QFrameGraphNode

This class was introduced in Qt 5.7.

Public Types

enum SortType { StateChangeCost, BackToFront, Material, FrontToBack, Texture, Uniform }

Public Functions

QSortPolicy(Qt3DCore::QNode *parent = nullptr)

Detailed Description

A Qt3DRender::QSortPolicy class stores the sorting type used by the FrameGraph. The sort types determine how drawable entities are sorted before drawing to determine the drawing order. When QSortPolicy is present in the FrameGraph, the sorting mechanism is determined by the sortTypes list. Multiple sort types can be used simultaneously. If QSortPolicy is not present in the FrameGraph, entities are drawn in the order they appear in the entity hierarchy.

Member Type Documentation

enum QSortPolicy::SortType

This enum type describes the available sort types.

ConstantValueDescription
Qt3DRender::QSortPolicy::StateChangeCost(1 << 0)sort the objects so as to minimize the cost of changing from the currently rendered state
Qt3DRender::QSortPolicy::BackToFront(1 << 1)sort the objects from back to front based on inverted z order. More accurately, the sorting key is the z component of the projection of the camera-to-object-center vector onto the camera's view vector.
Qt3DRender::QSortPolicy::Material(1 << 2)sort the objects based on their material (shader) value.
Qt3DRender::QSortPolicy::FrontToBack(1 << 3)sort the objects from front to back. The opposite of BackToFront.
Qt3DRender::QSortPolicy::Texture (since Qt 5.14)(1 << 4)sort the objects to minimize texture changes.
Qt3DRender::QSortPolicy::Uniform (since Qt 5.15)(1 << 5)sort the objects to minimize uniform changes.

Member Function Documentation

QSortPolicy::QSortPolicy(Qt3DCore::QNode *parent = nullptr)

Constructs QSortPolicy with given parent.