]> Dogcows Code - chaz/openbox/blobdiff - otk/rect.cc
support the button pressed resources better
[chaz/openbox] / otk / rect.cc
index db53b37e1a2f53a799e3d1c4dbb3119e93ce6147..7ec5c2c4487378c36a8ac62d509902d13d8c0ea7 100644 (file)
@@ -1,8 +1,15 @@
+// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
+
+#ifdef HAVE_CONFIG_H
+# include "../config.h"
+#endif
+
 #include "rect.hh"
 
 namespace otk {
 
-void Rect::setX(int x) {
+void Rect::setX(int x)
+{
   _x2 += x - _x1;
   _x1 = x;
 }
@@ -15,7 +22,17 @@ void Rect::setY(int y)
 }
 
 
-void Rect::setPos(int x, int y) {
+void Rect::setPos(const Point &location)
+{
+  _x2 += location.x() - _x1;
+  _x1 = location.x();
+  _y2 += location.y() - _y1;
+  _y1 = location.y();
+}
+
+
+void Rect::setPos(int x, int y)
+{
   _x2 += x - _x1;
   _x1 = x;
   _y2 += y - _y1;
@@ -23,28 +40,46 @@ void Rect::setPos(int x, int y) {
 }
 
 
-void Rect::setWidth(unsigned int w) {
+void Rect::setWidth(int w)
+{
   _x2 = w + _x1 - 1;
 }
 
 
-void Rect::setHeight(unsigned int h) {
+void Rect::setHeight(int h)
+{
   _y2 = h + _y1 - 1;
 }
 
 
-void Rect::setSize(unsigned int w, unsigned int h) {
+void Rect::setSize(int w, int h)
+{
   _x2 = w + _x1 - 1;
   _y2 = h + _y1 - 1;
 }
 
 
-void Rect::setRect(int x, int y, unsigned int w, unsigned int h) {
+void Rect::setSize(const Point &size)
+{
+  _x2 = size.x() + _x1 - 1;
+  _y2 = size.y() + _y1 - 1;
+}
+
+
+void Rect::setRect(int x, int y, int w, int h)
+{
   *this = Rect(x, y, w, h);
 }
 
 
-void Rect::setCoords(int l, int t, int r, int b) {
+void Rect::setRect(const Point &location, const Point &size)
+{
+  *this = Rect(location, size);
+}
+
+
+void Rect::setCoords(int l, int t, int r, int b)
+{
   _x1 = l;
   _y1 = t;
   _x2 = r;
@@ -52,7 +87,17 @@ void Rect::setCoords(int l, int t, int r, int b) {
 }
 
 
-Rect Rect::operator|(const Rect &a) const {
+void Rect::setCoords(const Point &tl, const Point &br)
+{
+  _x1 = tl.x();
+  _y1 = tl.y();
+  _x2 = br.x();
+  _y2 = br.y();
+}
+
+
+Rect Rect::operator|(const Rect &a) const
+{
   Rect b;
 
   b._x1 = std::min(_x1, a._x1);
@@ -64,7 +109,8 @@ Rect Rect::operator|(const Rect &a) const {
 }
 
 
-Rect Rect::operator&(const Rect &a) const {
+Rect Rect::operator&(const Rect &a) const
+{
   Rect b;
 
   b._x1 = std::max(_x1, a._x1);
@@ -76,19 +122,28 @@ Rect Rect::operator&(const Rect &a) const {
 }
 
 
-bool Rect::intersects(const Rect &a) const {
+bool Rect::intersects(const Rect &a) const
+{
   return std::max(_x1, a._x1) <= std::min(_x2, a._x2) &&
          std::max(_y1, a._y1) <= std::min(_y2, a._y2);
 }
 
 
-bool Rect::contains(int x, int y) const {
+bool Rect::contains(int x, int y) const
+{
   return x >= _x1 && x <= _x2 &&
          y >= _y1 && y <= _y2;
 }
 
 
-bool Rect::contains(const Rect& a) const {
+bool Rect::contains(const Point &p) const
+{
+  return contains(p.x(), p.y());
+}
+
+
+bool Rect::contains(const Rect& a) const
+{
   return a._x1 >= _x1 && a._x2 <= _x2 &&
          a._y1 >= _y1 && a._y2 <= _y2;
 }
This page took 0.024779 seconds and 4 git commands to generate.