/*! \file piline.h * \ingroup Math * \brief * \~english Two-dimensional line class * \~russian Класс отрезка двумерной линии */ /* PIP - Platform Independent Primitives Two-dimensional line class Ivan Pelipenko peri4ko@yandex.ru, Andrey Bychkov work.a.b@yandex.ru This program 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. This program 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 this program. If not, see . */ #ifndef PILINE_H #define PILINE_H #include "pipoint.h" /*! \brief * \~english Two-dimensional line class * \~russian Класс отрезка двумерной линии * \~\details * \~russian * Этот класс описывает линию на плоскости в прямоугольной системе координат */ template class PIP_EXPORT PILine { static_assert(std::is_arithmetic::value, "Type must be arithmetic"); public: PIPoint p0; PIPoint p1; //! \~russian //! Пустой конструктор. //! \details //! При выполнении пустого конструктора координаты не изменяются. //! Начало и конец совпадают. PILine() {} //! \~russian //! Создает линию по двум принятым точкам \a PIPoint начала и конца. PILine(const PIPoint & p0_, const PIPoint & p1_) { p0 = p0_; p1 = p1_; } //! \~russian //! Создает линию по принятым координатам начала и конца. PILine(Type x0, Type y0, Type x1, Type y1) { p0.set(x0, y0); p1.set(x1, y1); } //! \~russian //! Задать новые координаты начала и конца по двум принятым точкам \a PIPoint. PILine & set(const PIPoint & p0_, const PIPoint & p1_) { p0 = p0_; p1 = p1_; return *this; } //! \~russian //! Задать новые координаты начала и конца. PILine & set(Type x0, Type y0, Type x1, Type y1) { p0.set(x0, y0); p1.set(x1, y1); return *this; } //! \~russian //! Проверить на совпадение координат начала и конца. bool isEmpty() const { return (p0 == p1); } //! \~russian //! Вычислить ширину прямоугольника, диагональю которого является данный отрезок. Type width() const {return piAbs(p1.x - p0.x);} //! \~russian //! Вычислить высоту прямоугольника, диагональю которого является данный отрезок. Type height() const {return piAbs(p1.y - p0.y);} //! \~russian //! Сдвинуть линию на \a x, \a y. PILine & translate(Type x, Type y) { p0.translate(x, y); p1.translate(x, y); return *this; } //! \~russian //! Сдвинуть линию на значение координат точки \a PIPoint. PILine & translate(const PIPoint & p) { p0.translate(p); p1.translate(p); return *this; } //! Создать копию отрезка и сдвинуть её на `x` и `y`. PILine translated(Type x, Type y) const { PILine l(*this); l.translate(x, y); return l; } //! \~russian //! Создать копию отрезка и сдвинуть её на значение координат точки \a PIPoint. PILine translated(const PIPoint & p) const { PILine l(*this); l.translate(p); return l; } //! \~russian //! Сдвинуть линию на \a x, \a y. //! \details Является копией метода \a translate(). PILine & move(Type x, Type y) {return translate(x, y);} //! \~russian //! Сдвинуть линию на значение координат точки \a PIPoint. //! \details Является копией метода \a translate(). PILine & move(const PIPoint & p) {return translate(p);} //! \~russian //! Создать копию отрезка и сдвинуть её на \a x, \a y. //! \details Является копией метода \a translated(). PILine moved(Type x, Type y) const { PILine l(*this); l.translate(x, y); return l; } //! \~russian //! Создать копию отрезка и сдвинуть её на значение координат точки \a PIPoint. //! \details Является копией метода \a translated(). PILine moved(const PIPoint & p) const { PILine l(*this); l.translate(p); return l; } //! \~russian Сдвинуть линию по двум координатам на значение \a x. void operator +=(Type x) {translate(x, x);} //! \~russian Сдвинуть линию по двум координатам на величину координат точки \a PIPoint. void operator +=(const PIPoint & p) {translate(p);} //! \~russian Сдвинуть линию по двум координатам на значение \a x. void operator -=(Type x) {translate(-x, -x);} //! \~russian Сдвинуть линию по двум координатам на величину координат точки \a PIPoint. void operator -=(const PIPoint & p) {translate(-p);} //! \~russian Сдвинуть линию по двум координатам на величину координат точки \a PIPoint. PILine operator +(const PIPoint & p) {return translated(p);} //! \~russian Сдвинуть линию по двум координатам на величину координат точки \a PIPoint. PILine operator -(const PIPoint & p) {return translated(-p);} //! \~russian Проверить равенство координат двух отрезков. bool operator ==(const PILine & r) const {return (p0 == r.p0 && p1 == r.p1);} //! \~russian Проверить неравенство координат двух отрезков. bool operator !=(const PILine & r) const {return (p1 != r.p1 || p1 != r.p1);} }; //! \~russian Перегруженный оператор для вывода координат в \a PICout. template PICout operator <<(PICout & s, const PILine & v) { s.saveAndSetControls(0); s << "Line{" << v.p0 << ", " << v.p1 << "}"; s.restoreControls(); return s; } typedef PILine PILinei; typedef PILine PILineu; typedef PILine PILinef; typedef PILine PILined; #endif // PILINE_H