Qt3D-Design-Choices: Difference between revisions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
h1. Design Choices | |||
A list of relevant design choices and various methods used or considered to solve a given feature.<br /> There is also a list of failed attempts to remind us of the reason a given method was discarded. | A list of relevant design choices and various methods used or considered to solve a given feature.<br />There is also a list of failed attempts to remind us of the reason a given method was discarded. | ||
==In Use== | == In Use == | ||
===Component Entity Model=== | === Component Entity Model === | ||
===Aspects=== | === Aspects === | ||
===ResourcesManager=== | === ResourcesManager === | ||
===FrameGraph=== | === FrameGraph === | ||
===Qml | === Qml API based on qmlRegisterExtendedType === | ||
We try to expose the same elements from | We try to expose the same elements from QML as we defined C+''. However as we want the core of Qt3D to be independent of the QML module, having extension classes that offer a way to extend our C''+ base classes to add QQmlListProperty and other QML specific elements is the best design choice we have agreed on at that point.<br />Until recently we used to have a abstract classes and the C++ or QML would define subclasses based on those. However, that was not as clean as the extension approach mainly because of the multple inheritance that implied. | ||
===QChangeArbiter=== | === QChangeArbiter === | ||
A mechanism used to have observers monitor observables. In | A mechanism used to have observers monitor observables. In Qt3D's context, backend rendering element can monitor frontend scene elements for updates to adapt the rendering accordingly. | ||
==Being considered== | == Being considered == | ||
===QQmlCustomParser=== | === QQmlCustomParser === | ||
This could be useful for declaring shader uniforms in a quick/efficient | This could be useful for declaring shader uniforms in a quick/efficient QML. This poses a conflict at the moment as a QObject cannot be registered as a custom type and a custom type. | ||
==Possible Qt improvements== | == Possible Qt improvements == | ||
===Move | === Move QML types outside of QtQuick === | ||
It would make sense to move all element that could be reused by other | It would make sense to move all element that could be reused by other QML API outside of the QtQuick scope. For instance Qt.vector3d can only be used when importing QtQuick.<br />Also finding a way to have Animations not depend on QtQuick would be nice. | ||
==Failed Attempts== | == Failed Attempts == |
Revision as of 10:36, 24 February 2015
h1. Design Choices
A list of relevant design choices and various methods used or considered to solve a given feature.
There is also a list of failed attempts to remind us of the reason a given method was discarded.
In Use
Component Entity Model
Aspects
ResourcesManager
FrameGraph
Qml API based on qmlRegisterExtendedType
We try to expose the same elements from QML as we defined C+. However as we want the core of Qt3D to be independent of the QML module, having extension classes that offer a way to extend our C+ base classes to add QQmlListProperty and other QML specific elements is the best design choice we have agreed on at that point.
Until recently we used to have a abstract classes and the C++ or QML would define subclasses based on those. However, that was not as clean as the extension approach mainly because of the multple inheritance that implied.
QChangeArbiter
A mechanism used to have observers monitor observables. In Qt3D's context, backend rendering element can monitor frontend scene elements for updates to adapt the rendering accordingly.
Being considered
QQmlCustomParser
This could be useful for declaring shader uniforms in a quick/efficient QML. This poses a conflict at the moment as a QObject cannot be registered as a custom type and a custom type.
Possible Qt improvements
Move QML types outside of QtQuick
It would make sense to move all element that could be reused by other QML API outside of the QtQuick scope. For instance Qt.vector3d can only be used when importing QtQuick.
Also finding a way to have Animations not depend on QtQuick would be nice.