ViSP
2.8.0
|
#include <vpImageSimulator.h>
Public Types | |
enum | vpColorPlan { COLORED, GRAY_SCALED } |
enum | vpInterpolationType { SIMPLE, BILINEAR_INTERPOLATION } |
Public Member Functions | |
vpImageSimulator (const vpColorPlan &col=COLORED) | |
vpImageSimulator (const vpImageSimulator &text) | |
virtual | ~vpImageSimulator () |
vpImageSimulator & | operator= (const vpImageSimulator &sim) |
void | init (const vpImage< unsigned char > &I, vpColVector *_X) |
void | init (const vpImage< vpRGBa > &I, vpColVector *_X) |
void | init (const char *file_image, vpColVector *_X) |
void | init (const vpImage< unsigned char > &I, const std::vector< vpPoint > &_X) |
void | init (const vpImage< vpRGBa > &I, const std::vector< vpPoint > &_X) |
void | init (const char *file_image, const std::vector< vpPoint > &_X) |
void | setCameraPosition (const vpHomogeneousMatrix &_cMt) |
void | setInterpolationType (const vpInterpolationType interp) |
void | getImage (vpImage< unsigned char > &I, const vpCameraParameters &cam) |
void | getImage (vpImage< vpRGBa > &I, const vpCameraParameters &cam) |
void | getImage (vpImage< unsigned char > &I, vpImage< unsigned char > &Isrc, const vpCameraParameters &cam) |
void | getImage (vpImage< vpRGBa > &I, vpImage< vpRGBa > &Isrc, const vpCameraParameters &cam) |
void | getImage (vpImage< unsigned char > &I, const vpCameraParameters &cam, vpMatrix &zBuffer) |
void | getImage (vpImage< vpRGBa > &I, const vpCameraParameters &cam, vpMatrix &zBuffer) |
void | setCleanPreviousImage (const bool &clean, const vpColor &color=vpColor::white) |
void | setBackGroundTexture (const vpImage< unsigned char > &Iback) |
Static Public Member Functions | |
static void | getImage (vpImage< unsigned char > &I, std::list< vpImageSimulator > &list, const vpCameraParameters &cam) |
static void | getImage (vpImage< vpRGBa > &I, std::list< vpImageSimulator > &list, const vpCameraParameters &cam) |
Deprecated functions | |
static vp_deprecated void | getImage (vpImage< unsigned char > &I, vpList< vpImageSimulator > &list, const vpCameraParameters &cam) |
static vp_deprecated void | getImage (vpImage< vpRGBa > &I, vpList< vpImageSimulator > &list, const vpCameraParameters &cam) |
Class which enables to project an image in the 3D space and get the view of a virtual camera.
The image is represented by a rectangular image whose corners coordinates are known in the 3D frame linked to the 3D rectangle.
The 3D rectangle is positionned relative to a virtual camera (represented by its intrinsic parameters). Indeed, the pose has to be given by the user of the class.
And finally, the view of the virtual camera is given by the geImage() method.
You can use a colored or a gray scaled image.
To avoid the aliasing especially when the camera is very near from the image plane, a bilinear interpolation can be done for every pixels which have to be filled in. By default this functionality is not used because it consumes lot of time.
The following example explain how to use the class.
Definition at line 140 of file vpImageSimulator.h.
Enumerator | |
---|---|
COLORED | |
GRAY_SCALED |
Definition at line 143 of file vpImageSimulator.h.
Enumerator | |
---|---|
SIMPLE | |
BILINEAR_INTERPOLATION |
Definition at line 148 of file vpImageSimulator.h.
vpImageSimulator::vpImageSimulator | ( | const vpColorPlan & | col = COLORED | ) |
Basic constructor.
You can choose if you want to use a colored or gray scaled image.
col | : Enable to choose the color space to use for the image which is projected. |
By default the class uses colored images.
Definition at line 61 of file vpImageSimulator.cpp.
References vpColVector::resize(), SIMPLE, and vpColor::white.
vpImageSimulator::vpImageSimulator | ( | const vpImageSimulator & | text | ) |
Copy constructor
Definition at line 99 of file vpImageSimulator.cpp.
References vpColVector::resize(), and setCameraPosition().
|
virtual |
Basic destructor.
Definition at line 144 of file vpImageSimulator.cpp.
void vpImageSimulator::getImage | ( | vpImage< unsigned char > & | I, |
const vpCameraParameters & | cam | ||
) |
Get the view of the virtual camera. Be careful, the image I is modified. The projected image is not added as an overlay!
I | : The image used to store the result. |
cam | : The parameters of the virtual camera. |
Definition at line 189 of file vpImageSimulator.cpp.
References vpRGBa::B, vpImage< Type >::bitmap, COLORED, vpPixelMeterConversion::convertPoint(), vpRGBa::G, vpRect::getBottom(), vpImage< Type >::getHeight(), vpRect::getLeft(), vpRect::getRight(), vpRect::getTop(), vpImage< Type >::getWidth(), GRAY_SCALED, vpRGBa::R, and vpImagePoint::set_ij().
Referenced by vpVirtualGrabber::acquire(), vpWireFrameSimulator::getExternalImage(), and vpWireFrameSimulator::getInternalImage().
void vpImageSimulator::getImage | ( | vpImage< vpRGBa > & | I, |
const vpCameraParameters & | cam | ||
) |
Get the view of the virtual camera. Be careful, the image I is modified. The projected image is not added as an overlay!
I | : The image used to store the result. |
cam | : The parameters of the virtual camera. |
Definition at line 402 of file vpImageSimulator.cpp.
References vpRGBa::B, vpImage< Type >::bitmap, COLORED, vpPixelMeterConversion::convertPoint(), vpRGBa::G, vpRect::getBottom(), vpImage< Type >::getHeight(), vpRect::getLeft(), vpRect::getRight(), vpRect::getTop(), vpImage< Type >::getWidth(), GRAY_SCALED, vpRGBa::R, and vpImagePoint::set_ij().
void vpImageSimulator::getImage | ( | vpImage< unsigned char > & | I, |
vpImage< unsigned char > & | Isrc, | ||
const vpCameraParameters & | cam | ||
) |
Get the view of the virtual camera. Be careful, the image I is modified. The projected image is not added as an overlay! In this method you specify directly the image which is projected.
I | : The image used to store the result. |
Isrc | : The image which is projected into . |
cam | : The parameters of the virtual camera. |
Definition at line 266 of file vpImageSimulator.cpp.
References vpRGBa::B, vpImage< Type >::bitmap, vpPixelMeterConversion::convertPoint(), vpRGBa::G, vpRect::getBottom(), vpImage< Type >::getHeight(), vpRect::getLeft(), vpRect::getRight(), vpRect::getTop(), vpImage< Type >::getWidth(), vpRGBa::R, and vpImagePoint::set_ij().
void vpImageSimulator::getImage | ( | vpImage< vpRGBa > & | I, |
vpImage< vpRGBa > & | Isrc, | ||
const vpCameraParameters & | cam | ||
) |
Get the view of the virtual camera. Be carefull, the image I is modified. The projected image is not added as an overlay! In this method you specify directly the image which is projected.
I | : The image used to store the result. |
Isrc | : The image which is projected into . |
cam | : The parameters of the virtual camera. |
Definition at line 473 of file vpImageSimulator.cpp.
References vpImage< Type >::bitmap, vpPixelMeterConversion::convertPoint(), vpRect::getBottom(), vpImage< Type >::getHeight(), vpRect::getLeft(), vpRect::getRight(), vpRect::getTop(), vpImage< Type >::getWidth(), and vpImagePoint::set_ij().
void vpImageSimulator::getImage | ( | vpImage< unsigned char > & | I, |
const vpCameraParameters & | cam, | ||
vpMatrix & | zBuffer | ||
) |
Get the view of the virtual camera. Be careful, the image I is modified. The projected image is not added as an overlay!
To take into account the projection of several images, a matrix is given as argument. This matrix contains the z coordinates of all the pixel of the image in the camera frame. During the projection, the pixels are updated if there is no other plan between the camera and the projected image. The matrix is updated in this case.
I | : The image used to store the result. |
cam | : The parameters of the virtual camera. |
zBuffer | : A matrix containing the z coordinates of the pixels of the image |
Definition at line 324 of file vpImageSimulator.cpp.
References vpRGBa::B, vpImage< Type >::bitmap, COLORED, vpPixelMeterConversion::convertPoint(), vpRGBa::G, vpRect::getBottom(), vpMatrix::getCols(), vpImage< Type >::getHeight(), vpRect::getLeft(), vpRect::getRight(), vpMatrix::getRows(), vpRect::getTop(), vpImage< Type >::getWidth(), GRAY_SCALED, vpMatrixException::incorrectMatrixSizeError, vpRGBa::R, and vpImagePoint::set_ij().
void vpImageSimulator::getImage | ( | vpImage< vpRGBa > & | I, |
const vpCameraParameters & | cam, | ||
vpMatrix & | zBuffer | ||
) |
Get the view of the virtual camera. Be carefull, the image I is modified. The projected image is not added as an overlay!
To take into account the projection of several images, a matrix is given as argument. This matrix contains the z coordinates of all the pixel of the image in the camera frame. During the projection, the pixels are updated if there is no other plan between the camera and the projected image. The matrix is updated in this case.
I | : The image used to store the result. |
cam | : The parameters of the virtual camera. |
zBuffer | : A matrix containing the z coordinates of the pixels of the image |
Definition at line 530 of file vpImageSimulator.cpp.
References vpRGBa::B, vpImage< Type >::bitmap, COLORED, vpPixelMeterConversion::convertPoint(), vpRGBa::G, vpRect::getBottom(), vpMatrix::getCols(), vpImage< Type >::getHeight(), vpRect::getLeft(), vpRect::getRight(), vpMatrix::getRows(), vpRect::getTop(), vpImage< Type >::getWidth(), GRAY_SCALED, vpMatrixException::incorrectMatrixSizeError, vpRGBa::R, and vpImagePoint::set_ij().
|
static |
Get the view of the virtual camera. Be careful, the image I is modified. The projected image is not added as an overlay! With this method, a list of image is projected into the image. Thus, you have to initialise a list of vpImageSimulator. Then you store them into a vpList. And finally with this method you project them into the image . The depth of the 3D scene is managed such as an image in foreground hides an image background.
The following example shows how to use the method:
I | : The image used to store the result |
list | : List of vpImageSimulator to project |
cam | : The parameters of the virtual camera |
Definition at line 1122 of file vpImageSimulator.cpp.
References vpRGBa::B, vpImage< Type >::bitmap, COLORED, vpPixelMeterConversion::convertPoint(), vpRGBa::G, vpRect::getBottom(), vpImage< Type >::getHeight(), vpRect::getLeft(), vpRect::getRight(), vpRect::getTop(), vpImage< Type >::getWidth(), GRAY_SCALED, vpRGBa::R, and vpImagePoint::set_ij().
|
static |
Get the view of the virtual camera. Be carefull, the image I is modified. The projected image is not added as an overlay!
With this method, a list of image is projected into the image. Thus, you have to initialise a list of vpImageSimulator. Then you store them into a vpList. And finally with this method you project them into the image . The depth of the 3D scene is managed such as an image in foreground hides an image background.
The following example shows how to use the method:
I | : The image used to store the result |
list | : List of vpImageSimulator to project |
cam | : The parameters of the virtual camera |
Definition at line 1322 of file vpImageSimulator.cpp.
References vpRGBa::B, vpImage< Type >::bitmap, COLORED, vpPixelMeterConversion::convertPoint(), vpRGBa::G, vpRect::getBottom(), vpImage< Type >::getHeight(), vpRect::getLeft(), vpRect::getRight(), vpRect::getTop(), vpImage< Type >::getWidth(), GRAY_SCALED, vpRGBa::R, and vpImagePoint::set_ij().
|
static |
Get the view of the virtual camera. Be carefull, the image I is modified. The projected image is not added as an overlay!
With this method, a list of image is projected into the image. Thus, you have to initialise a list of vpImageSimulator. Then you store them into a vpList. And finally with this method you project them into the image . The depth of the 3D scene is managed such as an image in foreground hides an image background.
The following example shows how to use the method:
I | : The image used to store the result |
list | : List of vpImageSimulator to project |
cam | : The parameters of the virtual camera |
Definition at line 711 of file vpImageSimulator.cpp.
References vpRGBa::B, vpImage< Type >::bitmap, COLORED, vpPixelMeterConversion::convertPoint(), vpList< type >::front(), vpRGBa::G, vpRect::getBottom(), vpImage< Type >::getHeight(), vpRect::getLeft(), vpRect::getRight(), vpRect::getTop(), vpImage< Type >::getWidth(), GRAY_SCALED, vpList< type >::nbElements(), vpList< type >::next(), vpRGBa::R, vpImagePoint::set_ij(), and vpList< type >::value().
|
static |
Get the view of the virtual camera. Be carefull, the image I is modified. The projected image is not added as an overlay!
With this method, a list of image is projected into the image. Thus, you have to initialise a list of vpImageSimulator. Then you store them into a vpList. And finally with this method you project them into the image . The depth of the 3D scene is managed such as an image in foreground hides an image background.
The following example shows how to use the method:
I | : The image used to store the result |
list | : List of vpImageSimulator to project |
cam | : The parameters of the virtual camera |
Definition at line 918 of file vpImageSimulator.cpp.
References vpRGBa::B, vpImage< Type >::bitmap, COLORED, vpPixelMeterConversion::convertPoint(), vpList< type >::front(), vpRGBa::G, vpRect::getBottom(), vpImage< Type >::getHeight(), vpRect::getLeft(), vpRect::getRight(), vpRect::getTop(), vpImage< Type >::getWidth(), GRAY_SCALED, vpList< type >::nbElements(), vpList< type >::next(), vpRGBa::R, vpImagePoint::set_ij(), and vpList< type >::value().
void vpImageSimulator::init | ( | const vpImage< unsigned char > & | I, |
vpColVector * | _X | ||
) |
Initialise the image thanks to an image and a table of vector containing the 3D coordinates of the image's corners.
The table must have a size of 4!
I | : The image which is projected. |
_X | : table of the 3D coordinates corresponding to the image corners. |
Definition at line 1532 of file vpImageSimulator.cpp.
References vpImageConvert::convert().
Referenced by vpVirtualGrabber::vpVirtualGrabber().
void vpImageSimulator::init | ( | const vpImage< vpRGBa > & | I, |
vpColVector * | _X | ||
) |
Initialise the image thanks to an image and a table of vector containing the 3D coordinates of the image's corners.
The table must have a size of 4!
I | : The image which is projected. |
_X | : table of the 3D coordinates corresponding to the image corners. |
Definition at line 1553 of file vpImageSimulator.cpp.
References vpImageConvert::convert().
void vpImageSimulator::init | ( | const char * | file_image, |
vpColVector * | _X | ||
) |
Initialise the image thanks to an image whose adress is given by and a table of vector containing the 3D coordinates of the image's corners.
The table must have a size of 4!
file_image | : The adress of an image file. |
_X | : table of the 3D coordinates corresponding to the image corners. |
Definition at line 1574 of file vpImageSimulator.cpp.
References vpImageIo::read().
void vpImageSimulator::init | ( | const vpImage< unsigned char > & | I, |
const std::vector< vpPoint > & | _X | ||
) |
Initialise the image thanks to an image and a table of vector containing the 3D coordinates of the image's corners.
vpException::dimensionError | if the _X vector is not of size 4. |
I | : The image which is projected. |
_X | : Vector of the 3D coordinates in the object frame (oX, oY, oZ) corresponding to the image corners. |
Definition at line 1596 of file vpImageSimulator.cpp.
References vpImageConvert::convert(), vpException::dimensionError, and vpColVector::resize().
Initialise the image thanks to an image and a table of vector containing the 3D coordinates of the image's corners.
vpException::dimensionError | if the _X vector is not of size 4. |
I | : The image which is projected. |
_X | : Vector of the 3D coordinates in the object frame (oX, oY, oZ) corresponding to the image corners. |
Definition at line 1628 of file vpImageSimulator.cpp.
References vpImageConvert::convert(), vpException::dimensionError, and vpColVector::resize().
void vpImageSimulator::init | ( | const char * | file_image, |
const std::vector< vpPoint > & | _X | ||
) |
Initialise the image thanks to an image whose adress is given by and a table of vector containing the 3D coordinates of the image's corners.
vpException::dimensionError | if the _X vector is not of size 4. |
file_image | : The adress of an image file. |
_X | : Vector of the 3D coordinates in the object frame (oX, oY, oZ) corresponding to the image corners. |
Definition at line 1660 of file vpImageSimulator.cpp.
References vpException::dimensionError, vpImageIo::read(), and vpColVector::resize().
vpImageSimulator & vpImageSimulator::operator= | ( | const vpImageSimulator & | sim | ) |
Definition at line 155 of file vpImageSimulator.cpp.
References setCameraPosition().
|
inline |
This function is to set the background to a texture instead of default black The corresponding flag is set
Iback | Image/Texture for the background |
Definition at line 264 of file vpImageSimulator.h.
void vpImageSimulator::setCameraPosition | ( | const vpHomogeneousMatrix & | _cMt | ) |
Enable to set the position of the 3D plane relative to the virtual camera.
_cMt | : The pose of the plane relative to the virtual camera. |
Definition at line 1429 of file vpImageSimulator.cpp.
References vpTriangle::buildFrom(), vpColVector::crossProd(), vpColVector::dotProd(), vpHomogeneousMatrix::extract(), vpPoint::get_X(), vpPoint::get_Y(), vpPoint::get_Z(), vpImagePoint::set_i(), vpImagePoint::set_j(), and vpForwardProjection::track().
Referenced by vpVirtualGrabber::acquire(), vpWireFrameSimulator::getExternalImage(), vpWireFrameSimulator::getInternalImage(), operator=(), and vpImageSimulator().
|
inline |
As it can be time consuming to reset all the image to a default baground value, this function enable to reset only the pixel which changed the previous time.
By default this functionality is disabled. and the background color is white.
clean | : Enable the reset method. |
color | : Color of the back ground. |
Definition at line 253 of file vpImageSimulator.h.
Referenced by vpVirtualGrabber::acquire().
|
inline |
Definition at line 223 of file vpImageSimulator.h.
Referenced by vpVirtualGrabber::vpVirtualGrabber().