当前位置: 首页>>代码示例>>C#>>正文


C# Mesh.CleanAndMergMesh方法代码示例

本文整理汇总了C#中Mesh.CleanAndMergMesh方法的典型用法代码示例。如果您正苦于以下问题:C# Mesh.CleanAndMergMesh方法的具体用法?C# Mesh.CleanAndMergMesh怎么用?C# Mesh.CleanAndMergMesh使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Mesh的用法示例。


在下文中一共展示了Mesh.CleanAndMergMesh方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: DoMerge

		public static Mesh DoMerge(List<MeshGroup> meshGroupsToMerge, MeshOutputSettings outputInfo)
		{
			Mesh allPolygons = new Mesh();
			if (outputInfo.CsgOptionState == MeshOutputSettings.CsgOption.DoCsgMerge)
			{
				foreach (MeshGroup meshGroup in meshGroupsToMerge)
				{
					foreach (Mesh mesh in meshGroup.Meshes)
					{
						allPolygons = CsgOperations.Union(allPolygons, mesh);
					}
				}
			}
			else
			{
				foreach (MeshGroup meshGroup in meshGroupsToMerge)
				{
					foreach (Mesh mesh in meshGroup.Meshes)
					{
						int currentMeshMaterialIntdex = MeshMaterialData.Get(mesh).MaterialIndex;
						if (outputInfo.MaterialIndexsToSave == null || outputInfo.MaterialIndexsToSave.Contains(currentMeshMaterialIntdex))
						{
							foreach (Face face in mesh.Faces)
							{
								List<Vertex> faceVertices = new List<Vertex>();
								foreach (FaceEdge faceEdgeToAdd in face.FaceEdges())
								{
									// we allow duplicates (the true) to make sure we are not changing the loaded models acuracy.
									Vertex newVertex = allPolygons.CreateVertex(faceEdgeToAdd.firstVertex.Position, CreateOption.CreateNew, SortOption.WillSortLater);
									faceVertices.Add(newVertex);
								}

								// we allow duplicates (the true) to make sure we are not changing the loaded models acuracy.
								allPolygons.CreateFace(faceVertices.ToArray(), CreateOption.CreateNew);
							}
						}
					}
				}

				allPolygons.CleanAndMergMesh();
			}

			return allPolygons;
		}
开发者ID:glocklueng,项目名称:agg-sharp,代码行数:44,代码来源:MeshFileIo.cs

示例2: MeshEdgeSplitAndUnsplitTests


