// ----------------------------------------------------------------------- // // Triangle.NET code by Christian Woltering, http://triangle.codeplex.com/ // // ----------------------------------------------------------------------- namespace TriangleNet.Topology.DCEL { using System.Collections.Generic; using TriangleNet.Geometry; /// /// A face of DCEL mesh. /// public class Face { #region Static initialization of "Outer Space" face public static readonly Face Empty; static Face() { Empty = new Face(null); Empty.id = -1; } #endregion internal int id; internal int mark; internal Point generator; internal HalfEdge edge; internal bool bounded; /// /// Gets or sets the face id. /// public int ID { get { return id; } set { id = value; } } /// /// Gets or sets a half-edge connected to the face. /// public HalfEdge Edge { get { return edge; } set { edge = value; } } /// /// Gets or sets a value, indicating if the face is bounded (for Voronoi diagram). /// public bool Bounded { get { return bounded; } set { bounded = value; } } /// /// Initializes a new instance of the class. /// /// The generator of this face (for Voronoi diagram) public Face(Point generator) : this(generator, null) { } /// /// Initializes a new instance of the class. /// /// The generator of this face (for Voronoi diagram) /// The half-edge connected to this face. public Face(Point generator, HalfEdge edge) { this.generator = generator; this.edge = edge; this.bounded = true; if (generator != null) { this.id = generator.ID; } } /// /// Enumerates all half-edges of the face boundary. /// /// public IEnumerable EnumerateEdges() { var edge = this.Edge; int first = edge.ID; do { yield return edge; edge = edge.Next; } while (edge.ID != first); } public override string ToString() { return string.Format("F-ID {0}", id); } } }