Commit 280af826 authored by Alexander Alekhin's avatar Alexander Alekhin

Merge pull request #555 from SSteve:master

parents 7b2c6f83 b6573a7b
...@@ -268,16 +268,16 @@ class CV_EXPORTS_W GridBoard : public Board { ...@@ -268,16 +268,16 @@ class CV_EXPORTS_W GridBoard : public Board {
* @param markersX number of markers in X direction * @param markersX number of markers in X direction
* @param markersY number of markers in Y direction * @param markersY number of markers in Y direction
* @param markerLength marker side length (normally in meters) * @param markerLength marker side length (normally in meters)
* @param markerSeparation separation between two markers (same unit than markerLenght) * @param markerSeparation separation between two markers (same unit as markerLength)
* @param dictionary dictionary of markers indicating the type of markers. * @param dictionary dictionary of markers indicating the type of markers
* The first markersX*markersY markers in the dictionary are used. * @param firstMarker id of first marker in dictionary to use on board.
* @return the output GridBoard object * @return the output GridBoard object
* *
* This functions creates a GridBoard object given the number of markers in each direction and * This functions creates a GridBoard object given the number of markers in each direction and
* the marker size and marker separation. * the marker size and marker separation.
*/ */
CV_WRAP static Ptr<GridBoard> create(int markersX, int markersY, float markerLength, CV_WRAP static Ptr<GridBoard> create(int markersX, int markersY, float markerLength,
float markerSeparation, Ptr<Dictionary> &dictionary); float markerSeparation, Ptr<Dictionary> &dictionary, int firstMarker = 0);
/** /**
* *
......
...@@ -1329,11 +1329,10 @@ void GridBoard::draw(Size outSize, OutputArray _img, int marginSize, int borderB ...@@ -1329,11 +1329,10 @@ void GridBoard::draw(Size outSize, OutputArray _img, int marginSize, int borderB
} }
/** /**
*/ */
Ptr<GridBoard> GridBoard::create(int markersX, int markersY, float markerLength, float markerSeparation, Ptr<GridBoard> GridBoard::create(int markersX, int markersY, float markerLength, float markerSeparation,
Ptr<Dictionary> &dictionary) { Ptr<Dictionary> &dictionary, int firstMarker) {
CV_Assert(markersX > 0 && markersY > 0 && markerLength > 0 && markerSeparation > 0); CV_Assert(markersX > 0 && markersY > 0 && markerLength > 0 && markerSeparation > 0);
...@@ -1351,7 +1350,7 @@ Ptr<GridBoard> GridBoard::create(int markersX, int markersY, float markerLength, ...@@ -1351,7 +1350,7 @@ Ptr<GridBoard> GridBoard::create(int markersX, int markersY, float markerLength,
// fill ids with first identifiers // fill ids with first identifiers
for(unsigned int i = 0; i < totalMarkers; i++) { for(unsigned int i = 0; i < totalMarkers; i++) {
res->ids[i] = i; res->ids[i] = i + firstMarker;
} }
// calculate Board objPoints // calculate Board objPoints
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment