// ----------------------------------------------------------------------- // // Original Triangle code by Jonathan Richard Shewchuk, http://www.cs.cmu.edu/~quake/triangle.html // Triangle.NET code by Christian Woltering, http://triangle.codeplex.com/ // // ----------------------------------------------------------------------- namespace TriangleNet.Topology { using System; using TriangleNet.Geometry; /// /// The subsegment data structure. /// public class SubSegment : ISegment { // Hash for dictionary. Will be set by mesh instance. internal int hash; internal Osub[] subsegs; internal Vertex[] vertices; internal Otri[] triangles; internal int boundary; public SubSegment() { // Four NULL vertices. vertices = new Vertex[4]; // Set the boundary marker to zero. boundary = 0; // Initialize the two adjoining subsegments to be the omnipresent // subsegment. subsegs = new Osub[2]; // Initialize the two adjoining triangles to be "outer space." triangles = new Otri[2]; } #region Public properties /// /// Gets the first endpoints vertex id. /// public int P0 { get { return this.vertices[0].id; } } /// /// Gets the seconds endpoints vertex id. /// public int P1 { get { return this.vertices[1].id; } } /// /// Gets the segment boundary mark. /// public int Label { get { return this.boundary; } } #endregion /// /// Gets the segments endpoint. /// public Vertex GetVertex(int index) { return this.vertices[index]; // TODO: Check range? } /// /// Gets an adjoining triangle. /// public ITriangle GetTriangle(int index) { return triangles[index].tri.hash == Mesh.DUMMY ? null : triangles[index].tri; } public override int GetHashCode() { return this.hash; } public override string ToString() { return String.Format("SID {0}", hash); } } }