Visual Servoing Platform
version 3.5.1 under development (2023-09-22)
|
#include <visp3/core/vpRect.h>
Public Member Functions | |
vpRect () | |
vpRect (double left, double top, double width, double height) | |
vpRect (const vpImagePoint &topLeft, double width, double height) | |
vpRect (const vpImagePoint &topLeft, const vpImagePoint &bottomRight) | |
vpRect (const vpRect &r) | |
vpRect (const std::vector< vpImagePoint > &ip) | |
double | getArea () const |
double | getBottom () const |
vpImagePoint | getBottomLeft () const |
vpImagePoint | getBottomRight () const |
void | getCenter (double &x, double &y) const |
vpImagePoint | getCenter () const |
double | getHeight () const |
double | getLeft () const |
double | getRight () const |
double | getSize () const |
double | getTop () const |
vpImagePoint | getTopLeft () const |
vpImagePoint | getTopRight () const |
double | getWidth () const |
bool | isInside (const vpImagePoint &ip) const |
bool | operator== (const vpRect &r) const |
bool | operator!= (const vpRect &r) const |
vpRect & | operator&= (const vpRect &r) |
vpRect & | operator= (const vpRect &r) |
vpRect | operator& (const vpRect &r) const |
void | set (double left, double top, double width, double height) |
void | set (const vpImagePoint &topLeft, double width, double height) |
void | set (const vpImagePoint &topLeft, const vpImagePoint &bottomRight) |
void | set (const vpRect &r) |
void | set (const std::vector< vpImagePoint > &ip) |
void | setBottom (double pos) |
void | setBottomRight (const vpImagePoint &bottomRight) |
void | setHeight (double h) |
void | setLeft (double pos) |
void | setRect (double l, double t, double w, double h) |
void | setRight (double pos) |
void | setTop (double pos) |
void | setTopLeft (const vpImagePoint &topLeft) |
void | setWidth (double w) |
void | moveCenter (double x, double y) |
void | moveCenter (const vpImagePoint ¢er) |
Friends | |
VISP_EXPORT bool | inRectangle (const vpImagePoint &ip, const vpRect &rect) |
VISP_EXPORT std::ostream & | operator<< (std::ostream &os, const vpRect &r) |
Defines a rectangle in the plane.
A rectangle is internally represented as an upper-left corner and a width and height, but it is normally expressed as an upper-left corner and bottom-right corner.
Note that the size (width and height) of a rectangle might be different from what you are used to. If the top-left corner and the bottom-right corner are the same, the height and the width of the rectangle will both be 1.
Generally, width = right - left + 1 and height = bottom - top + 1.
We designed it this way to make it correspond to rectangular spaces used by drawing functions in which the width and height denote a number of pixels. For example, drawing a rectangle with width and height 1 draws a single pixel.
The default coordinate system has origin (0, 0) in the top-left corner. The positive direction of the y axis is down, and the positive x axis is from left to right.
A vpRect can be constructed with a set of left, top, width and height double. After creation the dimensions can be changed, e.g. with setLeft(), setRight(), setTop() and setBottom(), or by setting sizes, e.g. setWidth(), setHeight()
vpRect::vpRect | ( | ) |
Constructs a default rectangle with the top, left corner set to (0,0) and width and height set to 1.
Definition at line 51 of file vpRect.cpp.
vpRect::vpRect | ( | double | l, |
double | t, | ||
double | w, | ||
double | h | ||
) |
Constructs a rectangle with the top, left corner and width and height.
l | : coordinate of the top/left corner along the horizontal axis. |
t | : coordinate of the top/left corner along the vertical axis. |
w | : rectangle width. |
h | : rectangle height. |
Definition at line 62 of file vpRect.cpp.
vpRect::vpRect | ( | const vpImagePoint & | topLeft, |
double | w, | ||
double | h | ||
) |
Constructs a rectangle with topLeft the top-left corner location and width and height the rectangle size.
topLeft | : coordinates of the top/left corner. |
w | : rectangle width. |
h | : rectangle height. |
Definition at line 72 of file vpRect.cpp.
vpRect::vpRect | ( | const vpImagePoint & | topLeft, |
const vpImagePoint & | bottomRight | ||
) |
Constructs a rectangle with topLeft the top-left corner location and bottomRight the bottom-right corner.
Definition at line 81 of file vpRect.cpp.
References vpImagePoint::get_u(), vpImagePoint::get_v(), setBottom(), and setRight().
vpRect::vpRect | ( | const vpRect & | r | ) |
Constructs a rectangle that is a copy of r.
Definition at line 94 of file vpRect.cpp.
|
explicit |
Create a rectangle as the bounding box of a vector of image points.
ip | : Vector of image points. At least 1 points is mandatory, otherwise an exception is thrown. |
Definition at line 114 of file vpRect.cpp.
References set().
|
inline |
Returns the area of the rectangle.
Definition at line 88 of file vpRect.h.
Referenced by vpDetectorDNNOpenCV::filterDetectionMultiClassInput().
|
inline |
Returns the bottom coordinate of the rectangle.
Definition at line 94 of file vpRect.h.
Referenced by vpMbtFaceDepthDense::computeDesiredFeatures(), vpMbtFaceDepthNormal::computeDesiredFeatures(), vpPose::computePlanarObjectPoseFromRGBD(), vpKeyPoint::detect(), vpDisplayOpenCV::displayRectangle(), vpImageSimulator::getImage(), vpImagePoint::inRectangle(), and vpDot2::searchDotsInArea().
|
inline |
Returns the bottom-left position of the rectangle.
Definition at line 101 of file vpRect.h.
References vpImagePoint::set_u(), and vpImagePoint::set_v().
|
inline |
Returns the bottom-right coordinate of the rectangle.
Definition at line 114 of file vpRect.h.
References vpImagePoint::set_u(), and vpImagePoint::set_v().
|
inline |
Returns the center point of the rectangle. The center point coordinates are (x, y).
The default coordinate system has origin (0, 0) in the top-left corner. The positive direction of the y axis is down, and the positive x axis is from left to right.
Definition at line 149 of file vpRect.h.
References vpImagePoint::set_u(), and vpImagePoint::set_v().
|
inline |
Returns the center point of the rectangle. The center point coordinates are (x, y).
The default coordinate system has origin (0, 0) in the top-left corner. The positive direction of the y axis is down, and the positive x axis is from left to right.
Definition at line 133 of file vpRect.h.
Referenced by vpRectOriented::operator=(), and vpRectOriented::vpRectOriented().
|
inline |
Returns the height of the rectangle. The height includes both the top and bottom edges, i.e. height = bottom - top + 1.
Definition at line 163 of file vpRect.h.
Referenced by vpV4l2Grabber::acquire(), vpMbtFaceDepthDense::computeDesiredFeatures(), vpMbtFaceDepthNormal::computeDesiredFeatures(), vpImageTools::crop(), vpKeyPoint::detect(), vpDisplayWin32::displayRectangle(), vpDisplayX::displayRectangle(), vpRectOriented::operator=(), and vpRectOriented::vpRectOriented().
|
inline |
Returns the left coordinate of the rectangle.
Definition at line 170 of file vpRect.h.
Referenced by vpV4l2Grabber::acquire(), vpMbtFaceDepthDense::computeDesiredFeatures(), vpMbtFaceDepthNormal::computeDesiredFeatures(), vpPose::computePlanarObjectPoseFromRGBD(), vpImageTools::crop(), vpKeyPoint::detect(), vpDisplayOpenCV::displayRectangle(), vpDisplayWin32::displayRectangle(), vpImageSimulator::getImage(), vpImagePoint::inRectangle(), and vpDot2::searchDotsInArea().
|
inline |
Returns the right coordinate of the rectangle.
Definition at line 176 of file vpRect.h.
Referenced by vpMbtFaceDepthDense::computeDesiredFeatures(), vpMbtFaceDepthNormal::computeDesiredFeatures(), vpPose::computePlanarObjectPoseFromRGBD(), vpKeyPoint::detect(), vpDisplayGTK::displayRectangle(), vpDisplayOpenCV::displayRectangle(), vpImageSimulator::getImage(), vpImagePoint::inRectangle(), and vpDot2::searchDotsInArea().
|
inline |
Returns the size of the rectangle.
|
inline |
Returns the top coordinate of the rectangle.
Definition at line 189 of file vpRect.h.
Referenced by vpV4l2Grabber::acquire(), vpMbtFaceDepthDense::computeDesiredFeatures(), vpMbtFaceDepthNormal::computeDesiredFeatures(), vpPose::computePlanarObjectPoseFromRGBD(), vpImageTools::crop(), vpKeyPoint::detect(), vpDisplayOpenCV::displayRectangle(), vpDisplayWin32::displayRectangle(), vpImageSimulator::getImage(), vpImagePoint::inRectangle(), and vpDot2::searchDotsInArea().
|
inline |
Returns the top-left position of the rectangle.
Definition at line 196 of file vpRect.h.
References vpImagePoint::set_u(), and vpImagePoint::set_v().
Referenced by vpDisplayGTK::displayRectangle(), and vpDisplayX::displayRectangle().
|
inline |
Returns the top-right position of the rectangle.
Definition at line 209 of file vpRect.h.
References vpImagePoint::set_u(), and vpImagePoint::set_v().
Referenced by vpDetectorDNNOpenCV::DetectedFeatures2D::display().
|
inline |
Returns the width of the rectangle. The width includes both the left and right edges, i.e. width = right - left + 1.
Definition at line 224 of file vpRect.h.
Referenced by vpV4l2Grabber::acquire(), vpMbtFaceDepthDense::computeDesiredFeatures(), vpMbtFaceDepthNormal::computeDesiredFeatures(), vpImageTools::crop(), vpKeyPoint::detect(), vpDisplayGTK::displayRectangle(), vpDisplayWin32::displayRectangle(), vpDisplayX::displayRectangle(), vpRectOriented::operator=(), and vpRectOriented::vpRectOriented().
bool vpRect::isInside | ( | const vpImagePoint & | ip | ) | const |
Returns true if the point belongs to the rectangle.
Check if an image point belongs to the rectangle.
ip | : the image point. |
Definition at line 123 of file vpRect.cpp.
References vpImagePoint::get_i(), and vpImagePoint::get_j().
|
inline |
Center the rectangle to the image point given as parameter, leaving the size unchanged.
Definition at line 399 of file vpRect.h.
References vpImagePoint::get_u(), and vpImagePoint::get_v().
|
inline |
Sets the center point of the rectangle to (x, y), leaving the size unchanged.
bool vpRect::operator!= | ( | const vpRect & | r | ) | const |
Operator to compare two rectangles.
Definition at line 233 of file vpRect.cpp.
Assign r to this rectangle and return a reference to this rectangle.
Definition at line 100 of file vpRect.cpp.
bool vpRect::operator== | ( | const vpRect & | r | ) | const |
Operator to compare two rectangles.
Definition at line 219 of file vpRect.cpp.
void vpRect::set | ( | const std::vector< vpImagePoint > & | ip | ) |
Set the rectangle as the bounding box of a vector of image points.
ip | : Vector of image points. At least 1 points is mandatory, otherwise an exception is thrown. |
Definition at line 166 of file vpRect.cpp.
References vpException::dimensionError, setBottom(), setLeft(), setRight(), and setTop().
void vpRect::set | ( | const vpImagePoint & | topLeft, |
const vpImagePoint & | bottomRight | ||
) |
Set the rectangle with topLeft the top-left corner location and bottomRight the bottom-right corner.
topLeft | : coordinates of the top-left corner. |
bottomRight | : coordinates of the bottom-right corner. |
Definition at line 201 of file vpRect.cpp.
References vpImagePoint::get_u(), vpImagePoint::get_v(), setBottom(), and setRight().
void vpRect::set | ( | const vpImagePoint & | topLeft, |
double | w, | ||
double | h | ||
) |
Set the rectangle with topLeft the top-left corner location and width and height the rectangle size.
topLeft | : coordinates of the top-left corner. |
w | : rectangle width. |
h | : rectangle height. |
Definition at line 153 of file vpRect.cpp.
References vpImagePoint::get_u(), and vpImagePoint::get_v().
void vpRect::set | ( | const vpRect & | r | ) |
Set the rectangle from r.
Definition at line 213 of file vpRect.cpp.
void vpRect::set | ( | double | l, |
double | t, | ||
double | w, | ||
double | h | ||
) |
Set the rectangle with the top, left corner and width and height.
l | : coordinate of the top/left corner along the horizontal axis. |
t | : coordinate of the top/left corner along the vertical axis. |
w | : rectangle width. |
h | : rectangle height. |
Definition at line 137 of file vpRect.cpp.
Referenced by vpRect().
|
inline |
Sets the bottom edge position of the rectangle to pos. May change the height of the rectangle, but will never change the top edge position the rectangle.
Definition at line 285 of file vpRect.h.
Referenced by vpMbtFaceDepthDense::computeDesiredFeatures(), vpMbtFaceDepthNormal::computeDesiredFeatures(), set(), and vpRect().
|
inline |
Sets the bottom-right position of the rectangle. Will never change the top-left position the rectangle.
Definition at line 293 of file vpRect.h.
References vpImagePoint::get_u(), and vpImagePoint::get_v().
Referenced by vpTemplateTrackerZone::getBoundingBox(), and vpPolygon::updateBoundingBox().
|
inline |
Sets the height of the rectangle to h. The top edge is not moved, but the bottom edge may be moved.
|
inline |
Sets the left edge position of the rectangle to pos. May change the right edge position of the rectangle, but will never change the width of the rectangle.
Definition at line 318 of file vpRect.h.
Referenced by vpMbtFaceDepthDense::computeDesiredFeatures(), vpMbtFaceDepthNormal::computeDesiredFeatures(), and set().
|
inline |
Sets the coordinates of the rectangle's top left corner to (left, top), and its size to (width, height).
l | : horizontal position of the rectangle upper/left corner position. |
t | : vertical position of the rectangle upper/left corner position. |
w | : rectangle width. |
h | : rectangle height. |
Definition at line 330 of file vpRect.h.
Referenced by vpDot::getBBox(), and vpDot2::getBBox().
|
inline |
Sets the right edge position of the rectangle to pos. May change the width of the rectangle, but will never change the left edge position of the rectangle.
Definition at line 345 of file vpRect.h.
Referenced by vpMbtFaceDepthDense::computeDesiredFeatures(), vpMbtFaceDepthNormal::computeDesiredFeatures(), set(), and vpRect().
|
inline |
Sets the top edge position of the rectangle to pos. May change the bottom edge position of the rectangle, but will never change the height of the rectangle.
Definition at line 354 of file vpRect.h.
Referenced by vpMbtFaceDepthDense::computeDesiredFeatures(), vpMbtFaceDepthNormal::computeDesiredFeatures(), and set().
|
inline |
Sets the top-left position of the rectangle. May change the bottom edge position of the rectangle, but will never change the height of the rectangle.
Definition at line 363 of file vpRect.h.
References vpImagePoint::get_u(), and vpImagePoint::get_v().
Referenced by vpTemplateTrackerZone::getBoundingBox(), and vpPolygon::updateBoundingBox().
|
inline |
Sets the width of the rectangle to w. The right edge is changed, but not the left edge.
|
friend |
Check if an image point belongs to a rectangle.
ip | : the image point. |
rect | : the rectangle. |
Definition at line 256 of file vpRect.cpp.
|
friend |
Definition at line 262 of file vpRect.cpp.