// -----------------------------------------------------------------------
//
// Triangle.NET code by Christian Woltering, http://triangle.codeplex.com/
//
// -----------------------------------------------------------------------
namespace TriangleNet.Topology.DCEL
{
public class HalfEdge
{
internal int id;
internal int mark;
internal Vertex origin;
internal Face face;
internal HalfEdge twin;
internal HalfEdge next;
///
/// Gets or sets the half-edge id.
///
public int ID
{
get { return id; }
set { id = value; }
}
public int Boundary
{
get { return mark; }
set { mark = value; }
}
///
/// Gets or sets the origin of the half-edge.
///
public Vertex Origin
{
get { return origin; }
set { origin = value; }
}
///
/// Gets or sets the face connected to the half-edge.
///
public Face Face
{
get { return face; }
set { face = value; }
}
///
/// Gets or sets the twin of the half-edge.
///
public HalfEdge Twin
{
get { return twin; }
set { twin = value; }
}
///
/// Gets or sets the next pointer of the half-edge.
///
public HalfEdge Next
{
get { return next; }
set { next = value; }
}
///
/// Initializes a new instance of the class.
///
/// The origin of this half-edge.
public HalfEdge(Vertex origin)
{
this.origin = origin;
}
///
/// Initializes a new instance of the class.
///
/// The origin of this half-edge.
/// The face connected to this half-edge.
public HalfEdge(Vertex origin, Face face)
{
this.origin = origin;
this.face = face;
// IMPORTANT: do not remove the (face.edge == null) check!
if (face != null && face.edge == null)
{
face.edge = this;
}
}
public override string ToString()
{
return string.Format("HE-ID {0} (Origin = VID-{1})", id, origin.id);
}
}
}