The main functionality of ArucoDetector class is detection of markers in an image with detectMarkers() method.
More...
#include <opencv2/objdetect/aruco_detector.hpp>
|
| ArucoDetector (const Dictionary &dictionary=getPredefinedDictionary(cv::aruco::DICT_4X4_50), const DetectorParameters &detectorParams=DetectorParameters(), const RefineParameters &refineParams=RefineParameters()) |
| Basic ArucoDetector constructor.
|
|
| ArucoDetector (const std::vector< Dictionary > &dictionaries, const DetectorParameters &detectorParams=DetectorParameters(), const RefineParameters &refineParams=RefineParameters()) |
| ArucoDetector constructor for multiple dictionaries.
|
|
void | detectMarkers (InputArray image, OutputArrayOfArrays corners, OutputArray ids, OutputArrayOfArrays rejectedImgPoints=noArray()) const |
| Basic marker detection.
|
|
void | detectMarkersMultiDict (InputArray image, OutputArrayOfArrays corners, OutputArray ids, OutputArrayOfArrays rejectedImgPoints=noArray(), OutputArray dictIndices=noArray()) const |
| Basic marker detection.
|
|
const DetectorParameters & | getDetectorParameters () const |
|
std::vector< Dictionary > | getDictionaries () const |
| Returns all dictionaries currently used for marker detection as a vector.
|
|
const Dictionary & | getDictionary () const |
| Returns first dictionary from internal list used for marker detection.
|
|
const RefineParameters & | getRefineParameters () const |
|
virtual void | read (const FileNode &fn) override |
| Reads algorithm parameters from a file storage.
|
|
void | refineDetectedMarkers (InputArray image, const Board &board, InputOutputArrayOfArrays detectedCorners, InputOutputArray detectedIds, InputOutputArrayOfArrays rejectedCorners, InputArray cameraMatrix=noArray(), InputArray distCoeffs=noArray(), OutputArray recoveredIdxs=noArray()) const |
| Refine not detected markers based on the already detected and the board layout.
|
|
void | setDetectorParameters (const DetectorParameters &detectorParameters) |
|
void | setDictionaries (const std::vector< Dictionary > &dictionaries) |
| Sets the entire collection of dictionaries to be used for marker detection, replacing any existing dictionaries.
|
|
void | setDictionary (const Dictionary &dictionary) |
| Sets and replaces the first dictionary in internal list to be used for marker detection.
|
|
void | setRefineParameters (const RefineParameters &refineParameters) |
|
virtual void | write (FileStorage &fs) const override |
| Stores algorithm parameters in a file storage.
|
|
void | write (FileStorage &fs, const String &name) |
| simplified API for language bindings
|
|
| Algorithm () |
|
virtual | ~Algorithm () |
|
virtual void | clear () |
| Clears the algorithm state.
|
|
virtual bool | empty () const |
| Returns true if the Algorithm is empty (e.g. in the very beginning or after unsuccessful read.
|
|
virtual String | getDefaultName () const |
|
virtual void | save (const String &filename) const |
|
void | write (const Ptr< FileStorage > &fs, const String &name=String()) const |
|
void | write (FileStorage &fs, const String &name) const |
|
The main functionality of ArucoDetector class is detection of markers in an image with detectMarkers() method.
After detecting some markers in the image, you can try to find undetected markers from this dictionary with refineDetectedMarkers() method.
- See also
- DetectorParameters, RefineParameters
◆ ArucoDetector() [1/2]
Python: |
---|
| cv.aruco.ArucoDetector( | [, dictionary[, detectorParams[, refineParams]]] | ) -> | <aruco_ArucoDetector object> |
| cv.aruco.ArucoDetector( | dictionaries[, detectorParams[, refineParams]] | ) -> | <aruco_ArucoDetector object> |
Basic ArucoDetector constructor.
- Parameters
-
dictionary | indicates the type of markers that will be searched |
detectorParams | marker detection parameters |
refineParams | marker refine detection parameters |
◆ ArucoDetector() [2/2]
Python: |
---|
| cv.aruco.ArucoDetector( | [, dictionary[, detectorParams[, refineParams]]] | ) -> | <aruco_ArucoDetector object> |
| cv.aruco.ArucoDetector( | dictionaries[, detectorParams[, refineParams]] | ) -> | <aruco_ArucoDetector object> |
ArucoDetector constructor for multiple dictionaries.
- Parameters
-
dictionaries | indicates the type of markers that will be searched. Empty dictionaries will throw an error. |
detectorParams | marker detection parameters |
refineParams | marker refine detection parameters |
◆ detectMarkers()
Python: |
---|
| cv.aruco.ArucoDetector.detectMarkers( | image[, corners[, ids[, rejectedImgPoints]]] | ) -> | corners, ids, rejectedImgPoints |
Basic marker detection.
- Parameters
-
image | input image |
corners | vector of detected marker corners. For each marker, its four corners are provided, (e.g std::vector<std::vector<cv::Point2f> > ). For N detected markers, the dimensions of this array is Nx4. The order of the corners is clockwise. |
ids | vector of identifiers of the detected markers. The identifier is of type int (e.g. std::vector<int>). For N detected markers, the size of ids is also N. The identifiers have the same order than the markers in the imgPoints array. |
rejectedImgPoints | contains the imgPoints of those squares whose inner code has not a correct codification. Useful for debugging purposes. |
Performs marker detection in the input image. Only markers included in the first specified dictionary are searched. For each detected marker, it returns the 2D position of its corner in the image and its corresponding identifier. Note that this function does not perform pose estimation.
- Note
- The function does not correct lens distortion or takes it into account. It's recommended to undistort input image with corresponding camera model, if camera parameters are known
- See also
- undistort, estimatePoseSingleMarkers, estimatePoseBoard
◆ detectMarkersMultiDict()
Python: |
---|
| cv.aruco.ArucoDetector.detectMarkersMultiDict( | image[, corners[, ids[, rejectedImgPoints[, dictIndices]]]] | ) -> | corners, ids, rejectedImgPoints, dictIndices |
Basic marker detection.
- Parameters
-
image | input image |
corners | vector of detected marker corners. For each marker, its four corners are provided, (e.g std::vector<std::vector<cv::Point2f> > ). For N detected markers, the dimensions of this array is Nx4. The order of the corners is clockwise. |
ids | vector of identifiers of the detected markers. The identifier is of type int (e.g. std::vector<int>). For N detected markers, the size of ids is also N. The identifiers have the same order than the markers in the imgPoints array. |
rejectedImgPoints | contains the imgPoints of those squares whose inner code has not a correct codification. Useful for debugging purposes. |
dictIndices | vector of dictionary indices for each detected marker. Use getDictionaries() to get the list of corresponding dictionaries. |
Performs marker detection in the input image. Only markers included in the specific dictionaries are searched. For each detected marker, it returns the 2D position of its corner in the image and its corresponding identifier. Note that this function does not perform pose estimation.
- Note
- The function does not correct lens distortion or takes it into account. It's recommended to undistort input image with corresponding camera model, if camera parameters are known
- See also
- undistort, estimatePoseSingleMarkers, estimatePoseBoard
◆ getDetectorParameters()
Python: |
---|
| cv.aruco.ArucoDetector.getDetectorParameters( | | ) -> | retval |
◆ getDictionaries()
std::vector< Dictionary > cv::aruco::ArucoDetector::getDictionaries |
( |
| ) |
const |
Python: |
---|
| cv.aruco.ArucoDetector.getDictionaries( | | ) -> | retval |
Returns all dictionaries currently used for marker detection as a vector.
- Returns
- A std::vector<Dictionary> containing all dictionaries used by the ArucoDetector.
◆ getDictionary()
const Dictionary & cv::aruco::ArucoDetector::getDictionary |
( |
| ) |
const |
Python: |
---|
| cv.aruco.ArucoDetector.getDictionary( | | ) -> | retval |
Returns first dictionary from internal list used for marker detection.
- Returns
- The first dictionary from the configured ArucoDetector.
◆ getRefineParameters()
const RefineParameters & cv::aruco::ArucoDetector::getRefineParameters |
( |
| ) |
const |
Python: |
---|
| cv.aruco.ArucoDetector.getRefineParameters( | | ) -> | retval |
◆ read()
virtual void cv::aruco::ArucoDetector::read |
( |
const FileNode & | fn | ) |
|
|
overridevirtual |
Python: |
---|
| cv.aruco.ArucoDetector.read( | fn | ) -> | None |
Reads algorithm parameters from a file storage.
Reimplemented from cv::Algorithm.
◆ refineDetectedMarkers()
Python: |
---|
| cv.aruco.ArucoDetector.refineDetectedMarkers( | image, board, detectedCorners, detectedIds, rejectedCorners[, cameraMatrix[, distCoeffs[, recoveredIdxs]]] | ) -> | detectedCorners, detectedIds, rejectedCorners, recoveredIdxs |
Refine not detected markers based on the already detected and the board layout.
- Parameters
-
image | input image |
board | layout of markers in the board. |
detectedCorners | vector of already detected marker corners. |
detectedIds | vector of already detected marker identifiers. |
rejectedCorners | vector of rejected candidates during the marker detection process. |
cameraMatrix | optional input 3x3 floating-point camera matrix |
distCoeffs | optional vector of distortion coefficients of 4, 5, 8 or 12 elements |
recoveredIdxs | Optional array to returns the indexes of the recovered candidates in the original rejectedCorners array. |
This function tries to find markers that were not detected in the basic detecMarkers function. First, based on the current detected marker and the board layout, the function interpolates the position of the missing markers. Then it tries to find correspondence between the reprojected markers and the rejected candidates based on the minRepDistance and errorCorrectionRate parameters. If camera parameters and distortion coefficients are provided, missing markers are reprojected using projectPoint function. If not, missing marker projections are interpolated using global homography, and all the marker corners in the board must have the same Z coordinate.
- Note
- This function assumes that the board only contains markers from one dictionary, so only the first configured dictionary is used. It has to match the dictionary of the board to work properly.
◆ setDetectorParameters()
void cv::aruco::ArucoDetector::setDetectorParameters |
( |
const DetectorParameters & | detectorParameters | ) |
|
Python: |
---|
| cv.aruco.ArucoDetector.setDetectorParameters( | detectorParameters | ) -> | None |
◆ setDictionaries()
void cv::aruco::ArucoDetector::setDictionaries |
( |
const std::vector< Dictionary > & | dictionaries | ) |
|
Python: |
---|
| cv.aruco.ArucoDetector.setDictionaries( | dictionaries | ) -> | None |
Sets the entire collection of dictionaries to be used for marker detection, replacing any existing dictionaries.
- Parameters
-
dictionaries | A std::vector<Dictionary> containing the new set of dictionaries to be used. |
Configures the ArucoDetector to use the provided vector of dictionaries for marker detection. This method replaces any dictionaries that were previously set.
- Note
- Setting an empty vector of dictionaries will throw an error.
◆ setDictionary()
void cv::aruco::ArucoDetector::setDictionary |
( |
const Dictionary & | dictionary | ) |
|
Python: |
---|
| cv.aruco.ArucoDetector.setDictionary( | dictionary | ) -> | None |
Sets and replaces the first dictionary in internal list to be used for marker detection.
- Parameters
-
dictionary | The new dictionary that will replace the first dictionary in the internal list. |
◆ setRefineParameters()
void cv::aruco::ArucoDetector::setRefineParameters |
( |
const RefineParameters & | refineParameters | ) |
|
Python: |
---|
| cv.aruco.ArucoDetector.setRefineParameters( | refineParameters | ) -> | None |
◆ write() [1/2]
virtual void cv::aruco::ArucoDetector::write |
( |
FileStorage & | fs | ) |
const |
|
overridevirtual |
Python: |
---|
| cv.aruco.ArucoDetector.write( | fs, name | ) -> | None |
Stores algorithm parameters in a file storage.
Reimplemented from cv::Algorithm.
◆ write() [2/2]
Python: |
---|
| cv.aruco.ArucoDetector.write( | fs, name | ) -> | None |
simplified API for language bindings
◆ arucoDetectorImpl
Ptr<ArucoDetectorImpl> cv::aruco::ArucoDetector::arucoDetectorImpl |
|
protected |
The documentation for this class was generated from the following file: