IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

QItemModelScatterDataProxy Class

Proxy class for presenting data in item models with Q3DScatter.

This class was introduced in QtDataVisualization 1.0.

Article lu   fois.

L'auteur

Liens sociaux

Viadeo Twitter Facebook Share on Google+   

QItemModelScatterDataProxy Class

  • Header: QItemModelScatterDataProxy

  • Since: QtDataVisualization 1.0

  • CMake:

    find_package(Qt6 REQUIRED COMPONENTS DataVisualization)

    target_link_libraries(mytarget PRIVATE Qt6::DataVisualization)

  • qmake: QT += datavisualization

  • Inherited By:

  • Instantiated By: qml-qtdatavisualization-itemmodelscatterdataproxy.xml

  • Inherits: QScatterDataProxy

Detailed Description

QItemModelScatterDataProxy allows you to use QAbstractItemModel derived models as a data source for Q3DScatter. It maps roles of QAbstractItemModel to the XYZ-values of Q3DScatter points.

The data is resolved asynchronously whenever the mapping or the model changes. QScatterDataProxy::arrayReset() is emitted when the data has been resolved. However, inserts, removes, and single data item changes after the model initialization are resolved synchronously, unless the same frame also contains a change that causes the whole model to be resolved.

Mapping ignores rows and columns of the QAbstractItemModel and treats all items equally. It requires the model to provide roles for the data items that can be mapped to X, Y, and Z-values for the scatter points.

For example, assume that you have a custom QAbstractItemModel for storing various measurements done on material samples, providing data for roles such as "density", "hardness", and "conductivity". You could visualize these properties on a scatter graph using this proxy:

 
Sélectionnez
// Map "density" value to X-axis, "hardness" to Y-axis and "conductivity" to Z-axis.
QItemModelScatterDataProxy *proxy = new QItemModelScatterDataProxy(customModel,
                                                                   QStringLiteral("density"),
                                                                   QStringLiteral("hardness"),
                                                                   QStringLiteral("conductivity"));

If the fields of the model do not contain the data in the exact format you need, you can specify a search pattern regular expression and a replace rule for each role to get the value in a format you need. For more information how the replace using regular expressions works, see QString::replace(const QRegularExpression &rx, const QString &after) function documentation. Note that using regular expressions has an impact on the performance, so it's more efficient to utilize item models where doing search and replace is not necessary to get the desired values.

For example about using the search patterns in conjunction with the roles, see ItemModelBarDataProxy usage in Simple Bar Graph example.

See Also

Property Documentation

 

itemModel : QAbstractItemModel*

This property holds the item model to use as a data source for a 3D scatter series.

Access functions:

Notifier signal:

  • void itemModelChanged(const *itemModel)

rotationRole : QString

This property holds the item model role to map into item rotation.

The model may supply the value for rotation as either variant that is directly convertible to QQuaternion, or as one of the string representations: "scalar,x,y,z" or "@angle,x,y,z". The first will construct the quaternion directly with given values, and the second one will construct the quaternion using QQuaternion::fromAxisAndAngle() method.

Access functions:

  • rotationRole() const

  • void setRotationRole(const &role)

Notifier signal:

  • void rotationRoleChanged(const &role)

rotationRolePattern : QRegularExpression

This property holds whether a search and replace is done on the value mapped by the rotation role before it is used as item rotation.

This property specifies the regular expression to find the portion of the mapped value to replace and rotationRoleReplace property contains the replacement string.

Access functions:

  • rotationRolePattern() const

  • void setRotationRolePattern(const &pattern)

Notifier signal:

  • void rotationRolePatternChanged(const &pattern)

See Also

rotationRoleReplace : QString

This property holds the replace content to be used in conjunction with the rotation role pattern.

Defaults to an empty string. For more information on how the search and replace using regular expressions works, see QString::replace(const QRegularExpression &rx, const QString &after) function documentation.

Access functions:

  • rotationRoleReplace() const

  • void setRotationRoleReplace(const &replace)

Notifier signal:

  • void rotationRoleReplaceChanged(const &replace)

See Also

xPosRole : QString

This property holds the item model role to map into the X position.

Access functions:

  • xPosRole() const

  • void setXPosRole(const &role)

Notifier signal:

  • void xPosRoleChanged(const &role)

xPosRolePattern : QRegularExpression

This property holds whether search and replace is done on the value mapped by the x position role before it is used as an item position value.

This property specifies the regular expression to find the portion of the mapped value to replace and xPosRoleReplace property contains the replacement string.

Access functions:

  • xPosRolePattern() const

  • void setXPosRolePattern(const &pattern)

Notifier signal:

  • void xPosRolePatternChanged(const &pattern)

See Also

xPosRoleReplace : QString

This property holds the replace content to be used in conjunction with the x position role pattern.

