// -----------------------------------------------------------------------
//
// Triangle.NET code by Christian Woltering, http://triangle.codeplex.com/
//
// -----------------------------------------------------------------------
namespace TriangleNet.Voronoi.Legacy
{
using System;
using System.Collections.Generic;
using TriangleNet.Topology;
using TriangleNet.Geometry;
///
/// Represents a region in the Voronoi diagram.
///
public class VoronoiRegion
{
int id;
Point generator;
List vertices;
bool bounded;
// A map (vertex id) -> (neighbor across adjacent edge)
Dictionary neighbors;
///
/// Gets the Voronoi region id (which is the same as the generators vertex id).
///
public int ID
{
get { return id; }
}
///
/// Gets the Voronoi regions generator.
///
public Point Generator
{
get { return generator; }
}
///
/// Gets the Voronoi vertices on the regions boundary.
///
public ICollection Vertices
{
get { return vertices; }
}
///
/// Gets or sets whether the Voronoi region is bounded.
///
public bool Bounded
{
get { return bounded; }
set { bounded = value; }
}
public VoronoiRegion(Vertex generator)
{
this.id = generator.id;
this.generator = generator;
this.vertices = new List();
this.bounded = true;
this.neighbors = new Dictionary();
}
public void Add(Point point)
{
this.vertices.Add(point);
}
public void Add(List points)
{
this.vertices.AddRange(points);
}
///
/// Returns the neighbouring Voronoi region, that lies across the edge starting at
/// given vertex.
///
/// Vertex defining an edge of the region.
/// Neighbouring Voronoi region
///
/// The edge starting at p is well defined (vertices are ordered counterclockwise).
///
public VoronoiRegion GetNeighbor(Point p)
{
VoronoiRegion neighbor;
if (neighbors.TryGetValue(p.id, out neighbor))
{
return neighbor;
}
return null;
}
internal void AddNeighbor(int id, VoronoiRegion neighbor)
{
this.neighbors.Add(id, neighbor);
}
public override string ToString()
{
return String.Format("R-ID {0}", id);
}
}
}