浏览代码

Fixed orientation of MD2, MD3 and 3DS models.

git-svn-id: https://assimp.svn.sourceforge.net/svnroot/assimp/trunk@75 67173fc5-114c-0410-ac8e-9d2fd5bffc1f
aramis_acg 17 年之前
父节点
当前提交
63596e22c5
共有 4 个文件被更改,包括 21 次插入17 次删除
  1. 1 1
      code/3DSConverter.cpp
  2. 7 2
      code/3DSGenNormals.cpp
  3. 9 9
      code/MD2Loader.cpp
  4. 4 5
      code/MD3Loader.cpp

+ 1 - 1
code/3DSConverter.cpp

@@ -593,7 +593,7 @@ void Dot3DSImporter::AddNodeToGraph(aiScene* pcSOut,aiNode* pcOut,Dot3DS::Node*
 					while (pvCurrent != pvEnd)
 					while (pvCurrent != pvEnd)
 					{
 					{
 						std::swap( pvCurrent->y, pvCurrent->z );
 						std::swap( pvCurrent->y, pvCurrent->z );
-						pvCurrent->y *= -1.0f;
+						//pvCurrent->y *= -1.0f;
 						++pvCurrent;
 						++pvCurrent;
 					}
 					}
 				}
 				}

+ 7 - 2
code/3DSGenNormals.cpp

@@ -66,8 +66,9 @@ void Dot3DSImporter::GenNormals(Dot3DS::Mesh* sMesh)
 		aiVector3D* pV2 = &sMesh->mPositions[face.mIndices[1]];
 		aiVector3D* pV2 = &sMesh->mPositions[face.mIndices[1]];
 		aiVector3D* pV3 = &sMesh->mPositions[face.mIndices[2]];
 		aiVector3D* pV3 = &sMesh->mPositions[face.mIndices[2]];
 
 
-		aiVector3D pDelta1 = *pV2 - *pV1;
-		aiVector3D pDelta2 = *pV3 - *pV1;
+		// FIX invert all vertex normals
+		aiVector3D pDelta1 = *pV3 - *pV1;
+		aiVector3D pDelta2 = *pV2 - *pV1;
 		aiVector3D vNor = pDelta1 ^ pDelta2;
 		aiVector3D vNor = pDelta1 ^ pDelta2;
 
 
 		sMesh->mNormals[face.mIndices[0]] = vNor;
 		sMesh->mNormals[face.mIndices[0]] = vNor;
@@ -127,6 +128,10 @@ void Dot3DSImporter::GenNormals(Dot3DS::Mesh* sMesh)
 			vNormals.y /= fDiv;
 			vNormals.y /= fDiv;
 			vNormals.z /= fDiv;
 			vNormals.z /= fDiv;
 			vNormals.Normalize();
 			vNormals.Normalize();
+
+			// do the common coordinate system adjustment
+			std::swap(vNormals.y,vNormals.z);
+
 			avNormals[(*i).mIndices[c]] = vNormals;
 			avNormals[(*i).mIndices[c]] = vNormals;
 			poResult.clear();
 			poResult.clear();
 		}
 		}

+ 9 - 9
code/MD2Loader.cpp

