2020-02-15 00:58:14 +01:00
|
|
|
/*
|
2024-10-04 13:19:50 +02:00
|
|
|
* Copyright (c) 2020-2021, Andreas Kling <andreas@ladybird.org>
|
2020-02-15 00:58:14 +01:00
|
|
|
*
|
2021-04-22 01:24:48 -07:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-02-15 00:58:14 +01:00
|
|
|
*/
|
|
|
|
|
2023-12-16 17:49:34 +03:30
|
|
|
#include <AK/ByteString.h>
|
2020-02-15 00:58:14 +01:00
|
|
|
#include <LibGfx/Point.h>
|
2020-07-25 21:31:47 -07:00
|
|
|
#include <LibGfx/Rect.h>
|
2020-03-29 19:03:13 +02:00
|
|
|
#include <LibIPC/Decoder.h>
|
2020-05-12 18:05:43 +02:00
|
|
|
#include <LibIPC/Encoder.h>
|
2020-02-15 00:58:14 +01:00
|
|
|
|
|
|
|
namespace Gfx {
|
|
|
|
|
2020-07-25 21:31:47 -07:00
|
|
|
template<typename T>
|
2021-06-16 19:24:27 +02:00
|
|
|
void Point<T>::constrain(Rect<T> const& rect)
|
2020-07-21 23:46:15 -07:00
|
|
|
{
|
2023-05-22 00:41:18 +02:00
|
|
|
m_x = AK::clamp<T>(x(), rect.left(), rect.right() - 1);
|
|
|
|
m_y = AK::clamp<T>(y(), rect.top(), rect.bottom() - 1);
|
2020-07-21 23:46:15 -07:00
|
|
|
}
|
|
|
|
|
2021-08-24 23:39:07 +02:00
|
|
|
template<typename T>
|
2021-09-15 19:34:50 -04:00
|
|
|
[[nodiscard]] Point<T> Point<T>::end_point_for_aspect_ratio(Point<T> const& previous_end_point, float aspect_ratio) const
|
2021-08-24 23:39:07 +02:00
|
|
|
{
|
2021-09-15 19:34:50 -04:00
|
|
|
VERIFY(aspect_ratio > 0);
|
2024-04-18 15:32:56 -04:00
|
|
|
T const x_sign = previous_end_point.x() >= x() ? 1 : -1;
|
|
|
|
T const y_sign = previous_end_point.y() >= y() ? 1 : -1;
|
2021-09-15 19:34:50 -04:00
|
|
|
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 };
|
2021-08-24 23:39:07 +02:00
|
|
|
}
|
|
|
|
|
2020-07-25 21:31:47 -07:00
|
|
|
template<>
|
2023-12-16 17:49:34 +03:30
|
|
|
ByteString IntPoint::to_byte_string() const
|
2020-02-15 00:58:14 +01:00
|
|
|
{
|
2023-12-16 17:49:34 +03:30
|
|
|
return ByteString::formatted("[{},{}]", x(), y());
|
2020-02-15 00:58:14 +01:00
|
|
|
}
|
|
|
|
|
2020-07-25 21:31:47 -07:00
|
|
|
template<>
|
2023-12-16 17:49:34 +03:30
|
|
|
ByteString FloatPoint::to_byte_string() const
|
2020-02-15 00:58:14 +01:00
|
|
|
{
|
2023-12-16 17:49:34 +03:30
|
|
|
return ByteString::formatted("[{},{}]", x(), y());
|
2020-02-15 00:58:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2020-02-15 12:04:35 +01:00
|
|
|
|
|
|
|
namespace IPC {
|
|
|
|
|
2024-04-13 01:21:20 -04:00
|
|
|
template<>
|
|
|
|
ErrorOr<void> encode(Encoder& encoder, Gfx::IntPoint const& point)
|
2020-05-12 18:05:43 +02:00
|
|
|
{
|
2023-01-01 23:37:35 -05:00
|
|
|
TRY(encoder.encode(point.x()));
|
|
|
|
TRY(encoder.encode(point.y()));
|
|
|
|
return {};
|
2020-05-12 18:05:43 +02:00
|
|
|
}
|
|
|
|
|
2024-04-13 01:21:20 -04:00
|
|
|
template<>
|
|
|
|
ErrorOr<void> encode(Encoder& encoder, Gfx::FloatPoint const& point)
|
|
|
|
{
|
|
|
|
TRY(encoder.encode(point.x()));
|
|
|
|
TRY(encoder.encode(point.y()));
|
|
|
|
return {};
|
|
|
|
}
|
2024-02-14 01:07:55 -05:00
|
|
|
|
2022-11-15 11:24:59 -05:00
|
|
|
template<>
|
2022-12-22 20:40:33 -05:00
|
|
|
ErrorOr<Gfx::IntPoint> decode(Decoder& decoder)
|
2020-02-15 12:04:35 +01:00
|
|
|
{
|
2022-12-22 20:40:33 -05:00
|
|
|
auto x = TRY(decoder.decode<int>());
|
|
|
|
auto y = TRY(decoder.decode<int>());
|
|
|
|
return Gfx::IntPoint { x, y };
|
2020-02-15 12:04:35 +01:00
|
|
|
}
|
|
|
|
|
2024-02-14 01:07:55 -05:00
|
|
|
template<>
|
|
|
|
ErrorOr<Gfx::FloatPoint> decode(Decoder& decoder)
|
|
|
|
{
|
|
|
|
auto x = TRY(decoder.decode<float>());
|
|
|
|
auto y = TRY(decoder.decode<float>());
|
|
|
|
return Gfx::FloatPoint { x, y };
|
|
|
|
}
|
|
|
|
|
2020-02-15 12:04:35 +01:00
|
|
|
}
|
2020-07-25 21:31:47 -07:00
|
|
|
|
|
|
|
template class Gfx::Point<int>;
|
|
|
|
template class Gfx::Point<float>;
|