/*! \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