// -----------------------------------------------------------------------
//
// Triangle.NET code by Christian Woltering, http://triangle.codeplex.com/
//
// -----------------------------------------------------------------------
namespace TriangleNet.Geometry
{
using System;
using System.Linq;
using System.Collections.Generic;
///
/// A polygon represented as a planar straight line graph.
///
public class Polygon : IPolygon
{
List points;
List holes;
List regions;
List segments;
///
public List Points
{
get { return points; }
}
///
public List Holes
{
get { return holes; }
}
///
public List Regions
{
get { return regions; }
}
///
public List Segments
{
get { return segments; }
}
///
public bool HasPointMarkers { get; set; }
///
public bool HasSegmentMarkers { get; set; }
///
public int Count
{
get { return points.Count; }
}
///
/// Initializes a new instance of the class.
///
public Polygon()
: this(3, false)
{
}
///
/// Initializes a new instance of the class.
///
/// The default capacity for the points list.
public Polygon(int capacity)
: this(3, false)
{
}
///
/// Initializes a new instance of the class.
///
/// The default capacity for the points list.
/// Use point and segment markers.
public Polygon(int capacity, bool markers)
{
points = new List(capacity);
holes = new List();
regions = new List();
segments = new List();
HasPointMarkers = markers;
HasSegmentMarkers = markers;
}
[Obsolete("Use polygon.Add(contour) method instead.")]
public void AddContour(IEnumerable points, int marker = 0,
bool hole = false, bool convex = false)
{
this.Add(new Contour(points, marker, convex), hole);
}
[Obsolete("Use polygon.Add(contour) method instead.")]
public void AddContour(IEnumerable points, int marker, Point hole)
{
this.Add(new Contour(points, marker), hole);
}
///
public Rectangle Bounds()
{
var bounds = new Rectangle();
bounds.Expand(this.points.Cast());
return bounds;
}
///
/// Add a vertex to the polygon.
///
/// The vertex to insert.
public void Add(Vertex vertex)
{
this.points.Add(vertex);
}
///
/// Add a segment to the polygon.
///
/// The segment to insert.
/// If true, both endpoints will be added to the points list.
public void Add(ISegment segment, bool insert = false)
{
this.segments.Add(segment);
if (insert)
{
this.points.Add(segment.GetVertex(0));
this.points.Add(segment.GetVertex(1));
}
}
///
/// Add a segment to the polygon.
///
/// The segment to insert.
/// The index of the segment endpoint to add to the points list (must be 0 or 1).
public void Add(ISegment segment, int index)
{
this.segments.Add(segment);
this.points.Add(segment.GetVertex(index));
}
///
/// Add a contour to the polygon.
///
/// The contour to insert.
/// Treat contour as a hole.
public void Add(Contour contour, bool hole = false)
{
if (hole)
{
this.Add(contour, contour.FindInteriorPoint());
}
else
{
this.points.AddRange(contour.Points);
this.segments.AddRange(contour.GetSegments());
}
}
///
/// Add a contour to the polygon.
///
/// The contour to insert.
/// Point inside the contour, making it a hole.
public void Add(Contour contour, Point hole)
{
this.points.AddRange(contour.Points);
this.segments.AddRange(contour.GetSegments());
this.holes.Add(hole);
}
}
}