/*! @file @author Albert Semenov @date 11/2007 */ /* This file is part of MyGUI. MyGUI is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. MyGUI is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with MyGUI. If not, see . */ #ifndef __MYGUI_TRECT_H__ #define __MYGUI_TRECT_H__ #include "MyGUI_Prerequest.h" namespace MyGUI { namespace types { template struct TRect { T left; T top; T right; T bottom; TRect() : left(0), top(0), right(0), bottom(0) { } TRect(T const& _left, T const& _top, T const& _right, T const& _bottom) : left(_left), top(_top), right(_right), bottom(_bottom) { } TRect(TRect const& _obj) : left(_obj.left), top(_obj.top), right(_obj.right), bottom(_obj.bottom) { } TRect& operator -= (TRect const& _obj) { left -= _obj.left; top -= _obj.top; right -= _obj.right; bottom -= _obj.bottom; return *this; } TRect& operator += (TRect const& _obj) { left += _obj.left; top += _obj.top; right += _obj.right; bottom += _obj.bottom; return *this; } TRect operator - (TRect const& _obj) const { return TRect(left - _obj.left, top - _obj.top, right - _obj.right, bottom - _obj.bottom); } TRect operator + (TRect const& _obj) const { return TRect(left + _obj.left, top + _obj.top, right + _obj.right, bottom + _obj.bottom); } TRect& operator = (TRect const& _obj) { left = _obj.left; top = _obj.top; right = _obj.right; bottom = _obj.bottom; return *this; } template TRect& operator = (TRect const& _obj) { left = _obj.left; top = _obj.top; right = _obj.right; bottom = _obj.bottom; return *this; } bool operator == (TRect const& _obj) const { return ((left == _obj.left) && (top == _obj.top) && (right == _obj.right) && (bottom == _obj.bottom)); } bool operator != (TRect const& _obj) const { return !((left == _obj.left) && (top == _obj.top) && (right == _obj.right) && (bottom == _obj.bottom)); } T width() const { return right - left; } T height() const { return bottom - top; } void clear() { left = top = right = bottom = 0; } void set(T const& _left, T const& _top, T const& _right, T const& _bottom) { left = _left; top = _top; right = _right; bottom = _bottom; } void swap(TRect& _value) { TRect tmp = _value; _value = *this; *this = tmp; } bool empty() const { return ((left == 0) && (top == 0) && (right == 0) && (bottom == 0)); } bool inside(const TRect& _value) const { return ((_value.left >= left) && (_value.right <= right) && (_value.top >= top) && (_value.bottom <= bottom)); } bool intersect(const TRect& _value) const { return ((_value.left <= right) && (_value.right >= left) && (_value.top <= bottom) && (_value.bottom >= top)); } bool inside(const TPoint& _value) const { return ((_value.left >= left) && (_value.left <= right) && (_value.top >= top) && (_value.top <= bottom)); } std::string print() const { std::ostringstream stream; stream << *this; return stream.str(); } static TRect parse(const std::string& _value) { TRect result; std::istringstream stream(_value); stream >> result.left >> result.top >> result.right >> result.bottom; if (stream.fail()) { return TRect(); } else { int item = stream.get(); while (item != -1) { if (item != ' ' && item != '\t') return TRect(); item = stream.get(); } } return result; } friend std::ostream& operator << (std::ostream& _stream, const TRect& _value) { _stream << _value.left << " " << _value.top << " " << _value.right << " " << _value.bottom; return _stream; } friend std::istream& operator >> (std::istream& _stream, TRect& _value) { _stream >> _value.left >> _value.top >> _value.right >> _value.bottom; if (_stream.fail()) _value.clear(); return _stream; } }; } // namespace types } // namespace MyGUI #endif // __MYGUI_TRECT_H__