2023-08-03 10:19:45 +00:00
|
|
|
#pragma once
|
|
|
|
#include <ui/Point.h>
|
|
|
|
|
|
|
|
namespace ui
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @brief A simple rectangle.
|
|
|
|
*/
|
|
|
|
struct Rect
|
|
|
|
{
|
2023-08-03 15:38:49 +00:00
|
|
|
Point pos;
|
2023-08-03 10:19:45 +00:00
|
|
|
int width;
|
|
|
|
int height;
|
|
|
|
|
2023-08-03 15:38:49 +00:00
|
|
|
/**
|
|
|
|
* @brief Check if a point is contained in this rectangle.
|
|
|
|
*
|
|
|
|
* @param point The point to check.
|
|
|
|
* @return true The point is contained inside the rectangle.
|
|
|
|
* @return false The point is not contained inside the rectangle.
|
|
|
|
*/
|
2023-08-03 10:19:45 +00:00
|
|
|
bool contains(Point point);
|
2023-08-03 15:38:49 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Normalize a point to fit inside this rectangle.
|
|
|
|
*
|
|
|
|
* @param point The original point.
|
|
|
|
* @return Point The normalized point.
|
|
|
|
*/
|
2023-08-03 10:19:45 +00:00
|
|
|
Point normalize(Point point);
|
2023-08-03 15:38:49 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return a copy of this rectangle with no negative values (normalized to 0).
|
|
|
|
*
|
|
|
|
* @return Rect The new rectangle.
|
|
|
|
*/
|
|
|
|
Rect absolute();
|
2023-08-03 10:19:45 +00:00
|
|
|
};
|
|
|
|
}
|