35 #ifndef _vpDetectorAprilTag_h_
36 #define _vpDetectorAprilTag_h_
40 #include <visp3/core/vpConfig.h>
42 #ifdef VISP_HAVE_APRILTAG
43 #include <visp3/core/vpCameraParameters.h>
44 #include <visp3/core/vpColor.h>
45 #include <visp3/core/vpHomogeneousMatrix.h>
46 #include <visp3/core/vpImage.h>
47 #include <visp3/detection/vpDetectorBase.h>
235 HOMOGRAPHY_VIRTUAL_VS,
237 DEMENTHON_VIRTUAL_VS,
241 BEST_RESIDUAL_VIRTUAL_VS,
244 HOMOGRAPHY_ORTHOGONAL_ITERATION
248 const vpPoseEstimationMethod &poseEstimationMethod = HOMOGRAPHY_VIRTUAL_VS);
255 std::vector<vpHomogeneousMatrix> &cMo_vec, std::vector<vpHomogeneousMatrix> *cMo_vec2 = NULL,
256 std::vector<double> *projErrors = NULL, std::vector<double> *projErrors2 = NULL);
260 void displayFrames(
const vpImage<vpRGBa> &I,
const std::vector<vpHomogeneousMatrix> &cMo_vec,
263 void displayTags(
const vpImage<unsigned char> &I,
const std::vector<std::vector<vpImagePoint> > &tagsCorners,
265 void displayTags(
const vpImage<vpRGBa> &I,
const std::vector<std::vector<vpImagePoint> > &tagsCorners,
276 std::vector<std::vector<vpImagePoint> > getTagsCorners()
const;
277 std::vector<int> getTagsId()
const;
278 std::vector<std::vector<vpPoint> > getTagsPoints3D(
const std::vector<int> &tagsId,
279 const std::map<int, double> &tagsSize)
const;
281 void setAprilTagDecodeSharpening(
double decodeSharpening);
282 void setAprilTagFamily(
const vpAprilTagFamily &tagFamily);
283 void setAprilTagNbThreads(
int nThreads);
284 void setAprilTagPoseEstimationMethod(
const vpPoseEstimationMethod &poseEstimationMethod);
285 void setAprilTagQuadDecimate(
float quadDecimate);
286 void setAprilTagQuadSigma(
float quadSigma);
287 void setAprilTagRefineDecode(
bool refineDecode);
288 void setAprilTagRefineEdges(
bool refineEdges);
289 void setAprilTagRefinePose(
bool refinePose);
295 m_displayTag = display;
296 m_displayTagColor = color;
297 m_displayTagThickness = thickness;
302 void setZAlignedWithCameraAxis(
bool zAlignedWithCameraFrame);
327 os <<
"HOMOGRAPHY_VIRTUAL_VS";
331 os <<
"DEMENTHON_VIRTUAL_VS";
335 os <<
"LAGRANGE_VIRTUAL_VS";
339 os <<
"BEST_RESIDUAL_VIRTUAL_VS";
343 os <<
"HOMOGRAPHY_ORTHOGONAL_ITERATION";
347 os <<
"ERROR_UNKNOWN_POSE_METHOD!";
394 os <<
"STANDARD52h13";
398 os <<
"STANDARD41h12";
friend std::ostream & operator<<(std::ostream &s, const vpArray2D< Type > &A)
Generic class defining intrinsic camera parameters.
Class to define RGB colors available for display functionalities.
static const vpColor none
@ BEST_RESIDUAL_VIRTUAL_VS
@ HOMOGRAPHY_ORTHOGONAL_ITERATION
void setDisplayTag(bool display, const vpColor &color=vpColor::none, unsigned int thickness=2)
vpPoseEstimationMethod getPoseEstimationMethod() const
unsigned int m_displayTagThickness
vpAprilTagFamily m_tagFamily
vpPoseEstimationMethod m_poseEstimationMethod
@ TAG_CIRCLE21h7
AprilTag Circle21h7 pattern.
@ TAG_25h7
DEPRECATED AND POOR DETECTION PERFORMANCE.
@ TAG_36ARTOOLKIT
DEPRECATED AND WILL NOT DETECT ARTOOLKIT TAGS.
@ TAG_25h9
AprilTag 25h9 pattern.
@ TAG_CUSTOM48h12
AprilTag Custom48h12 pattern.
@ TAG_36h11
AprilTag 36h11 pattern (recommended)
@ TAG_STANDARD52h13
AprilTag Standard52h13 pattern.
@ TAG_16h5
AprilTag 16h5 pattern.
@ TAG_STANDARD41h12
AprilTag Standard41h12 pattern.
@ TAG_CIRCLE49h12
AprilTag Circle49h12 pattern.
vpColor m_displayTagColor
virtual bool detect(const vpImage< unsigned char > &I)=0
Implementation of an homogeneous matrix and operations on such kind of matrices.