home *** CD-ROM | disk | FTP | other *** search
/ Hackers Magazine 57 / CdHackersMagazineNr57.iso / Software / Multimedia / k3d-setup-0.7.11.0.exe / include / k3d / k3dsdk / rectangle.h < prev    next >
Encoding:
C/C++ Source or Header  |  2008-11-07  |  2.4 KB  |  78 lines

  1. #ifndef K3DSDK_RECTANGLE_H
  2. #define K3DSDK_RECTANGLE_H
  3.  
  4. // K-3D
  5. // Copyright (c) 1995-2006, Timothy M. Shead
  6. //
  7. // Contact: tshead@k-3d.com
  8. //
  9. // This library is free software; you can redistribute it and/or
  10. // modify it under the terms of the GNU General Public
  11. // License as published by the Free Software Foundation; either
  12. // version 2 of the License, or (at your option) any later version.
  13. //
  14. // This library is distributed in the hope that it will be useful,
  15. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  17. // General Public License for more details.
  18. //
  19. // You should have received a copy of the GNU General Public
  20. // License along with this library; if not, write to the Free Software
  21. // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
  22.  
  23. /** \file
  24.         \brief 2D geometry routines
  25.         \author Tim Shead (tshead@k-3d.com)
  26. */
  27.  
  28. #include "point2.h"
  29.  
  30. namespace k3d
  31. {
  32.  
  33. /////////////////////////////////////////////////////////////////////////////
  34. // rectangle
  35.  
  36. /// A two-dimensional rectangle particularly suitable for use with window systems i.e. Y coordinates are reversed so that top <= bottom
  37. class rectangle
  38. {
  39. public:
  40.     rectangle(const double Left, const double Right, const double Top, const double Bottom);
  41.     rectangle(const point2& TopLeft, const point2& BottomRight);
  42.     rectangle(const point2& Center, const double Width, const double Height);
  43.     /// Returns the rectangle width
  44.     double width() const;
  45.     /// Returns the rectangle height
  46.     double height() const;
  47.     /// Returns the top-left corner of the rectangle
  48.     const point2 top_left() const;
  49.     /// Returns the bottom-right corner of the rectangle
  50.     const point2 bottom_right() const;
  51.     /// Returns the center of the rectangle
  52.     const point2 center() const;
  53.     /// Tests a point to see if it is contained within the rectangle
  54.     bool contains(const point2& Point) const;
  55.     /// Stores the rectangle's left edge
  56.     double left;
  57.     /// Stores the rectangle's right edge
  58.     double right;
  59.     /// Stores the rectangle's top edge
  60.     double top;
  61.     /// Stores the rectangle's bottom edge
  62.     double bottom;
  63. };
  64.  
  65. /// Returns a rectangle where left <= right and top <= bottom
  66. const rectangle normalize(const rectangle& Rectangle);
  67.  
  68. /// Output inserter
  69. std::ostream& operator<<(std::ostream& Stream, const rectangle& Arg);
  70. /// Input extractor
  71. std::istream& operator>>(std::istream& Stream, rectangle& Arg);
  72.  
  73.  
  74. } // namespace k3d
  75.  
  76. #endif // !K3DSDK_RECTANGLE_H
  77.  
  78.