Utility class for manipulating 2D axis aligned rectangles. More...
#include <SFML/Graphics/Rect.hpp>
| Public Member Functions | |
| constexpr | Rect ()=default | 
| Default constructor. | |
| constexpr | Rect (Vector2< T > position, Vector2< T > size) | 
| Construct the rectangle from position and size. | |
| template<typename U> | |
| constexpr | operator Rect< U > () const | 
| Converts the rectangle to another type of rectangle. | |
| constexpr bool | contains (Vector2< T > point) const | 
| Check if a point is inside the rectangle's area. | |
| constexpr std::optional< Rect< T > > | findIntersection (const Rect< T > &rectangle) const | 
| Check the intersection between two rectangles. | |
| constexpr Vector2< T > | getCenter () const | 
| Get the position of the center of the rectangle. | |
| Public Attributes | |
| Vector2< T > | position {} | 
| Position of the top-left corner of the rectangle. | |
| Vector2< T > | size {} | 
| Size of the rectangle. | |
| Related Symbols | |
| (Note that these are not member symbols.) | |
| template<typename T> | |
| constexpr bool | operator== (const Rect< T > &lhs, const Rect< T > &rhs) | 
| Overload of binary operator== | |
| template<typename T> | |
| constexpr bool | operator!= (const Rect< T > &lhs, const Rect< T > &rhs) | 
| Overload of binary operator!= | |
Detailed Description
class sf::Rect< T >
Utility class for manipulating 2D axis aligned rectangles.
A rectangle is defined by its top-left corner and its size.
It is a very simple class defined for convenience, so its member variables (position and size) are public and can be accessed directly, just like the vector classes (Vector2 and Vector3).
To keep things simple, sf::Rect doesn't define functions to emulate the properties that are not directly members (such as right, bottom, etc.), it rather only provides intersection functions.
sf::Rect uses the usual rules for its boundaries: 
- The left and top edges are included in the rectangle's area
- The right and bottom edges are excluded from the rectangle's area
This means that sf::IntRect({0, 0}, {1, 1}) and sf::IntRect({1, 1}, {1, 1}) don't intersect.
sf::Rect is a template and may be used with any numeric type, but for simplicity type aliases for the instantiations used by SFML are given: 
- sf::Rect<int>is- sf::IntRect
- sf::Rect<float>is- sf::FloatRect
So that you don't have to care about the template syntax.
Usage example:
Constructor & Destructor Documentation
◆ Rect() [1/2]
| 
 | constexprdefault | 
Default constructor.
Creates an empty rectangle (it is equivalent to calling Rect({0, 0}, {0, 0})). 
◆ Rect() [2/2]
Construct the rectangle from position and size.
Be careful, the last parameter is the size, not the bottom-right corner!
- Parameters
- 
  position Position of the top-left corner of the rectangle size Size of the rectangle 
Member Function Documentation
◆ contains()
Check if a point is inside the rectangle's area.
This check is non-inclusive. If the point lies on the edge of the rectangle, this function will return false.
- Parameters
- 
  point Point to test 
- Returns
- trueif the point is inside,- falseotherwise
- See also
- findIntersection
◆ findIntersection()
| 
 | nodiscardconstexpr | 
Check the intersection between two rectangles.
- Parameters
- 
  rectangle Rectangle to test 
- Returns
- Intersection rectangle if intersecting, std::nulloptotherwise
- See also
- contains
◆ getCenter()
Get the position of the center of the rectangle.
- Returns
- Center of rectangle
◆ operator Rect< U >()
| 
 | explicitconstexpr | 
Converts the rectangle to another type of rectangle.
Friends And Related Symbol Documentation
◆ operator!=()
Overload of binary operator!= 
This operator compares strict difference between two rectangles.
- Parameters
- 
  lhs Left operand (a rectangle) rhs Right operand (a rectangle) 
- Returns
- trueif lhs is not equal to rhs
◆ operator==()
Overload of binary operator== 
This operator compares strict equality between two rectangles.
- Parameters
- 
  lhs Left operand (a rectangle) rhs Right operand (a rectangle) 
- Returns
- trueif lhs is equal to rhs
Member Data Documentation
◆ position
◆ size
The documentation for this class was generated from the following file: