102 lines
2.8 KiB
C#
102 lines
2.8 KiB
C#
|
// -----------------------------------------------------------------------
|
|||
|
// <copyright file="HalfEdge.cs">
|
|||
|
// Triangle.NET code by Christian Woltering, http://triangle.codeplex.com/
|
|||
|
// </copyright>
|
|||
|
// -----------------------------------------------------------------------
|
|||
|
|
|||
|
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;
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// Gets or sets the half-edge id.
|
|||
|
/// </summary>
|
|||
|
public int ID
|
|||
|
{
|
|||
|
get { return id; }
|
|||
|
set { id = value; }
|
|||
|
}
|
|||
|
|
|||
|
public int Boundary
|
|||
|
{
|
|||
|
get { return mark; }
|
|||
|
set { mark = value; }
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// Gets or sets the origin of the half-edge.
|
|||
|
/// </summary>
|
|||
|
public Vertex Origin
|
|||
|
{
|
|||
|
get { return origin; }
|
|||
|
set { origin = value; }
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// Gets or sets the face connected to the half-edge.
|
|||
|
/// </summary>
|
|||
|
public Face Face
|
|||
|
{
|
|||
|
get { return face; }
|
|||
|
set { face = value; }
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// Gets or sets the twin of the half-edge.
|
|||
|
/// </summary>
|
|||
|
public HalfEdge Twin
|
|||
|
{
|
|||
|
get { return twin; }
|
|||
|
set { twin = value; }
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// Gets or sets the next pointer of the half-edge.
|
|||
|
/// </summary>
|
|||
|
public HalfEdge Next
|
|||
|
{
|
|||
|
get { return next; }
|
|||
|
set { next = value; }
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// Initializes a new instance of the <see cref="HalfEdge" /> class.
|
|||
|
/// </summary>
|
|||
|
/// <param name="origin">The origin of this half-edge.</param>
|
|||
|
public HalfEdge(Vertex origin)
|
|||
|
{
|
|||
|
this.origin = origin;
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// Initializes a new instance of the <see cref="HalfEdge" /> class.
|
|||
|
/// </summary>
|
|||
|
/// <param name="origin">The origin of this half-edge.</param>
|
|||
|
/// <param name="face">The face connected to this half-edge.</param>
|
|||
|
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);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|