/* * Copyright (c) 2020-2021, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include #include #include namespace Gfx { template void Point::constrain(Rect const& rect) { m_x = AK::clamp(x(), rect.left(), rect.right() - 1); m_y = AK::clamp(y(), rect.top(), rect.bottom() - 1); } template [[nodiscard]] Point Point::end_point_for_aspect_ratio(Point const& previous_end_point, float aspect_ratio) const { VERIFY(aspect_ratio > 0); T const x_sign = previous_end_point.x() >= x() ? 1 : -1; T const y_sign = previous_end_point.y() >= y() ? 1 : -1; T dx = AK::abs(previous_end_point.x() - x()); T dy = AK::abs(previous_end_point.y() - y()); if (dx > dy) { dy = (T)((float)dx / aspect_ratio); } else { dx = (T)((float)dy * aspect_ratio); } return { x() + x_sign * dx, y() + y_sign * dy }; } template<> ByteString IntPoint::to_byte_string() const { return ByteString::formatted("[{},{}]", x(), y()); } template<> ByteString FloatPoint::to_byte_string() const { return ByteString::formatted("[{},{}]", x(), y()); } } namespace IPC { template<> ErrorOr encode(Encoder& encoder, Gfx::IntPoint const& point) { TRY(encoder.encode(point.x())); TRY(encoder.encode(point.y())); return {}; } template<> ErrorOr encode(Encoder& encoder, Gfx::FloatPoint const& point) { TRY(encoder.encode(point.x())); TRY(encoder.encode(point.y())); return {}; } template<> ErrorOr decode(Decoder& decoder) { auto x = TRY(decoder.decode()); auto y = TRY(decoder.decode()); return Gfx::IntPoint { x, y }; } template<> ErrorOr decode(Decoder& decoder) { auto x = TRY(decoder.decode()); auto y = TRY(decoder.decode()); return Gfx::FloatPoint { x, y }; } } template class Gfx::Point; template class Gfx::Point;