Merge pull request #1494 from assimp/invalid_normals_in_unittest

UnitTest: use correct initialized normals in unittest.
pull/1480/head
Kim Kulling 2017-10-14 17:45:30 +02:00 committed by GitHub
commit 8e7f476490
1 changed files with 14 additions and 6 deletions

View File

@ -90,28 +90,36 @@ void PretransformVerticesTest::SetUp()
// add 5 empty materials // add 5 empty materials
scene->mMaterials = new aiMaterial*[scene->mNumMaterials = 5]; scene->mMaterials = new aiMaterial*[scene->mNumMaterials = 5];
for (unsigned int i = 0; i < 5;++i) for (unsigned int i = 0; i < 5;++i) {
scene->mMaterials[i] = new aiMaterial(); scene->mMaterials[i] = new aiMaterial();
}
// add 25 test meshes // add 25 test meshes
scene->mMeshes = new aiMesh*[scene->mNumMeshes = 25]; scene->mMeshes = new aiMesh*[scene->mNumMeshes = 25];
for (unsigned int i = 0; i < 25;++i) { for ( unsigned int i = 0; i < 25; ++i) {
aiMesh* mesh = scene->mMeshes[i] = new aiMesh(); aiMesh* mesh = scene->mMeshes[ i ] = new aiMesh();
mesh->mPrimitiveTypes = aiPrimitiveType_POINT; mesh->mPrimitiveTypes = aiPrimitiveType_POINT;
mesh->mFaces = new aiFace[ mesh->mNumFaces = 10+i ]; mesh->mFaces = new aiFace[ mesh->mNumFaces = 10+i ];
mesh->mVertices = new aiVector3D[mesh->mNumVertices = mesh->mNumFaces]; mesh->mVertices = new aiVector3D[mesh->mNumVertices = mesh->mNumFaces];
for (unsigned int a = 0; a < mesh->mNumFaces; ++a ) { for (unsigned int a = 0; a < mesh->mNumFaces; ++a ) {
aiFace& f = mesh->mFaces[a]; aiFace& f = mesh->mFaces[ a ];
f.mIndices = new unsigned int [f.mNumIndices = 1]; f.mIndices = new unsigned int [ f.mNumIndices = 1 ];
f.mIndices[0] = a*3; f.mIndices[0] = a*3;
mesh->mVertices[a] = aiVector3D((float)i,(float)a,0.f); mesh->mVertices[a] = aiVector3D((float)i,(float)a,0.f);
} }
mesh->mMaterialIndex = i%5; mesh->mMaterialIndex = i%5;
if (i % 2) if (i % 2) {
mesh->mNormals = new aiVector3D[mesh->mNumVertices]; mesh->mNormals = new aiVector3D[mesh->mNumVertices];
for ( unsigned int normalIdx=0; normalIdx<mesh->mNumVertices; ++normalIdx ) {
mesh->mNormals[ normalIdx ].x = 1.0f;
mesh->mNormals[ normalIdx ].y = 1.0f;
mesh->mNormals[ normalIdx ].z = 1.0f;
mesh->mNormals[ normalIdx ].Normalize();
}
}
} }
// construct some nodes (1+25) // construct some nodes (1+25)