aboutsummaryrefslogtreecommitdiff
path: root/src/utils/sceneparser.cpp
diff options
context:
space:
mode:
authorNicholas Bottone <nick@bottone.io>2023-12-08 13:52:22 -0500
committerNicholas Bottone <nick@bottone.io>2023-12-08 13:52:22 -0500
commit965859204890f980594f5fff1d20a46bb8606f55 (patch)
tree5f7da56bbd7beffe47ee43b091e1b92dc07461ff /src/utils/sceneparser.cpp
parent7e02d29375e9d6a1bbea98dc6dca600730ab8ec3 (diff)
Update translation and scaling in SceneTransformation struct
Diffstat (limited to 'src/utils/sceneparser.cpp')
-rw-r--r--src/utils/sceneparser.cpp18
1 files changed, 14 insertions, 4 deletions
diff --git a/src/utils/sceneparser.cpp b/src/utils/sceneparser.cpp
index 99c4f55..991dcfd 100644
--- a/src/utils/sceneparser.cpp
+++ b/src/utils/sceneparser.cpp
@@ -34,21 +34,25 @@ TextureData loadTextureFromFile(const QString &file) {
}
// helper to handle recursive creation of tree
-void initTree(SceneNode* currentNode, std::vector<RenderShapeData> *shapes, std::vector<SceneLightData> *lights, glm::mat4 currentCTM) {
+void initTree(SceneNode* currentNode, std::vector<RenderShapeData> *shapes, std::vector<SceneLightData> *lights, glm::mat4 currentCTM, glm::vec4 currentTranslation4d) {
for (auto t : currentNode->transformations) {
switch (t->type)
{
case TransformationType::TRANSFORMATION_TRANSLATE:
- currentCTM *= glm::translate(glm::vec3(t->translate[0], t->translate[1], t->translate[2]));
+ currentCTM *= glm::translate(glm::vec3(t->translate));
+ currentTranslation4d *= glm::vec4(t->translate); // TODO
break;
case TransformationType::TRANSFORMATION_SCALE:
- currentCTM *= glm::scale(glm::vec3(t->scale[0], t->scale[1], t->scale[2]));
+ currentCTM *= glm::scale(glm::vec3(t->scale));
+ currentTranslation4d *= glm::vec4(t->scale); // TODO
break;
case TransformationType::TRANSFORMATION_ROTATE:
currentCTM *= glm::rotate(t->angle, glm::vec3(t->rotate[0], t->rotate[1], t->rotate[2]));
+ // TODO: 4d rotation
break;
case TransformationType::TRANSFORMATION_MATRIX:
currentCTM *= glm::mat4(t->matrix);
+ currentTranslation4d *= glm::vec4(t->matrixRight4d); // TODO
break;
default:
std::cout << "Invalid transformation type" << std::endl;
@@ -59,7 +63,13 @@ void initTree(SceneNode* currentNode, std::vector<RenderShapeData> *shapes, std:
for(auto primitive : currentNode->primitives) {
// primitive->material.textureData = loadTextureFromFile(QString::fromStdString(primitive->material.textureMap.filename));
- RenderShapeData rsd = {*primitive, currentCTM, glm::inverse(currentCTM)};
+ RenderShapeData rsd = {
+ primitive: *primitive,
+ ctm: currentCTM,
+ translation4d: currentTranslation4d,
+ inverseCTM: glm::inverse(currentCTM),
+ inverseTranslation4d: glm::inverse(currentTranslation4d)
+ };
shapes->push_back(rsd);
}