// -----------------------------------------------------------------------
//
// Triangle.NET code by Christian Woltering, http://triangle.codeplex.com/
//
// -----------------------------------------------------------------------
namespace TriangleNet.Geometry
{
using System;
using System.Collections.Generic;
///
/// A simple rectangle class.
///
public class Rectangle
{
double xmin, ymin, xmax, ymax;
///
/// Initializes a new instance of the class.
///
public Rectangle()
{
this.xmin = this.ymin = double.MaxValue;
this.xmax = this.ymax = -double.MaxValue;
}
public Rectangle(Rectangle other)
: this(other.Left, other.Bottom, other.Right, other.Top)
{
}
///
/// Initializes a new instance of the class
/// with predefined bounds.
///
/// Minimum x value (left).
/// Minimum y value (bottom).
/// Width of the rectangle.
/// Height of the rectangle.
public Rectangle(double x, double y, double width, double height)
{
this.xmin = x;
this.ymin = y;
this.xmax = x + width;
this.ymax = y + height;
}
///
/// Gets the minimum x value (left boundary).
///
public double Left
{
get { return xmin; }
}
///
/// Gets the maximum x value (right boundary).
///
public double Right
{
get { return xmax; }
}
///
/// Gets the minimum y value (bottom boundary).
///
public double Bottom
{
get { return ymin; }
}
///
/// Gets the maximum y value (top boundary).
///
public double Top
{
get { return ymax; }
}
///
/// Gets the width of the rectangle.
///
public double Width
{
get { return xmax - xmin; }
}
///
/// Gets the height of the rectangle.
///
public double Height
{
get { return ymax - ymin; }
}
///
/// Update bounds.
///
/// Add dx to left and right bounds.
/// Add dy to top and bottom bounds.
public void Resize(double dx, double dy)
{
xmin -= dx;
xmax += dx;
ymin -= dy;
ymax += dy;
}
///
/// Expand rectangle to include given point.
///
/// Point.
public void Expand(Point p)
{
xmin = Math.Min(xmin, p.x);
ymin = Math.Min(ymin, p.y);
xmax = Math.Max(xmax, p.x);
ymax = Math.Max(ymax, p.y);
}
///
/// Expand rectangle to include a list of points.
///
public void Expand(IEnumerable points)
{
foreach (var p in points)
{
Expand(p);
}
}
///
/// Expand rectangle to include given rectangle.
///
/// X coordinate.
/// Y coordinate.
public void Expand(Rectangle other)
{
xmin = Math.Min(xmin, other.xmin);
ymin = Math.Min(ymin, other.ymin);
xmax = Math.Max(xmax, other.xmax);
ymax = Math.Max(ymax, other.ymax);
}
///
/// Check if given point is inside rectangle.
///
/// Point to check.
/// Point to check.
/// Return true, if rectangle contains given point.
public bool Contains(double x, double y)
{
return ((x >= xmin) && (x <= xmax) && (y >= ymin) && (y <= ymax));
}
///
/// Check if given point is inside rectangle.
///
/// Point to check.
/// Return true, if rectangle contains given point.
public bool Contains(Point pt)
{
return Contains(pt.x, pt.y);
}
///
/// Check if this rectangle contains other rectangle.
///
/// Rectangle to check.
/// Return true, if this rectangle contains given rectangle.
public bool Contains(Rectangle other)
{
return (xmin <= other.Left && other.Right <= xmax
&& ymin <= other.Bottom && other.Top <= ymax);
}
///
/// Check if this rectangle intersects other rectangle.
///
/// Rectangle to check.
/// Return true, if given rectangle intersects this rectangle.
public bool Intersects(Rectangle other)
{
return (other.Left < xmax && xmin < other.Right
&& other.Bottom < ymax && ymin < other.Top);
}
}
}