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();
|
|
}
|
|
}
|
|
}
|