X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fcanvas%2Ftypes.cc;h=536147a7f4ff917a443312a5fc34e8910159545d;hb=c8c6bca6587450ff64303dbc994a4cd28d6ce7aa;hp=dfd934b126f7bbfd47d13bd11dbb9edfd31f3868;hpb=e2f0c5f91e2579c41d8efc9495b6ebac31a61ba3;p=ardour.git diff --git a/libs/canvas/types.cc b/libs/canvas/types.cc index dfd934b126..536147a7f4 100644 --- a/libs/canvas/types.cc +++ b/libs/canvas/types.cc @@ -17,9 +17,11 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ -#include #include #include + +#include + #include "canvas/types.h" using namespace std; @@ -27,127 +29,6 @@ using namespace ArdourCanvas; Coord const ArdourCanvas::COORD_MAX = 1.7e307; -static inline Coord -safe_add (Coord a, Coord b) -{ - if (((COORD_MAX - a) <= b) || ((COORD_MAX - b) <= a)) { - return COORD_MAX; - } - - return a + b; -} - -Duple -Duple::translate (Duple t) const -{ - Duple d; - - d.x = safe_add (x, t.x); - d.y = safe_add (y, t.y); - - return d; -} - -boost::optional -Rect::intersection (Rect const & o) const -{ - Rect i; - - i.x0 = max (x0, o.x0); - i.y0 = max (y0, o.y0); - i.x1 = min (x1, o.x1); - i.y1 = min (y1, o.y1); - - if (i.x0 > i.x1 || i.y0 > i.y1) { - return boost::optional (); - } - - return boost::optional (i); -} - -Rect -Rect::translate (Duple t) const -{ - Rect r; - - r.x0 = safe_add (x0, t.x); - r.y0 = safe_add (y0, t.y); - r.x1 = safe_add (x1, t.x); - r.y1 = safe_add (y1, t.y); - return r; -} - -Rect -Rect::extend (Rect const & o) const -{ - Rect r; - r.x0 = min (x0, o.x0); - r.y0 = min (y0, o.y0); - r.x1 = max (x1, o.x1); - r.y1 = max (y1, o.y1); - return r; -} - -Rect -Rect::expand (Distance amount) const -{ - Rect r; - r.x0 = x0 - amount; - r.y0 = y0 - amount; - r.x1 = safe_add (x1, amount); - r.y1 = safe_add (y1, amount); - return r; -} - -bool -Rect::contains (Duple point) const -{ - return point.x >= x0 && point.x <= x1 && point.y >= y0 && point.y <= y1; -} - -Rect -Rect::fix () const -{ - Rect r; - - r.x0 = min (x0, x1); - r.y0 = min (y0, y1); - r.x1 = max (x0, x1); - r.y1 = max (y0, y1); - - return r; -} - -Duple -ArdourCanvas::operator- (Duple const & o) -{ - return Duple (-o.x, -o.y); -} - -Duple -ArdourCanvas::operator+ (Duple const & a, Duple const & b) -{ - return Duple (safe_add (a.x, b.x), safe_add (a.y, b.y)); -} - -bool -ArdourCanvas::operator== (Duple const & a, Duple const & b) -{ - return a.x == b.x && a.y == b.y; -} - -Duple -ArdourCanvas::operator- (Duple const & a, Duple const & b) -{ - return Duple (a.x - b.x, a.y - b.y); -} - -Duple -ArdourCanvas::operator/ (Duple const & a, double b) -{ - return Duple (a.x / b, a.y / b); -} - ostream & ArdourCanvas::operator<< (ostream & s, Duple const & r) {