@@ -344,16 +344,18 @@ void MD2Importer::InternReadFile(
 				vec.x += pcFrame->translate[0];
 				vec.x += pcFrame->translate[0];
 
 
 				// (flip z and y component)
 				// (flip z and y component)
-				vec.z = (float)pcVerts[iIndex].vertex[1] * pcFrame->scale[1];
-				vec.z += pcFrame->translate[1];
+				// FIX: no .... invert y instead
+				vec.y = (float)pcVerts[iIndex].vertex[1] * pcFrame->scale[1];
+				vec.y += pcFrame->translate[1];
+				vec.y *= -1.0f;
 
 
-				vec.y = (float)pcVerts[iIndex].vertex[2] * pcFrame->scale[2];
-				vec.y += pcFrame->translate[2];
+				vec.z = (float)pcVerts[iIndex].vertex[2] * pcFrame->scale[2];
+				vec.z += pcFrame->translate[2];
 
 
 				// read the normal vector from the precalculated normal table
 				// read the normal vector from the precalculated normal table
 				aiVector3D& vNormal = pcMesh->mNormals[iCurrent];
 				aiVector3D& vNormal = pcMesh->mNormals[iCurrent];
 				LookupNormalIndex(pcVerts[iIndex].lightNormalIndex,vNormal);
 				LookupNormalIndex(pcVerts[iIndex].lightNormalIndex,vNormal);
-				std::swap ( vNormal.y,vNormal.z );
+				vNormal.y *= -1.0f;
 
 
 				// validate texture coordinates
 				// validate texture coordinates
 				if (pcTriangles[iIndex].textureIndices[c] >= this->m_pcHeader->numTexCoords)
 				if (pcTriangles[iIndex].textureIndices[c] >= this->m_pcHeader->numTexCoords)
@@ -407,18 +409,16 @@ void MD2Importer::InternReadFile(
 
 
 				vec.x = (float)pcVerts[iIndex].vertex[0] * pcFrame->scale[0];
 				vec.x = (float)pcVerts[iIndex].vertex[0] * pcFrame->scale[0];
 				vec.x += pcFrame->translate[0];
 				vec.x += pcFrame->translate[0];
-
-				// (flip z and y component)
 				vec.z = (float)pcVerts[iIndex].vertex[1] * pcFrame->scale[1];
 				vec.z = (float)pcVerts[iIndex].vertex[1] * pcFrame->scale[1];
 				vec.z += pcFrame->translate[1];
 				vec.z += pcFrame->translate[1];
-
 				vec.y = (float)pcVerts[iIndex].vertex[2] * pcFrame->scale[2];
 				vec.y = (float)pcVerts[iIndex].vertex[2] * pcFrame->scale[2];
 				vec.y += pcFrame->translate[2];
 				vec.y += pcFrame->translate[2];
+				vec.y *= -1.f;
 
 
 				// read the normal vector from the precalculated normal table
 				// read the normal vector from the precalculated normal table
 				aiVector3D& vNormal = pcMesh->mNormals[iCurrent];
 				aiVector3D& vNormal = pcMesh->mNormals[iCurrent];
 				LookupNormalIndex(pcVerts[iIndex].lightNormalIndex,vNormal);
 				LookupNormalIndex(pcVerts[iIndex].lightNormalIndex,vNormal);
-				std::swap ( vNormal.y,vNormal.z );
+				vNormal.y *= -1.0f;
 			}
 			}
 			// FIX: flip the face order for use with OpenGL
 			// FIX: flip the face order for use with OpenGL
 			pScene->mMeshes[0]->mFaces[i].mIndices[0] = iTemp+2;
 			pScene->mMeshes[0]->mFaces[i].mIndices[0] = iTemp+2;

+ 4 - 5
code/MD3Loader.cpp

@@ -251,19 +251,18 @@ void MD3Importer::InternReadFile(
 			{
 			{
 				// read vertices
 				// read vertices
 				pcMesh->mVertices[iCurrent].x = pcVertices[ pcTriangles->INDEXES[c]].X;
 				pcMesh->mVertices[iCurrent].x = pcVertices[ pcTriangles->INDEXES[c]].X;
-				pcMesh->mVertices[iCurrent].y = pcVertices[ pcTriangles->INDEXES[c]].Y;
-				pcMesh->mVertices[iCurrent].z = pcVertices[ pcTriangles->INDEXES[c]].Z*-1.0f;
+				pcMesh->mVertices[iCurrent].y = pcVertices[ pcTriangles->INDEXES[c]].Y*-1.0f;
+				pcMesh->mVertices[iCurrent].z = pcVertices[ pcTriangles->INDEXES[c]].Z;
 
 
 				// convert the normal vector to uncompressed float3 format
 				// convert the normal vector to uncompressed float3 format
 				LatLngNormalToVec3(pcVertices[pcTriangles->INDEXES[c]].NORMAL,
 				LatLngNormalToVec3(pcVertices[pcTriangles->INDEXES[c]].NORMAL,
 					(float*)&pcMesh->mNormals[iCurrent]);
 					(float*)&pcMesh->mNormals[iCurrent]);
 
 
-				//std::swap(pcMesh->mNormals[iCurrent].z,pcMesh->mNormals[iCurrent].y);
-				pcMesh->mNormals[iCurrent].z *= -1.0f;
+				pcMesh->mNormals[iCurrent].y *= -1.0f;
 
 
 				// read texture coordinates
 				// read texture coordinates
 				pcMesh->mTextureCoords[0][iCurrent].x = pcUVs[ pcTriangles->INDEXES[c]].U;
 				pcMesh->mTextureCoords[0][iCurrent].x = pcUVs[ pcTriangles->INDEXES[c]].U;
-				pcMesh->mTextureCoords[0][iCurrent].y = 1.0f - pcUVs[ pcTriangles->INDEXES[c]].V;
+				pcMesh->mTextureCoords[0][iCurrent].y = 1.0f-pcUVs[ pcTriangles->INDEXES[c]].V;
 			}
 			}
 			// FIX: flip the face ordering for use with OpenGL
 			// FIX: flip the face ordering for use with OpenGL
 			pcMesh->mFaces[i].mIndices[0] = iTemp+2;
 			pcMesh->mFaces[i].mIndices[0] = iTemp+2;