2011-05-23 17:18:52 +10:00
|
|
|
/*
|
2011-06-21 20:26:32 +10:00
|
|
|
* This file is part of libgim.
|
2011-05-23 17:18:52 +10:00
|
|
|
*
|
2011-06-21 20:26:32 +10:00
|
|
|
* libgim is free software: you can redistribute it and/or modify it under the
|
2011-05-23 17:18:52 +10:00
|
|
|
* terms of the GNU General Public License as published by the Free Software
|
|
|
|
* Foundation, either version 3 of the License, or (at your option) any later
|
|
|
|
* version.
|
|
|
|
*
|
2011-06-21 20:26:32 +10:00
|
|
|
* libgim is distributed in the hope that it will be useful, but WITHOUT ANY
|
2011-05-23 17:18:52 +10:00
|
|
|
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
|
|
* details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
2011-06-21 20:26:32 +10:00
|
|
|
* along with libgim. If not, see <http://www.gnu.org/licenses/>.
|
2011-05-23 17:18:52 +10:00
|
|
|
*
|
2012-04-23 13:06:41 +10:00
|
|
|
* Copyright 2010 Danny Robson <danny@nerdcruft.net>
|
2011-05-23 17:18:52 +10:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef __UTIL_REGION_HPP
|
|
|
|
#define __UTIL_REGION_HPP
|
|
|
|
|
2011-10-17 17:20:17 +11:00
|
|
|
#include "point.hpp"
|
2012-05-25 15:30:28 +10:00
|
|
|
#include "types/traits.hpp"
|
2011-10-17 17:20:17 +11:00
|
|
|
|
2011-08-15 20:10:43 +10:00
|
|
|
namespace util {
|
|
|
|
/**
|
|
|
|
* A two-dimensional rectangle, with size and position.
|
|
|
|
*/
|
|
|
|
template <typename T>
|
2011-08-29 14:40:05 +10:00
|
|
|
struct region {
|
2012-06-08 16:49:09 +10:00
|
|
|
typedef T position_type;
|
2012-06-14 18:30:08 +10:00
|
|
|
#if 0
|
2012-05-25 15:30:28 +10:00
|
|
|
typedef typename always_unsigned<T>::type size_type;
|
2012-06-14 18:30:08 +10:00
|
|
|
#else
|
|
|
|
typedef T size_type;
|
|
|
|
#endif
|
2011-05-23 17:18:52 +10:00
|
|
|
|
2012-05-25 15:30:28 +10:00
|
|
|
T x, y;
|
|
|
|
size_type w, h;
|
|
|
|
|
|
|
|
region (T _x, T _y, size_type _w, size_type _h);
|
2011-05-23 17:18:52 +10:00
|
|
|
|
2012-05-18 17:56:24 +10:00
|
|
|
region& operator +=(const vector<2>& rhs);
|
2011-10-26 21:43:55 +11:00
|
|
|
|
2012-05-25 15:30:28 +10:00
|
|
|
size_type area (void) const;
|
|
|
|
size_type diameter (void) const;
|
2013-07-30 23:51:55 +10:00
|
|
|
void scale (double factor);
|
2011-10-24 19:55:51 +11:00
|
|
|
|
2011-08-15 20:10:43 +10:00
|
|
|
bool empty (void) const;
|
2011-10-24 19:55:51 +11:00
|
|
|
|
2013-07-30 23:52:09 +10:00
|
|
|
point2 base (void) const;
|
|
|
|
point2 centre (void) const;
|
2011-10-17 17:20:17 +11:00
|
|
|
|
2013-07-30 23:52:09 +10:00
|
|
|
bool includes (const point2&) const; // inclusive of borders
|
|
|
|
bool contains (const point2&) const; // exclusive of borders
|
2012-05-03 15:59:01 +10:00
|
|
|
bool overlaps (const region<T>&) const; // exclusive of borders
|
2011-05-23 17:18:52 +10:00
|
|
|
|
2013-08-05 16:38:05 +10:00
|
|
|
void constrain (point2&) const;
|
|
|
|
point2 constrained (const point2&) const;
|
2013-07-30 23:52:09 +10:00
|
|
|
|
2012-05-11 12:22:23 +10:00
|
|
|
region overlap (const region<T>&) const;
|
|
|
|
|
2011-08-29 14:40:05 +10:00
|
|
|
bool operator ==(const region<T>& rhs) const;
|
|
|
|
bool operator !=(const region<T>& rhs) const
|
2011-08-15 20:10:43 +10:00
|
|
|
{ return !(*this == rhs); }
|
2011-05-23 17:18:52 +10:00
|
|
|
|
2012-06-15 16:38:57 +10:00
|
|
|
static const region<T> MAX;
|
|
|
|
static const region<T> UNIT;
|
|
|
|
|
2011-08-15 20:10:43 +10:00
|
|
|
void sanity (void) const;
|
2012-06-14 18:29:09 +10:00
|
|
|
|
|
|
|
#if 0
|
|
|
|
struct iterator {
|
|
|
|
T x, y;
|
|
|
|
T a;
|
|
|
|
size_type w, h;
|
|
|
|
|
|
|
|
iterator& operator++ (void);
|
|
|
|
iterator& operator* (void);
|
|
|
|
bool operator== (const iterator&) const;
|
|
|
|
bool operator!= (const iterator&) const;
|
|
|
|
};
|
|
|
|
|
|
|
|
iterator begin (void);
|
|
|
|
iterator end (void);
|
|
|
|
#endif
|
2011-08-15 20:10:43 +10:00
|
|
|
};
|
2012-06-13 14:41:53 +10:00
|
|
|
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
std::ostream& operator<< (std::ostream&, const util::region<T>&);
|
2011-08-15 20:10:43 +10:00
|
|
|
}
|
2011-05-23 17:18:52 +10:00
|
|
|
|
2011-10-20 23:53:30 +11:00
|
|
|
|
2011-05-23 17:18:52 +10:00
|
|
|
#endif
|