93 lines
2.8 KiB
C#
93 lines
2.8 KiB
C#
|
// -----------------------------------------------------------------------
|
|||
|
// <copyright file="TriangleFormat.cs" company="">
|
|||
|
// Triangle.NET code by Christian Woltering, http://triangle.codeplex.com/
|
|||
|
// </copyright>
|
|||
|
// -----------------------------------------------------------------------
|
|||
|
|
|||
|
namespace TriangleNet.IO
|
|||
|
{
|
|||
|
using System;
|
|||
|
using System.Collections.Generic;
|
|||
|
using System.IO;
|
|||
|
using TriangleNet.Geometry;
|
|||
|
using TriangleNet.Meshing;
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// Implements geometry and mesh file formats of the the original Triangle code.
|
|||
|
/// </summary>
|
|||
|
public class TriangleFormat : IPolygonFormat, IMeshFormat
|
|||
|
{
|
|||
|
public bool IsSupported(string file)
|
|||
|
{
|
|||
|
string ext = Path.GetExtension(file).ToLower();
|
|||
|
|
|||
|
if (ext == ".node" || ext == ".poly" || ext == ".ele")
|
|||
|
{
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
public IMesh Import(string filename)
|
|||
|
{
|
|||
|
string ext = Path.GetExtension(filename);
|
|||
|
|
|||
|
if (ext == ".node" || ext == ".poly" || ext == ".ele")
|
|||
|
{
|
|||
|
List<ITriangle> triangles;
|
|||
|
Polygon geometry;
|
|||
|
|
|||
|
(new TriangleReader()).Read(filename, out geometry, out triangles);
|
|||
|
|
|||
|
if (geometry != null && triangles != null)
|
|||
|
{
|
|||
|
return Converter.ToMesh(geometry, triangles.ToArray());
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
throw new NotSupportedException("Could not load '" + filename + "' file.");
|
|||
|
}
|
|||
|
|
|||
|
public void Write(IMesh mesh, string filename)
|
|||
|
{
|
|||
|
var writer = new TriangleWriter();
|
|||
|
|
|||
|
writer.WritePoly((Mesh)mesh, Path.ChangeExtension(filename, ".poly"));
|
|||
|
writer.WriteElements((Mesh)mesh, Path.ChangeExtension(filename, ".ele"));
|
|||
|
}
|
|||
|
|
|||
|
public void Write(IMesh mesh, Stream stream)
|
|||
|
{
|
|||
|
throw new NotImplementedException();
|
|||
|
}
|
|||
|
|
|||
|
public IPolygon Read(string filename)
|
|||
|
{
|
|||
|
string ext = Path.GetExtension(filename);
|
|||
|
|
|||
|
if (ext == ".node")
|
|||
|
{
|
|||
|
return (new TriangleReader()).ReadNodeFile(filename);
|
|||
|
}
|
|||
|
else if (ext == ".poly")
|
|||
|
{
|
|||
|
return (new TriangleReader()).ReadPolyFile(filename);
|
|||
|
}
|
|||
|
|
|||
|
throw new NotSupportedException("File format '" + ext + "' not supported.");
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
public void Write(IPolygon polygon, string filename)
|
|||
|
{
|
|||
|
(new TriangleWriter()).WritePoly(polygon, filename);
|
|||
|
}
|
|||
|
|
|||
|
public void Write(IPolygon polygon, Stream stream)
|
|||
|
{
|
|||
|
throw new NotImplementedException();
|
|||
|
}
|
|||
|
}
|
|||
|
}
|