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