123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811 |
- using OpenCVForUnity.CoreModule;
- using OpenCVForUnity.UtilsModule;
- using System;
- using System.Collections.Generic;
- using System.Runtime.InteropServices;
- namespace OpenCVForUnity.Features2dModule
- {
- // C++: class ORB
- /**
- * Class implementing the ORB (*oriented BRIEF*) keypoint detector and descriptor extractor
- *
- * described in CITE: RRKB11 . The algorithm uses FAST in pyramids to detect stable keypoints, selects
- * the strongest features using FAST or Harris response, finds their orientation using first-order
- * moments and computes the descriptors using BRIEF (where the coordinates of random point pairs (or
- * k-tuples) are rotated according to the measured orientation).
- */
- public class ORB : Feature2D
- {
- protected override void Dispose(bool disposing)
- {
- try
- {
- if (disposing)
- {
- }
- if (IsEnabledDispose)
- {
- if (nativeObj != IntPtr.Zero)
- features2d_ORB_delete(nativeObj);
- nativeObj = IntPtr.Zero;
- }
- }
- finally
- {
- base.Dispose(disposing);
- }
- }
- protected internal ORB(IntPtr addr) : base(addr) { }
- // internal usage only
- public static new ORB __fromPtr__(IntPtr addr) { return new ORB(addr); }
- // C++: enum cv.ORB.ScoreType
- public const int HARRIS_SCORE = 0;
- public const int FAST_SCORE = 1;
- //
- // C++: static Ptr_ORB cv::ORB::create(int nfeatures = 500, float scaleFactor = 1.2f, int nlevels = 8, int edgeThreshold = 31, int firstLevel = 0, int WTA_K = 2, ORB_ScoreType scoreType = ORB::HARRIS_SCORE, int patchSize = 31, int fastThreshold = 20)
- //
- /**
- * The ORB constructor
- *
- * param nfeatures The maximum number of features to retain.
- * param scaleFactor Pyramid decimation ratio, greater than 1. scaleFactor==2 means the classical
- * pyramid, where each next level has 4x less pixels than the previous, but such a big scale factor
- * will degrade feature matching scores dramatically. On the other hand, too close to 1 scale factor
- * will mean that to cover certain scale range you will need more pyramid levels and so the speed
- * will suffer.
- * param nlevels The number of pyramid levels. The smallest level will have linear size equal to
- * input_image_linear_size/pow(scaleFactor, nlevels - firstLevel).
- * param edgeThreshold This is size of the border where the features are not detected. It should
- * roughly match the patchSize parameter.
- * param firstLevel The level of pyramid to put source image to. Previous layers are filled
- * with upscaled source image.
- * param WTA_K The number of points that produce each element of the oriented BRIEF descriptor. The
- * default value 2 means the BRIEF where we take a random point pair and compare their brightnesses,
- * so we get 0/1 response. Other possible values are 3 and 4. For example, 3 means that we take 3
- * random points (of course, those point coordinates are random, but they are generated from the
- * pre-defined seed, so each element of BRIEF descriptor is computed deterministically from the pixel
- * rectangle), find point of maximum brightness and output index of the winner (0, 1 or 2). Such
- * output will occupy 2 bits, and therefore it will need a special variant of Hamming distance,
- * denoted as NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to compute each
- * bin (that will also occupy 2 bits with possible values 0, 1, 2 or 3).
- * param scoreType The default HARRIS_SCORE means that Harris algorithm is used to rank features
- * (the score is written to KeyPoint::score and is used to retain best nfeatures features);
- * FAST_SCORE is alternative value of the parameter that produces slightly less stable keypoints,
- * but it is a little faster to compute.
- * param patchSize size of the patch used by the oriented BRIEF descriptor. Of course, on smaller
- * pyramid layers the perceived image area covered by a feature will be larger.
- * param fastThreshold the fast threshold
- * return automatically generated
- */
- public static ORB create(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold, int firstLevel, int WTA_K, int scoreType, int patchSize, int fastThreshold)
- {
- return ORB.__fromPtr__(DisposableObject.ThrowIfNullIntPtr(features2d_ORB_create_10(nfeatures, scaleFactor, nlevels, edgeThreshold, firstLevel, WTA_K, scoreType, patchSize, fastThreshold)));
- }
- /**
- * The ORB constructor
- *
- * param nfeatures The maximum number of features to retain.
- * param scaleFactor Pyramid decimation ratio, greater than 1. scaleFactor==2 means the classical
- * pyramid, where each next level has 4x less pixels than the previous, but such a big scale factor
- * will degrade feature matching scores dramatically. On the other hand, too close to 1 scale factor
- * will mean that to cover certain scale range you will need more pyramid levels and so the speed
- * will suffer.
- * param nlevels The number of pyramid levels. The smallest level will have linear size equal to
- * input_image_linear_size/pow(scaleFactor, nlevels - firstLevel).
- * param edgeThreshold This is size of the border where the features are not detected. It should
- * roughly match the patchSize parameter.
- * param firstLevel The level of pyramid to put source image to. Previous layers are filled
- * with upscaled source image.
- * param WTA_K The number of points that produce each element of the oriented BRIEF descriptor. The
- * default value 2 means the BRIEF where we take a random point pair and compare their brightnesses,
- * so we get 0/1 response. Other possible values are 3 and 4. For example, 3 means that we take 3
- * random points (of course, those point coordinates are random, but they are generated from the
- * pre-defined seed, so each element of BRIEF descriptor is computed deterministically from the pixel
- * rectangle), find point of maximum brightness and output index of the winner (0, 1 or 2). Such
- * output will occupy 2 bits, and therefore it will need a special variant of Hamming distance,
- * denoted as NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to compute each
- * bin (that will also occupy 2 bits with possible values 0, 1, 2 or 3).
- * param scoreType The default HARRIS_SCORE means that Harris algorithm is used to rank features
- * (the score is written to KeyPoint::score and is used to retain best nfeatures features);
- * FAST_SCORE is alternative value of the parameter that produces slightly less stable keypoints,
- * but it is a little faster to compute.
- * param patchSize size of the patch used by the oriented BRIEF descriptor. Of course, on smaller
- * pyramid layers the perceived image area covered by a feature will be larger.
- * return automatically generated
- */
- public static ORB create(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold, int firstLevel, int WTA_K, int scoreType, int patchSize)
- {
- return ORB.__fromPtr__(DisposableObject.ThrowIfNullIntPtr(features2d_ORB_create_11(nfeatures, scaleFactor, nlevels, edgeThreshold, firstLevel, WTA_K, scoreType, patchSize)));
- }
- /**
- * The ORB constructor
- *
- * param nfeatures The maximum number of features to retain.
- * param scaleFactor Pyramid decimation ratio, greater than 1. scaleFactor==2 means the classical
- * pyramid, where each next level has 4x less pixels than the previous, but such a big scale factor
- * will degrade feature matching scores dramatically. On the other hand, too close to 1 scale factor
- * will mean that to cover certain scale range you will need more pyramid levels and so the speed
- * will suffer.
- * param nlevels The number of pyramid levels. The smallest level will have linear size equal to
- * input_image_linear_size/pow(scaleFactor, nlevels - firstLevel).
- * param edgeThreshold This is size of the border where the features are not detected. It should
- * roughly match the patchSize parameter.
- * param firstLevel The level of pyramid to put source image to. Previous layers are filled
- * with upscaled source image.
- * param WTA_K The number of points that produce each element of the oriented BRIEF descriptor. The
- * default value 2 means the BRIEF where we take a random point pair and compare their brightnesses,
- * so we get 0/1 response. Other possible values are 3 and 4. For example, 3 means that we take 3
- * random points (of course, those point coordinates are random, but they are generated from the
- * pre-defined seed, so each element of BRIEF descriptor is computed deterministically from the pixel
- * rectangle), find point of maximum brightness and output index of the winner (0, 1 or 2). Such
- * output will occupy 2 bits, and therefore it will need a special variant of Hamming distance,
- * denoted as NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to compute each
- * bin (that will also occupy 2 bits with possible values 0, 1, 2 or 3).
- * param scoreType The default HARRIS_SCORE means that Harris algorithm is used to rank features
- * (the score is written to KeyPoint::score and is used to retain best nfeatures features);
- * FAST_SCORE is alternative value of the parameter that produces slightly less stable keypoints,
- * but it is a little faster to compute.
- * pyramid layers the perceived image area covered by a feature will be larger.
- * return automatically generated
- */
- public static ORB create(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold, int firstLevel, int WTA_K, int scoreType)
- {
- return ORB.__fromPtr__(DisposableObject.ThrowIfNullIntPtr(features2d_ORB_create_12(nfeatures, scaleFactor, nlevels, edgeThreshold, firstLevel, WTA_K, scoreType)));
- }
- /**
- * The ORB constructor
- *
- * param nfeatures The maximum number of features to retain.
- * param scaleFactor Pyramid decimation ratio, greater than 1. scaleFactor==2 means the classical
- * pyramid, where each next level has 4x less pixels than the previous, but such a big scale factor
- * will degrade feature matching scores dramatically. On the other hand, too close to 1 scale factor
- * will mean that to cover certain scale range you will need more pyramid levels and so the speed
- * will suffer.
- * param nlevels The number of pyramid levels. The smallest level will have linear size equal to
- * input_image_linear_size/pow(scaleFactor, nlevels - firstLevel).
- * param edgeThreshold This is size of the border where the features are not detected. It should
- * roughly match the patchSize parameter.
- * param firstLevel The level of pyramid to put source image to. Previous layers are filled
- * with upscaled source image.
- * param WTA_K The number of points that produce each element of the oriented BRIEF descriptor. The
- * default value 2 means the BRIEF where we take a random point pair and compare their brightnesses,
- * so we get 0/1 response. Other possible values are 3 and 4. For example, 3 means that we take 3
- * random points (of course, those point coordinates are random, but they are generated from the
- * pre-defined seed, so each element of BRIEF descriptor is computed deterministically from the pixel
- * rectangle), find point of maximum brightness and output index of the winner (0, 1 or 2). Such
- * output will occupy 2 bits, and therefore it will need a special variant of Hamming distance,
- * denoted as NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to compute each
- * bin (that will also occupy 2 bits with possible values 0, 1, 2 or 3).
- * (the score is written to KeyPoint::score and is used to retain best nfeatures features);
- * FAST_SCORE is alternative value of the parameter that produces slightly less stable keypoints,
- * but it is a little faster to compute.
- * pyramid layers the perceived image area covered by a feature will be larger.
- * return automatically generated
- */
- public static ORB create(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold, int firstLevel, int WTA_K)
- {
- return ORB.__fromPtr__(DisposableObject.ThrowIfNullIntPtr(features2d_ORB_create_13(nfeatures, scaleFactor, nlevels, edgeThreshold, firstLevel, WTA_K)));
- }
- /**
- * The ORB constructor
- *
- * param nfeatures The maximum number of features to retain.
- * param scaleFactor Pyramid decimation ratio, greater than 1. scaleFactor==2 means the classical
- * pyramid, where each next level has 4x less pixels than the previous, but such a big scale factor
- * will degrade feature matching scores dramatically. On the other hand, too close to 1 scale factor
- * will mean that to cover certain scale range you will need more pyramid levels and so the speed
- * will suffer.
- * param nlevels The number of pyramid levels. The smallest level will have linear size equal to
- * input_image_linear_size/pow(scaleFactor, nlevels - firstLevel).
- * param edgeThreshold This is size of the border where the features are not detected. It should
- * roughly match the patchSize parameter.
- * param firstLevel The level of pyramid to put source image to. Previous layers are filled
- * with upscaled source image.
- * default value 2 means the BRIEF where we take a random point pair and compare their brightnesses,
- * so we get 0/1 response. Other possible values are 3 and 4. For example, 3 means that we take 3
- * random points (of course, those point coordinates are random, but they are generated from the
- * pre-defined seed, so each element of BRIEF descriptor is computed deterministically from the pixel
- * rectangle), find point of maximum brightness and output index of the winner (0, 1 or 2). Such
- * output will occupy 2 bits, and therefore it will need a special variant of Hamming distance,
- * denoted as NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to compute each
- * bin (that will also occupy 2 bits with possible values 0, 1, 2 or 3).
- * (the score is written to KeyPoint::score and is used to retain best nfeatures features);
- * FAST_SCORE is alternative value of the parameter that produces slightly less stable keypoints,
- * but it is a little faster to compute.
- * pyramid layers the perceived image area covered by a feature will be larger.
- * return automatically generated
- */
- public static ORB create(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold, int firstLevel)
- {
- return ORB.__fromPtr__(DisposableObject.ThrowIfNullIntPtr(features2d_ORB_create_14(nfeatures, scaleFactor, nlevels, edgeThreshold, firstLevel)));
- }
- /**
- * The ORB constructor
- *
- * param nfeatures The maximum number of features to retain.
- * param scaleFactor Pyramid decimation ratio, greater than 1. scaleFactor==2 means the classical
- * pyramid, where each next level has 4x less pixels than the previous, but such a big scale factor
- * will degrade feature matching scores dramatically. On the other hand, too close to 1 scale factor
- * will mean that to cover certain scale range you will need more pyramid levels and so the speed
- * will suffer.
- * param nlevels The number of pyramid levels. The smallest level will have linear size equal to
- * input_image_linear_size/pow(scaleFactor, nlevels - firstLevel).
- * param edgeThreshold This is size of the border where the features are not detected. It should
- * roughly match the patchSize parameter.
- * with upscaled source image.
- * default value 2 means the BRIEF where we take a random point pair and compare their brightnesses,
- * so we get 0/1 response. Other possible values are 3 and 4. For example, 3 means that we take 3
- * random points (of course, those point coordinates are random, but they are generated from the
- * pre-defined seed, so each element of BRIEF descriptor is computed deterministically from the pixel
- * rectangle), find point of maximum brightness and output index of the winner (0, 1 or 2). Such
- * output will occupy 2 bits, and therefore it will need a special variant of Hamming distance,
- * denoted as NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to compute each
- * bin (that will also occupy 2 bits with possible values 0, 1, 2 or 3).
- * (the score is written to KeyPoint::score and is used to retain best nfeatures features);
- * FAST_SCORE is alternative value of the parameter that produces slightly less stable keypoints,
- * but it is a little faster to compute.
- * pyramid layers the perceived image area covered by a feature will be larger.
- * return automatically generated
- */
- public static ORB create(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold)
- {
- return ORB.__fromPtr__(DisposableObject.ThrowIfNullIntPtr(features2d_ORB_create_15(nfeatures, scaleFactor, nlevels, edgeThreshold)));
- }
- /**
- * The ORB constructor
- *
- * param nfeatures The maximum number of features to retain.
- * param scaleFactor Pyramid decimation ratio, greater than 1. scaleFactor==2 means the classical
- * pyramid, where each next level has 4x less pixels than the previous, but such a big scale factor
- * will degrade feature matching scores dramatically. On the other hand, too close to 1 scale factor
- * will mean that to cover certain scale range you will need more pyramid levels and so the speed
- * will suffer.
- * param nlevels The number of pyramid levels. The smallest level will have linear size equal to
- * input_image_linear_size/pow(scaleFactor, nlevels - firstLevel).
- * roughly match the patchSize parameter.
- * with upscaled source image.
- * default value 2 means the BRIEF where we take a random point pair and compare their brightnesses,
- * so we get 0/1 response. Other possible values are 3 and 4. For example, 3 means that we take 3
- * random points (of course, those point coordinates are random, but they are generated from the
- * pre-defined seed, so each element of BRIEF descriptor is computed deterministically from the pixel
- * rectangle), find point of maximum brightness and output index of the winner (0, 1 or 2). Such
- * output will occupy 2 bits, and therefore it will need a special variant of Hamming distance,
- * denoted as NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to compute each
- * bin (that will also occupy 2 bits with possible values 0, 1, 2 or 3).
- * (the score is written to KeyPoint::score and is used to retain best nfeatures features);
- * FAST_SCORE is alternative value of the parameter that produces slightly less stable keypoints,
- * but it is a little faster to compute.
- * pyramid layers the perceived image area covered by a feature will be larger.
- * return automatically generated
- */
- public static ORB create(int nfeatures, float scaleFactor, int nlevels)
- {
- return ORB.__fromPtr__(DisposableObject.ThrowIfNullIntPtr(features2d_ORB_create_16(nfeatures, scaleFactor, nlevels)));
- }
- /**
- * The ORB constructor
- *
- * param nfeatures The maximum number of features to retain.
- * param scaleFactor Pyramid decimation ratio, greater than 1. scaleFactor==2 means the classical
- * pyramid, where each next level has 4x less pixels than the previous, but such a big scale factor
- * will degrade feature matching scores dramatically. On the other hand, too close to 1 scale factor
- * will mean that to cover certain scale range you will need more pyramid levels and so the speed
- * will suffer.
- * input_image_linear_size/pow(scaleFactor, nlevels - firstLevel).
- * roughly match the patchSize parameter.
- * with upscaled source image.
- * default value 2 means the BRIEF where we take a random point pair and compare their brightnesses,
- * so we get 0/1 response. Other possible values are 3 and 4. For example, 3 means that we take 3
- * random points (of course, those point coordinates are random, but they are generated from the
- * pre-defined seed, so each element of BRIEF descriptor is computed deterministically from the pixel
- * rectangle), find point of maximum brightness and output index of the winner (0, 1 or 2). Such
- * output will occupy 2 bits, and therefore it will need a special variant of Hamming distance,
- * denoted as NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to compute each
- * bin (that will also occupy 2 bits with possible values 0, 1, 2 or 3).
- * (the score is written to KeyPoint::score and is used to retain best nfeatures features);
- * FAST_SCORE is alternative value of the parameter that produces slightly less stable keypoints,
- * but it is a little faster to compute.
- * pyramid layers the perceived image area covered by a feature will be larger.
- * return automatically generated
- */
- public static ORB create(int nfeatures, float scaleFactor)
- {
- return ORB.__fromPtr__(DisposableObject.ThrowIfNullIntPtr(features2d_ORB_create_17(nfeatures, scaleFactor)));
- }
- /**
- * The ORB constructor
- *
- * param nfeatures The maximum number of features to retain.
- * pyramid, where each next level has 4x less pixels than the previous, but such a big scale factor
- * will degrade feature matching scores dramatically. On the other hand, too close to 1 scale factor
- * will mean that to cover certain scale range you will need more pyramid levels and so the speed
- * will suffer.
- * input_image_linear_size/pow(scaleFactor, nlevels - firstLevel).
- * roughly match the patchSize parameter.
- * with upscaled source image.
- * default value 2 means the BRIEF where we take a random point pair and compare their brightnesses,
- * so we get 0/1 response. Other possible values are 3 and 4. For example, 3 means that we take 3
- * random points (of course, those point coordinates are random, but they are generated from the
- * pre-defined seed, so each element of BRIEF descriptor is computed deterministically from the pixel
- * rectangle), find point of maximum brightness and output index of the winner (0, 1 or 2). Such
- * output will occupy 2 bits, and therefore it will need a special variant of Hamming distance,
- * denoted as NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to compute each
- * bin (that will also occupy 2 bits with possible values 0, 1, 2 or 3).
- * (the score is written to KeyPoint::score and is used to retain best nfeatures features);
- * FAST_SCORE is alternative value of the parameter that produces slightly less stable keypoints,
- * but it is a little faster to compute.
- * pyramid layers the perceived image area covered by a feature will be larger.
- * return automatically generated
- */
- public static ORB create(int nfeatures)
- {
- return ORB.__fromPtr__(DisposableObject.ThrowIfNullIntPtr(features2d_ORB_create_18(nfeatures)));
- }
- /**
- * The ORB constructor
- *
- * pyramid, where each next level has 4x less pixels than the previous, but such a big scale factor
- * will degrade feature matching scores dramatically. On the other hand, too close to 1 scale factor
- * will mean that to cover certain scale range you will need more pyramid levels and so the speed
- * will suffer.
- * input_image_linear_size/pow(scaleFactor, nlevels - firstLevel).
- * roughly match the patchSize parameter.
- * with upscaled source image.
- * default value 2 means the BRIEF where we take a random point pair and compare their brightnesses,
- * so we get 0/1 response. Other possible values are 3 and 4. For example, 3 means that we take 3
- * random points (of course, those point coordinates are random, but they are generated from the
- * pre-defined seed, so each element of BRIEF descriptor is computed deterministically from the pixel
- * rectangle), find point of maximum brightness and output index of the winner (0, 1 or 2). Such
- * output will occupy 2 bits, and therefore it will need a special variant of Hamming distance,
- * denoted as NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to compute each
- * bin (that will also occupy 2 bits with possible values 0, 1, 2 or 3).
- * (the score is written to KeyPoint::score and is used to retain best nfeatures features);
- * FAST_SCORE is alternative value of the parameter that produces slightly less stable keypoints,
- * but it is a little faster to compute.
- * pyramid layers the perceived image area covered by a feature will be larger.
- * return automatically generated
- */
- public static ORB create()
- {
- return ORB.__fromPtr__(DisposableObject.ThrowIfNullIntPtr(features2d_ORB_create_19()));
- }
- //
- // C++: void cv::ORB::setMaxFeatures(int maxFeatures)
- //
- public void setMaxFeatures(int maxFeatures)
- {
- ThrowIfDisposed();
- features2d_ORB_setMaxFeatures_10(nativeObj, maxFeatures);
- }
- //
- // C++: int cv::ORB::getMaxFeatures()
- //
- public int getMaxFeatures()
- {
- ThrowIfDisposed();
- return features2d_ORB_getMaxFeatures_10(nativeObj);
- }
- //
- // C++: void cv::ORB::setScaleFactor(double scaleFactor)
- //
- public void setScaleFactor(double scaleFactor)
- {
- ThrowIfDisposed();
- features2d_ORB_setScaleFactor_10(nativeObj, scaleFactor);
- }
- //
- // C++: double cv::ORB::getScaleFactor()
- //
- public double getScaleFactor()
- {
- ThrowIfDisposed();
- return features2d_ORB_getScaleFactor_10(nativeObj);
- }
- //
- // C++: void cv::ORB::setNLevels(int nlevels)
- //
- public void setNLevels(int nlevels)
- {
- ThrowIfDisposed();
- features2d_ORB_setNLevels_10(nativeObj, nlevels);
- }
- //
- // C++: int cv::ORB::getNLevels()
- //
- public int getNLevels()
- {
- ThrowIfDisposed();
- return features2d_ORB_getNLevels_10(nativeObj);
- }
- //
- // C++: void cv::ORB::setEdgeThreshold(int edgeThreshold)
- //
- public void setEdgeThreshold(int edgeThreshold)
- {
- ThrowIfDisposed();
- features2d_ORB_setEdgeThreshold_10(nativeObj, edgeThreshold);
- }
- //
- // C++: int cv::ORB::getEdgeThreshold()
- //
- public int getEdgeThreshold()
- {
- ThrowIfDisposed();
- return features2d_ORB_getEdgeThreshold_10(nativeObj);
- }
- //
- // C++: void cv::ORB::setFirstLevel(int firstLevel)
- //
- public void setFirstLevel(int firstLevel)
- {
- ThrowIfDisposed();
- features2d_ORB_setFirstLevel_10(nativeObj, firstLevel);
- }
- //
- // C++: int cv::ORB::getFirstLevel()
- //
- public int getFirstLevel()
- {
- ThrowIfDisposed();
- return features2d_ORB_getFirstLevel_10(nativeObj);
- }
- //
- // C++: void cv::ORB::setWTA_K(int wta_k)
- //
- public void setWTA_K(int wta_k)
- {
- ThrowIfDisposed();
- features2d_ORB_setWTA_1K_10(nativeObj, wta_k);
- }
- //
- // C++: int cv::ORB::getWTA_K()
- //
- public int getWTA_K()
- {
- ThrowIfDisposed();
- return features2d_ORB_getWTA_1K_10(nativeObj);
- }
- //
- // C++: void cv::ORB::setScoreType(ORB_ScoreType scoreType)
- //
- public void setScoreType(int scoreType)
- {
- ThrowIfDisposed();
- features2d_ORB_setScoreType_10(nativeObj, scoreType);
- }
- //
- // C++: ORB_ScoreType cv::ORB::getScoreType()
- //
- public int getScoreType()
- {
- ThrowIfDisposed();
- return features2d_ORB_getScoreType_10(nativeObj);
- }
- //
- // C++: void cv::ORB::setPatchSize(int patchSize)
- //
- public void setPatchSize(int patchSize)
- {
- ThrowIfDisposed();
- features2d_ORB_setPatchSize_10(nativeObj, patchSize);
- }
- //
- // C++: int cv::ORB::getPatchSize()
- //
- public int getPatchSize()
- {
- ThrowIfDisposed();
- return features2d_ORB_getPatchSize_10(nativeObj);
- }
- //
- // C++: void cv::ORB::setFastThreshold(int fastThreshold)
- //
- public void setFastThreshold(int fastThreshold)
- {
- ThrowIfDisposed();
- features2d_ORB_setFastThreshold_10(nativeObj, fastThreshold);
- }
- //
- // C++: int cv::ORB::getFastThreshold()
- //
- public int getFastThreshold()
- {
- ThrowIfDisposed();
- return features2d_ORB_getFastThreshold_10(nativeObj);
- }
- //
- // C++: String cv::ORB::getDefaultName()
- //
- public override string getDefaultName()
- {
- ThrowIfDisposed();
- string retVal = Marshal.PtrToStringAnsi(DisposableObject.ThrowIfNullIntPtr(features2d_ORB_getDefaultName_10(nativeObj)));
- return retVal;
- }
- #if (UNITY_IOS || UNITY_WEBGL) && !UNITY_EDITOR
- const string LIBNAME = "__Internal";
- #else
- const string LIBNAME = "opencvforunity";
- #endif
- // C++: static Ptr_ORB cv::ORB::create(int nfeatures = 500, float scaleFactor = 1.2f, int nlevels = 8, int edgeThreshold = 31, int firstLevel = 0, int WTA_K = 2, ORB_ScoreType scoreType = ORB::HARRIS_SCORE, int patchSize = 31, int fastThreshold = 20)
- [DllImport(LIBNAME)]
- private static extern IntPtr features2d_ORB_create_10(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold, int firstLevel, int WTA_K, int scoreType, int patchSize, int fastThreshold);
- [DllImport(LIBNAME)]
- private static extern IntPtr features2d_ORB_create_11(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold, int firstLevel, int WTA_K, int scoreType, int patchSize);
- [DllImport(LIBNAME)]
- private static extern IntPtr features2d_ORB_create_12(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold, int firstLevel, int WTA_K, int scoreType);
- [DllImport(LIBNAME)]
- private static extern IntPtr features2d_ORB_create_13(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold, int firstLevel, int WTA_K);
- [DllImport(LIBNAME)]
- private static extern IntPtr features2d_ORB_create_14(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold, int firstLevel);
- [DllImport(LIBNAME)]
- private static extern IntPtr features2d_ORB_create_15(int nfeatures, float scaleFactor, int nlevels, int edgeThreshold);
- [DllImport(LIBNAME)]
- private static extern IntPtr features2d_ORB_create_16(int nfeatures, float scaleFactor, int nlevels);
- [DllImport(LIBNAME)]
- private static extern IntPtr features2d_ORB_create_17(int nfeatures, float scaleFactor);
- [DllImport(LIBNAME)]
- private static extern IntPtr features2d_ORB_create_18(int nfeatures);
- [DllImport(LIBNAME)]
- private static extern IntPtr features2d_ORB_create_19();
- // C++: void cv::ORB::setMaxFeatures(int maxFeatures)
- [DllImport(LIBNAME)]
- private static extern void features2d_ORB_setMaxFeatures_10(IntPtr nativeObj, int maxFeatures);
- // C++: int cv::ORB::getMaxFeatures()
- [DllImport(LIBNAME)]
- private static extern int features2d_ORB_getMaxFeatures_10(IntPtr nativeObj);
- // C++: void cv::ORB::setScaleFactor(double scaleFactor)
- [DllImport(LIBNAME)]
- private static extern void features2d_ORB_setScaleFactor_10(IntPtr nativeObj, double scaleFactor);
- // C++: double cv::ORB::getScaleFactor()
- [DllImport(LIBNAME)]
- private static extern double features2d_ORB_getScaleFactor_10(IntPtr nativeObj);
- // C++: void cv::ORB::setNLevels(int nlevels)
- [DllImport(LIBNAME)]
- private static extern void features2d_ORB_setNLevels_10(IntPtr nativeObj, int nlevels);
- // C++: int cv::ORB::getNLevels()
- [DllImport(LIBNAME)]
- private static extern int features2d_ORB_getNLevels_10(IntPtr nativeObj);
- // C++: void cv::ORB::setEdgeThreshold(int edgeThreshold)
- [DllImport(LIBNAME)]
- private static extern void features2d_ORB_setEdgeThreshold_10(IntPtr nativeObj, int edgeThreshold);
- // C++: int cv::ORB::getEdgeThreshold()
- [DllImport(LIBNAME)]
- private static extern int features2d_ORB_getEdgeThreshold_10(IntPtr nativeObj);
- // C++: void cv::ORB::setFirstLevel(int firstLevel)
- [DllImport(LIBNAME)]
- private static extern void features2d_ORB_setFirstLevel_10(IntPtr nativeObj, int firstLevel);
- // C++: int cv::ORB::getFirstLevel()
- [DllImport(LIBNAME)]
- private static extern int features2d_ORB_getFirstLevel_10(IntPtr nativeObj);
- // C++: void cv::ORB::setWTA_K(int wta_k)
- [DllImport(LIBNAME)]
- private static extern void features2d_ORB_setWTA_1K_10(IntPtr nativeObj, int wta_k);
- // C++: int cv::ORB::getWTA_K()
- [DllImport(LIBNAME)]
- private static extern int features2d_ORB_getWTA_1K_10(IntPtr nativeObj);
- // C++: void cv::ORB::setScoreType(ORB_ScoreType scoreType)
- [DllImport(LIBNAME)]
- private static extern void features2d_ORB_setScoreType_10(IntPtr nativeObj, int scoreType);
- // C++: ORB_ScoreType cv::ORB::getScoreType()
- [DllImport(LIBNAME)]
- private static extern int features2d_ORB_getScoreType_10(IntPtr nativeObj);
- // C++: void cv::ORB::setPatchSize(int patchSize)
- [DllImport(LIBNAME)]
- private static extern void features2d_ORB_setPatchSize_10(IntPtr nativeObj, int patchSize);
- // C++: int cv::ORB::getPatchSize()
- [DllImport(LIBNAME)]
- private static extern int features2d_ORB_getPatchSize_10(IntPtr nativeObj);
- // C++: void cv::ORB::setFastThreshold(int fastThreshold)
- [DllImport(LIBNAME)]
- private static extern void features2d_ORB_setFastThreshold_10(IntPtr nativeObj, int fastThreshold);
- // C++: int cv::ORB::getFastThreshold()
- [DllImport(LIBNAME)]
- private static extern int features2d_ORB_getFastThreshold_10(IntPtr nativeObj);
- // C++: String cv::ORB::getDefaultName()
- [DllImport(LIBNAME)]
- private static extern IntPtr features2d_ORB_getDefaultName_10(IntPtr nativeObj);
- // native support for java finalize()
- [DllImport(LIBNAME)]
- private static extern void features2d_ORB_delete(IntPtr nativeObj);
- }
- }
|