//.........这里部分代码省略.........

			// make sure that the data on FaceEdges is correct (split the center edge of an extruded plus).
			{
				// make an extruded pluss sign.
				Mesh testMesh = new Mesh();
				Vertex centerVertex = testMesh.CreateVertex(0, 0, 0);
				Vertex leftVertex = testMesh.CreateVertex(-1, 0, 0);
				Vertex rightVertex = testMesh.CreateVertex(1, 0, 0);
				Vertex frontVertex = testMesh.CreateVertex(0, -1, 0);
				Vertex backVertex = testMesh.CreateVertex(0, 1, 0);

				Vertex centerVertexTop = testMesh.CreateVertex(0, 0, 1);
				Vertex leftVertexTop = testMesh.CreateVertex(-1, 0, 1);
				Vertex rightVertexTop = testMesh.CreateVertex(1, 0, 1);
				Vertex frontVertexTop = testMesh.CreateVertex(0, -1, 1);
				Vertex backVertexTop = testMesh.CreateVertex(0, 1, 1);

				testMesh.CreateFace(new Vertex[] { centerVertex, centerVertexTop, frontVertexTop, frontVertex });
				MeshEdge centerEdge = testMesh.FindMeshEdges(centerVertex, centerVertexTop)[0];
				Assert.IsTrue(centerEdge.GetNumFacesSharingEdge() == 1, "There should be 1 faces on this edge.");
				testMesh.CreateFace(new Vertex[] { centerVertex, centerVertexTop, rightVertexTop, rightVertex });
				Assert.IsTrue(centerEdge.GetNumFacesSharingEdge() == 2, "There should be 2 faces on this edge.");
				testMesh.CreateFace(new Vertex[] { centerVertex, centerVertexTop, backVertexTop, backVertex });
				Assert.IsTrue(centerEdge.GetNumFacesSharingEdge() == 3, "There should be 3 faces on this edge.");
				testMesh.CreateFace(new Vertex[] { centerVertex, centerVertexTop, leftVertexTop, leftVertex });
				Assert.IsTrue(centerEdge.GetNumFacesSharingEdge() == 4, "There should be 4 faces on this edge.");

				foreach (Face face in centerEdge.FacesSharingMeshEdgeIterator())
				{
					Assert.IsTrue(face.NumVertices == 4, "The faces should all have 4 vertices.");
				}

				Vertex createdVertx;
				MeshEdge createdEdge;
				testMesh.SplitMeshEdge(centerEdge, out createdVertx, out createdEdge);
				Assert.IsTrue(centerEdge.GetNumFacesSharingEdge() == 4, "There should still be 4 faces on this edge.");
				Assert.IsTrue(createdEdge.GetNumFacesSharingEdge() == 4, "There should be 4 faces on this new edge.");
				foreach (Face face in centerEdge.FacesSharingMeshEdgeIterator())
				{
					Assert.IsTrue(face.NumVertices == 5, "The faces should all now have 5 vertices.");
				}

				testMesh.UnsplitMeshEdge(centerEdge, createdVertx);
				Assert.IsTrue(centerEdge.GetNumFacesSharingEdge() == 4, "There should again be 4 faces on this edge.");
				foreach (Face face in centerEdge.FacesSharingMeshEdgeIterator())
				{
					Assert.IsTrue(face.NumVertices == 4, "The faces should all finally have 4 vertices.");
				}
			}

			// make sure that the data on FaceEdges is correct (split the center edge of an extruded plus).
			if (false)
			{
				Mesh testMesh = new Mesh();
				Vertex centerVertex = testMesh.CreateVertex(0, 0, 0);
				Vertex leftVertex = testMesh.CreateVertex(-1, 0, 0);
				Vertex rightVertex = testMesh.CreateVertex(1, 0, 0);

				Vertex centerVertexTop = testMesh.CreateVertex(0, 0, 1);
				Vertex leftVertexTop = testMesh.CreateVertex(-1, 0, 1);
				Vertex rightVertexTop = testMesh.CreateVertex(1, 0, 1);

				testMesh.CreateFace(new Vertex[] { centerVertex, centerVertexTop, leftVertexTop, leftVertex });
				MeshEdge centerEdge = testMesh.FindMeshEdges(centerVertex, centerVertexTop)[0];
				Assert.IsTrue(centerEdge.GetNumFacesSharingEdge() == 1, "There should be 1 faces on this edge.");
				testMesh.CreateFace(new Vertex[] { centerVertexTop, centerVertex, rightVertex, rightVertexTop });
				Assert.IsTrue(centerEdge.GetNumFacesSharingEdge() == 2, "There should be 2 faces on this edge.");

				foreach (Face face in centerEdge.FacesSharingMeshEdgeIterator())
				{
					Assert.IsTrue(face.NumVertices == 4, "The faces should all have 4 vertices.");
				}

				SaveDebugInfo(testMesh);
				testMesh.CleanAndMergMesh();
				SaveDebugInfo(testMesh);

				Vertex createdVertx;
				MeshEdge createdEdge;
				testMesh.SplitMeshEdge(centerEdge, out createdVertx, out createdEdge);
				SaveDebugInfo(testMesh);
				Assert.IsTrue(centerEdge.GetNumFacesSharingEdge() == 4, "There should still be 4 faces on this edge.");
				Assert.IsTrue(createdEdge.GetNumFacesSharingEdge() == 4, "There should be 4 faces on this new edge.");
				foreach (Face face in centerEdge.FacesSharingMeshEdgeIterator())
				{
					Assert.IsTrue(face.NumVertices == 5, "The faces should all now have 5 vertices.");
				}

				testMesh.CleanAndMergMesh();

				testMesh.UnsplitMeshEdge(centerEdge, createdVertx);
				Assert.IsTrue(centerEdge.GetNumFacesSharingEdge() == 4, "There should again be 4 faces on this edge.");
				foreach (Face face in centerEdge.FacesSharingMeshEdgeIterator())
				{
					Assert.IsTrue(face.NumVertices == 4, "The faces should all finally have 4 vertices.");
				}

				testMesh.CleanAndMergMesh();
			}
		}
