Archive 19/01/2023.

Bug In OBJ Export

theak472009

Hello!
I dont know if this is the right place but there is a bug in Drawable.cpp:
Function: WriteDrawablesToOBJ
Buggy Line number: 530 -> Vector3 vertexNormal = ((const Vector3 )(&vertexData[(vertexStart + j) * elementSize + positionOffset]));
Correct Line -> Vector3 vertexNormal = ((const Vector3 )(&vertexData[(vertexStart + j) * elementSize + normalOffset]));

positionOffset should be replaced by normalOffset. (one of the evils of ctrl-c + ctrl-v :stuck_out_tongue: )

Also, I dont know if this is right but multiplying the worldTransform with the normal is not required.

rasteron

Yes, probably post this issue on GitHub as well. :slight_smile:

codingmonkey

actually this is not all, There is another bug with normal orientation, if you trying save scene and import into blender.

this code solve this bug for blender import
Drawable.cpp (line 468)

Node* node = drawable->GetNode(); Matrix3x4 transMat = drawable->GetNode()->GetWorldTransform(); Matrix3x4 n = transMat.Inverse(); Matrix3 normalMat = Matrix3(n.m00_, n.m01_, n.m02_, n.m10_, n.m11_, n.m12_, n.m20_, n.m21_, n.m22_); normalMat = normalMat.Transpose();

line(535)

                        vertexNormal = normalMat * vertexNormal;

after this fix meshes are not have inside oriented normal (black faces)

weitjong

Can someone send a PR for this. Thanks.