Defaults to an empty string. For more information on how the search and replace using regular expressions works, see QString::replace(const QRegularExpression &rx, const QString &after) function documentation.

Access functions:

  • xPosRoleReplace() const

  • void setXPosRoleReplace(const &replace)

Notifier signal:

  • void xPosRoleReplaceChanged(const &replace)

See Also

yPosRole : QString

This property holds the item model role to map into the Y position.

Access functions:

  • yPosRole() const

  • void setYPosRole(const &role)

Notifier signal:

  • void yPosRoleChanged(const &role)

yPosRolePattern : QRegularExpression

This property holds whether a search and replace is done on the value mapped by the y position role before it is used as an item position value.

This property specifies the regular expression to find the portion of the mapped value to replace and yPosRoleReplace property contains the replacement string.

Access functions:

  • yPosRolePattern() const

  • void setYPosRolePattern(const &pattern)

Notifier signal:

  • void yPosRolePatternChanged(const &pattern)

See Also

yPosRoleReplace : QString

This property holds the replace content to be used in conjunction with the y position role pattern.

Defaults to an empty string. For more information on how the search and replace using regular expressions works, see QString::replace(const QRegularExpression &rx, const QString &after) function documentation.

Access functions:

  • yPosRoleReplace() const

  • void setYPosRoleReplace(const &replace)

Notifier signal:

  • void yPosRoleReplaceChanged(const &replace)

See Also

zPosRole : QString

This property holds the item model role to map into the Z position.

Access functions:

  • zPosRole() const

  • void setZPosRole(const &role)

Notifier signal:

  • void zPosRoleChanged(const &role)

zPosRolePattern : QRegularExpression

This property holds whether a search and replace is done on the value mapped by the z position role before it is used as an item position value.

This property specifies the regular expression to find the portion of the mapped value to replace and zPosRoleReplace property contains the replacement string.

Access functions:

  • zPosRolePattern() const

  • void setZPosRolePattern(const &pattern)

Notifier signal:

  • void zPosRolePatternChanged(const &pattern)

See Also

zPosRoleReplace : QString

This property holds the replace content to be used in conjunction with the z position role pattern.

Defaults to an empty string. For more information on how the search and replace using regular expressions works, see QString::replace(const QRegularExpression &rx, const QString &after) function documentation.

Access functions:

  • zPosRoleReplace() const

  • void setZPosRoleReplace(const &replace)

Notifier signal:

  • void zPosRoleReplaceChanged(const &replace)

See Also

Member Function Documentation

 

[explicit] QItemModelScatterDataProxy::QItemModelScatterDataProxy(QObject *parent = nullptr)

Constructs QItemModelScatterDataProxy with optional parent.

[explicit] QItemModelScatterDataProxy::QItemModelScatterDataProxy(QAbstractItemModel *itemModel, QObject *parent = nullptr)

Constructs QItemModelScatterDataProxy with itemModel and optional parent. Proxy doesn't take ownership of the itemModel, as typically item models are owned by other controls.

[explicit] QItemModelScatterDataProxy::QItemModelScatterDataProxy(QAbstractItemModel *itemModel, const QString &xPosRole, const QString &yPosRole, const QString &zPosRole, QObject *parent = nullptr)

Constructs QItemModelScatterDataProxy with itemModel and optional parent. Proxy doesn't take ownership of the itemModel, as typically item models are owned by other controls. The xPosRole property is set to xPosRole, yPosRole property to yPosRole, and zPosRole property to zPosRole.

[explicit] QItemModelScatterDataProxy::QItemModelScatterDataProxy(QAbstractItemModel *itemModel, const QString &xPosRole, const QString &yPosRole, const QString &zPosRole, const QString &rotationRole, QObject *parent = nullptr)

Constructs QItemModelScatterDataProxy with itemModel and optional parent. Proxy doesn't take ownership of the itemModel, as typically item models are owned by other controls. The xPosRole property is set to xPosRole, yPosRole property to yPosRole, zPosRole property to zPosRole, and rotationRole property to rotationRole.

[virtual] QItemModelScatterDataProxy::~QItemModelScatterDataProxy()

void QItemModelScatterDataProxy::remap(const QString &xPosRole, const QString &yPosRole, const QString &zPosRole, const QString &rotationRole)

Changes xPosRole, yPosRole, zPosRole, and rotationRole mapping.

void QItemModelScatterDataProxy::setItemModel(QAbstractItemModel *itemModel)

Sets itemModel as the item model for Q3DScatter. Does not take ownership of the model, but does connect to it to listen for changes.

Setter function for property itemModel.

See Also

See also itemModel()

Vous avez aimé ce tutoriel ? Alors partagez-le en cliquant sur les boutons suivants : Viadeo Twitter Facebook Share on Google+