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