本文整理匯總了C#中Autodesk.Triangulate方法的典型用法代碼示例。如果您正苦於以下問題:C# Autodesk.Triangulate方法的具體用法?C# Autodesk.Triangulate怎麽用?C# Autodesk.Triangulate使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Autodesk
的用法示例。
在下文中一共展示了Autodesk.Triangulate方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: TriangulateFace
public void TriangulateFace(Autodesk.Revit.DB.Face vFace, Transform instTransform)
{
try
{
//setup utility class
LuxExporter.UnitConverter Converter = new UnitConverter();
//process face
Mesh vMesh = vFace.Triangulate();
//check if we have a quad mesh (4 edges to a face)
if (vMesh.Vertices.Count == 4)
{
//increase face counter
iNumberOfFaces++;
//found quad
Data.NumberOfVerticesinFace = 4;
//loop through all vertices and add
foreach (XYZ ii in vMesh.Vertices)
{
XYZ point = ii;
XYZ transformedPoint;
//transform geometry (only required in nested families / or elements like baluster
if (instTransform == null)
{
transformedPoint = point;
}
else
{
transformedPoint = instTransform.OfPoint(point);
}
//get the normal
XYZ NormalAtPoint;
IntersectionResult IntResult= vFace.Project(ii);
if (IntResult != null)
{
UV UVatPoint = IntResult.UVPoint;
NormalAtPoint = new XYZ(vFace.ComputeNormal(UVatPoint).X, vFace.ComputeNormal(UVatPoint).Y, vFace.ComputeNormal(UVatPoint).Z);
}
else
{
//this needs fixing!!!
NormalAtPoint = new XYZ(0, 0, 0);
}
//convert to meter
transformedPoint = Converter.ConvertPointCoordToMeter(transformedPoint);
//NormalAtPoint = Converter.ConvertPointCoordToMeter(NormalAtPoint);
//add to ply class
Data.AddVertice(transformedPoint,NormalAtPoint);
}
}
else
{
// set pointer
Data.NumberOfVerticesinFace = 3;
//export all triangles in face
for (int i = 0; i < vMesh.NumTriangles; i++)
{
//increase face counter
iNumberOfFaces++;
MeshTriangle objTriangular = vMesh.get_Triangle(i);
for (int iPointsCounter = 0; iPointsCounter < 3; iPointsCounter++)
{
XYZ point = objTriangular.get_Vertex(iPointsCounter);
XYZ transformedPoint;
//transform geometry (only required in nested families / or elements like baluster
if (instTransform == null)
{
transformedPoint = point;
}
else
{
transformedPoint = instTransform.OfPoint(point);
}
XYZ NormalAtPoint;
//get the normal
IntersectionResult IntResult = vFace.Project(point);
if (IntResult!=null)
{
UV UVatPoint = IntResult.UVPoint;
NormalAtPoint = new XYZ(vFace.ComputeNormal(UVatPoint).X,vFace.ComputeNormal(UVatPoint).Y,vFace.ComputeNormal(UVatPoint).Z);
}
else
{
//this needs fixing
NormalAtPoint = new XYZ(0, 0, 0);
//.........這裏部分代碼省略.........