2 #include <visp3/visual_features/vpFeatureBuilder.h>
3 #include <visp3/vs/vpServo.h>
4 #include <visp3/robot/vpSimulatorCamera.h>
5 #include <visp3/gui/vpDisplayX.h>
6 #include <visp3/gui/vpDisplayOpenCV.h>
7 #include <visp3/gui/vpDisplayGDI.h>
8 #include <visp3/gui/vpProjectionDisplay.h>
9 #include <visp3/vs/vpServoDisplay.h>
10 #include <visp3/robot/vpWireFrameSimulator.h>
18 static std::vector<vpImagePoint> traj[4];
20 for (
unsigned int i=0; i<4; i++) {
22 point[i].project(cMo);
24 traj[i].push_back(cog);
26 for (
unsigned int i=0; i<4; i++) {
27 for (
unsigned int j=1; j<traj[i].size(); j++) {
39 std::vector<vpPoint> point(4) ;
40 point[0].setWorldCoordinates(-0.1,-0.1, 0);
41 point[1].setWorldCoordinates( 0.1,-0.1, 0);
42 point[2].setWorldCoordinates( 0.1, 0.1, 0);
43 point[3].setWorldCoordinates(-0.1, 0.1, 0);
51 for (
unsigned int i = 0 ; i < 4 ; i++) {
67 #if defined VISP_HAVE_X11
68 vpDisplayX displayInt(Iint, 0, 0,
"Internal view");
69 vpDisplayX displayExt(Iext, 670, 0,
"External view");
70 #elif defined VISP_HAVE_GDI
73 #elif defined VISP_HAVE_OPENCV
77 std::cout <<
"No image viewer is available..." << std::endl;
94 for (
unsigned int i = 0 ; i < 4 ; i++) {
109 display_trajectory(Iint, point, cMo, cam);
121 std::cout <<
"Catch an exception: " << e << std::endl;
The object displayed at the desired position is the same than the scene object defined in vpSceneObje...
VISP_EXPORT int wait(double t0, double t)
void setVelocity(const vpRobot::vpControlFrameType frame, const vpColVector &vel)
unsigned int getWidth() const
double getSamplingTime() const
Implementation of an homogeneous matrix and operations on such kind of matrices.
Class that defines the simplest robot: a free flying camera.
A 40cm by 40cm plate with 4 points at coordinates (-0.1,-0.1,0), (0.1,-0.1,0), (0.1,0.1,0), (0.1,0.1,0). Each point is represented by a circle with 2cm radius.
static void convertPoint(const vpCameraParameters &cam, const double &x, const double &y, double &u, double &v)
Point coordinates conversion from normalized coordinates in meter to pixel coordinates ...
Display for windows using GDI (available on any windows 32 platform).
Define the X11 console to display images.
void addFeature(vpBasicFeature &s, vpBasicFeature &s_star, const unsigned int select=vpBasicFeature::FEATURE_ALL)
error that can be emited by ViSP classes.
Class that defines a 2D point visual feature which is composed by two parameters that are the cartes...
void setExternalCameraPosition(const vpHomogeneousMatrix &cam_Mf)
void setDesiredCameraPosition(const vpHomogeneousMatrix &cdMo_)
static const vpColor green
static void flush(const vpImage< unsigned char > &I)
virtual void setSamplingTime(const double &delta_t)
vpColVector computeControlLaw()
static void display(const vpImage< unsigned char > &I)
The vpDisplayOpenCV allows to display image using the opencv library.
Generic class defining intrinsic camera parameters.
void initScene(const vpSceneObject &obj, const vpSceneDesiredObject &desiredObject)
vpHomogeneousMatrix getPosition() const
void getExternalImage(vpImage< unsigned char > &I)
Implementation of a wire frame simulator. Compared to the vpSimulator class, it does not require thir...
void setInteractionMatrixType(const vpServoIteractionMatrixType &interactionMatrixType, const vpServoInversionType &interactionMatrixInversion=PSEUDO_INVERSE)
static double rad(double deg)
void setExternalCameraParameters(const vpCameraParameters &cam)
void setCameraPositionRelObj(const vpHomogeneousMatrix &cMo_)
void getInternalImage(vpImage< unsigned char > &I)
Implementation of column vector and the associated operations.
vpHomogeneousMatrix inverse() const
void setInternalCameraParameters(const vpCameraParameters &cam)
unsigned int getHeight() const
virtual bool getClick(bool blocking=true)=0
Class that defines a 2D point in an image. This class is useful for image processing and stores only ...
virtual void displayLine(const vpImagePoint &ip1, const vpImagePoint &ip2, const vpColor &color, unsigned int thickness=1)=0
static void create(vpFeaturePoint &s, const vpCameraParameters &cam, const vpDot &d)
void setServo(const vpServoType &servo_type)