// ----------------------------------------------------------------------- // // Triangle.NET code by Christian Woltering, http://triangle.codeplex.com/ // // ----------------------------------------------------------------------- namespace TriangleNet.Topology.DCEL { using System.Collections.Generic; public class Vertex : TriangleNet.Geometry.Point { internal HalfEdge leaving; /// /// Gets or sets a half-edge leaving the vertex. /// public HalfEdge Leaving { get { return leaving; } set { leaving = value; } } /// /// Initializes a new instance of the class. /// /// The x coordinate. /// The y coordinate. public Vertex(double x, double y) : base(x, y) { } /// /// Initializes a new instance of the class. /// /// The x coordinate. /// The y coordinate. /// A half-edge leaving this vertex. public Vertex(double x, double y, HalfEdge leaving) : base(x, y) { this.leaving = leaving; } /// /// Enumerates all half-edges leaving this vertex. /// /// public IEnumerable EnumerateEdges() { var edge = this.Leaving; int first = edge.ID; do { yield return edge; edge = edge.Twin.Next; } while (edge.ID != first); } public override string ToString() { return string.Format("V-ID {0}", base.id); } } }