开发者ID:glocklueng,项目名称:agg-sharp,代码行数:101,代码来源:MeshTests.cs

示例3: ParseFileContents


//.........这里部分代码省略.........
						bool continueProcessing;
						reportProgress(stlStream.Position / (double)bytesInFile * parsingFileRatio, "Loading Polygons", out continueProcessing);
						if (!continueProcessing)
						{
							stlStream.Close();
							return null;
						}
						maxProgressReport.Restart();
					}
				}
			}
			else
			{
				// load it as a binary stl
				// skip the first 80 bytes
				// read in the number of triangles
				stlStream.Position = 0;
				BinaryReader br = new BinaryReader(stlStream);
				byte[] fileContents = br.ReadBytes((int)stlStream.Length);
				int currentPosition = 80;
				uint numTriangles = System.BitConverter.ToUInt32(fileContents, currentPosition);
				long bytesForNormals = numTriangles * 3 * 4;
				long bytesForVertices = numTriangles * 3 * 4 * 3;
				long bytesForAttributs = numTriangles * 2;
				currentPosition += 4;
				long numBytesRequiredForVertexData = currentPosition + bytesForNormals + bytesForVertices + bytesForAttributs;
				if (fileContents.Length < numBytesRequiredForVertexData || numTriangles < 4)
				{
					stlStream.Close();
					return null;
				}
				Vector3[] vector = new Vector3[3];
				for (int i = 0; i < numTriangles; i++)
				{
					// skip the normal
					currentPosition += 3 * 4;
					for (int j = 0; j < 3; j++)
					{
						vector[j] = new Vector3(
							System.BitConverter.ToSingle(fileContents, currentPosition + 0 * 4),
							System.BitConverter.ToSingle(fileContents, currentPosition + 1 * 4),
							System.BitConverter.ToSingle(fileContents, currentPosition + 2 * 4));
						currentPosition += 3 * 4;
					}
					currentPosition += 2; // skip the attribute

					if (reportProgress != null && maxProgressReport.ElapsedMilliseconds > 200)
					{
						bool continueProcessing;
						reportProgress(i / (double)numTriangles * parsingFileRatio, "Loading Polygons", out continueProcessing);
						if (!continueProcessing)
						{
							stlStream.Close();
							return null;
						}
						maxProgressReport.Restart();
					}

					if (!Vector3.Collinear(vector[0], vector[1], vector[2]))
					{
						Vertex vertex1 = meshFromStlFile.CreateVertex(vector[0], CreateOption.CreateNew, SortOption.WillSortLater);
						Vertex vertex2 = meshFromStlFile.CreateVertex(vector[1], CreateOption.CreateNew, SortOption.WillSortLater);
						Vertex vertex3 = meshFromStlFile.CreateVertex(vector[2], CreateOption.CreateNew, SortOption.WillSortLater);
						meshFromStlFile.CreateFace(new Vertex[] { vertex1, vertex2, vertex3 }, CreateOption.CreateNew);
					}
				}
				//uint numTriangles = System.BitConverter.ToSingle(fileContents, 80);
			}

			// merge all the vetexes that are in the same place together
			bool finishedCleanAndMerge = true;
			meshFromStlFile.CleanAndMergMesh(
				(double progress0To1, string processingState, out bool continueProcessing) =>
				{
					if (reportProgress != null)
					{
						reportProgress(parsingFileRatio + progress0To1 * (1 - parsingFileRatio), processingState, out continueProcessing);
						if (!continueProcessing)
						{
							finishedCleanAndMerge = false;
						}
					}
					else
					{
						continueProcessing = true;
					}
				}
			);

			if (!finishedCleanAndMerge)
			{
				return null;
			}

			time.Stop();
			Debug.WriteLine(string.Format("STL Load in {0:0.00}s", time.Elapsed.TotalSeconds));

			stlStream.Close();
			return meshFromStlFile;
		}
开发者ID:glocklueng,项目名称:agg-sharp,代码行数:101,代码来源:StlProcessing.cs


注:本文中的Mesh.CleanAndMergMesh方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。