Made samples build independent from nonfree module.
(cherry picked from commit bba8c0beac)
			
			
This commit is contained in:
		| @@ -4,8 +4,9 @@ | ||||
| # ---------------------------------------------------------------------------- | ||||
|  | ||||
| SET(OPENCV_CPP_SAMPLES_REQUIRED_DEPS opencv_core opencv_flann opencv_imgproc | ||||
|     opencv_highgui opencv_ml opencv_video opencv_objdetect opencv_photo opencv_nonfree | ||||
|     opencv_features2d opencv_calib3d opencv_legacy opencv_contrib opencv_stitching opencv_videostab) | ||||
|     opencv_highgui opencv_ml opencv_video opencv_objdetect opencv_photo | ||||
|     opencv_features2d opencv_calib3d opencv_legacy opencv_contrib | ||||
|     opencv_stitching opencv_videostab) | ||||
|  | ||||
| ocv_check_dependencies(${OPENCV_CPP_SAMPLES_REQUIRED_DEPS}) | ||||
|  | ||||
|   | ||||
| @@ -1,29 +1,41 @@ | ||||
| #include "opencv2/opencv_modules.hpp" | ||||
| #include "opencv2/highgui/highgui.hpp" | ||||
| #include "opencv2/imgproc/imgproc.hpp" | ||||
| #include "opencv2/features2d/features2d.hpp" | ||||
| #include "opencv2/nonfree/nonfree.hpp" | ||||
| #include "opencv2/ml/ml.hpp" | ||||
| #ifdef HAVE_OPENCV_OCL | ||||
| #define _OCL_SVM_ 1 //select whether using ocl::svm method or not, default is using | ||||
| #include "opencv2/ocl/ocl.hpp" | ||||
| #endif | ||||
|  | ||||
| #include <fstream> | ||||
| #include <iostream> | ||||
| #include <memory> | ||||
| #include <functional> | ||||
|  | ||||
| #if defined WIN32 || defined _WIN32 | ||||
| #define WIN32_LEAN_AND_MEAN | ||||
| #include <windows.h> | ||||
| #undef min | ||||
| #undef max | ||||
| #include "sys/types.h" | ||||
| #endif | ||||
| #include <sys/stat.h> | ||||
| #ifndef HAVE_OPENCV_NONFREE | ||||
|  | ||||
| #define DEBUG_DESC_PROGRESS | ||||
| int main(int, char**) | ||||
| { | ||||
|     std::cout << "The sample requires nonfree module that is not available in your OpenCV distribution." << std::endl; | ||||
|     return -1; | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| # include "opencv2/highgui/highgui.hpp" | ||||
| # include "opencv2/imgproc/imgproc.hpp" | ||||
| # include "opencv2/features2d/features2d.hpp" | ||||
| # include "opencv2/nonfree/nonfree.hpp" | ||||
| # include "opencv2/ml/ml.hpp" | ||||
| # ifdef HAVE_OPENCV_OCL | ||||
| # define _OCL_SVM_ 1 //select whether using ocl::svm method or not, default is using | ||||
| #  include "opencv2/ocl/ocl.hpp" | ||||
| # endif | ||||
|  | ||||
| # include <fstream> | ||||
| # include <memory> | ||||
| # include <functional> | ||||
|  | ||||
|  | ||||
| # if defined WIN32 || defined _WIN32 | ||||
| #  define WIN32_LEAN_AND_MEAN | ||||
| #  include <windows.h> | ||||
| #  undef min | ||||
| #  undef max | ||||
| #  include "sys/types.h" | ||||
| # endif | ||||
| # include <sys/stat.h> | ||||
|  | ||||
| # define DEBUG_DESC_PROGRESS | ||||
|  | ||||
| using namespace cv; | ||||
| using namespace std; | ||||
| @@ -2623,3 +2635,5 @@ int main(int argc, char** argv) | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -1,8 +1,11 @@ | ||||
| #include "opencv2/opencv_modules.hpp" | ||||
| #include "opencv2/highgui/highgui.hpp" | ||||
| #include "opencv2/calib3d/calib3d.hpp" | ||||
| #include "opencv2/imgproc/imgproc.hpp" | ||||
| #include "opencv2/features2d/features2d.hpp" | ||||
| #include "opencv2/nonfree/nonfree.hpp" | ||||
| #ifdef HAVE_OPENCV_NONFREE | ||||
| # include "opencv2/nonfree/nonfree.hpp" | ||||
| #endif | ||||
|  | ||||
| #include <iostream> | ||||
|  | ||||
| @@ -17,14 +20,14 @@ static void help(char** argv) | ||||
|      << "Case1: second image is obtained from the first (given) image using random generated homography matrix\n" | ||||
|      << argv[0] << " [detectorType] [descriptorType] [matcherType] [matcherFilterType] [image] [evaluate(0 or 1)]\n" | ||||
|      << "Example of case1:\n" | ||||
|      << "./descriptor_extractor_matcher SURF SURF FlannBased NoneFilter cola.jpg 0\n" | ||||
|      << "./descriptor_extractor_matcher ORB ORB FlannBased NoneFilter cola.jpg 0\n" | ||||
|      << "\n" | ||||
|      << "Case2: both images are given. If ransacReprojThreshold>=0 then homography matrix are calculated\n" | ||||
|      << argv[0] << " [detectorType] [descriptorType] [matcherType] [matcherFilterType] [image1] [image2] [ransacReprojThreshold]\n" | ||||
|      << "\n" | ||||
|      << "Matches are filtered using homography matrix in case1 and case2 (if ransacReprojThreshold>=0)\n" | ||||
|      << "Example of case2:\n" | ||||
|      << "./descriptor_extractor_matcher SURF SURF BruteForce CrossCheckFilter cola1.jpg cola2.jpg 3\n" | ||||
|      << "./descriptor_extractor_matcher ORB ORB BruteForce CrossCheckFilter cola1.jpg cola2.jpg 3\n" | ||||
|      << "\n" | ||||
|      << "Possible detectorType values: see in documentation on createFeatureDetector().\n" | ||||
|      << "Possible descriptorType values: see in documentation on createDescriptorExtractor().\n" | ||||
| @@ -239,7 +242,11 @@ int main(int argc, char** argv) | ||||
|         return -1; | ||||
|     } | ||||
|  | ||||
| #ifdef HAVE_OPENCV_NONFREE | ||||
|     cv::initModule_nonfree(); | ||||
| #else | ||||
|     cout << "Warning: OpenCV is built without nonfree support SIFT, SURF and some other algorithms are not available." << endl; | ||||
| #endif | ||||
|  | ||||
|     bool isWarpPerspective = argc == 7; | ||||
|     double ransacReprojThreshold = -1; | ||||
|   | ||||
| @@ -49,9 +49,21 @@ | ||||
| // | ||||
| //M*/ | ||||
|  | ||||
| #include "opencv2/opencv_modules.hpp" | ||||
| #include <iostream> | ||||
|  | ||||
| #include "opencv2/opencv.hpp" | ||||
| #include "opencv2/nonfree/nonfree.hpp" | ||||
| #ifndef HAVE_OPENCV_NONFREE | ||||
|  | ||||
| int main(int, char**) | ||||
| { | ||||
|     std::cout << "The sample requires nonfree module that is not available in your OpenCV distribution." << std::endl; | ||||
|     return -1; | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| # include "opencv2/opencv.hpp" | ||||
| # include "opencv2/nonfree/nonfree.hpp" | ||||
|  | ||||
| using namespace cv; | ||||
| using namespace std; | ||||
| @@ -212,3 +224,5 @@ int main(int argc, char * argv[]) { | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -34,15 +34,27 @@ | ||||
| //  or tort (including negligence or otherwise) arising in any way out of | ||||
| //  the use of this software, even if advised of the possibility of such damage. | ||||
|  | ||||
| #include "opencv2/opencv_modules.hpp" | ||||
| #include <iostream> | ||||
| #include <string> | ||||
| #include <vector> | ||||
|  | ||||
| #include <opencv2/core/core.hpp> | ||||
| #include <opencv2/highgui/highgui.hpp> | ||||
| #include <opencv2/features2d/features2d.hpp> | ||||
| #include <opencv2/nonfree/features2d.hpp> | ||||
| #include <opencv2/legacy/legacy.hpp> | ||||
| #ifndef HAVE_OPENCV_NONFREE | ||||
|  | ||||
| int main(int, char**) | ||||
| { | ||||
|     std::cout << "The sample requires nonfree module that is not available in your OpenCV distribution." << std::endl; | ||||
|     return -1; | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| # include <string> | ||||
| # include <vector> | ||||
|  | ||||
| # include <opencv2/core/core.hpp> | ||||
| # include <opencv2/highgui/highgui.hpp> | ||||
| # include <opencv2/features2d/features2d.hpp> | ||||
| # include <opencv2/nonfree/features2d.hpp> | ||||
| # include <opencv2/legacy/legacy.hpp> | ||||
|  | ||||
| using namespace cv; | ||||
|  | ||||
| @@ -126,3 +138,5 @@ int main( int argc, char** argv ) { | ||||
|     imshow("matches", imgMatch); | ||||
|     waitKey(0); | ||||
| } | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -1,11 +1,23 @@ | ||||
| #include "opencv2/calib3d/calib3d.hpp" | ||||
| #include "opencv2/features2d/features2d.hpp" | ||||
| #include "opencv2/highgui/highgui.hpp" | ||||
| #include "opencv2/imgproc/imgproc.hpp" | ||||
| #include "opencv2/nonfree/nonfree.hpp" | ||||
|  | ||||
| #include "opencv2/opencv_modules.hpp" | ||||
| #include <cstdio> | ||||
|  | ||||
| #ifndef HAVE_OPENCV_NONFREE | ||||
|  | ||||
| int main(int, char**) | ||||
| { | ||||
|     printf("The sample requires nonfree module that is not available in your OpenCV distribution.\n"); | ||||
|     return -1; | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| # include "opencv2/opencv_modules.hpp" | ||||
| # include "opencv2/calib3d/calib3d.hpp" | ||||
| # include "opencv2/features2d/features2d.hpp" | ||||
| # include "opencv2/highgui/highgui.hpp" | ||||
| # include "opencv2/imgproc/imgproc.hpp" | ||||
| # include "opencv2/nonfree/nonfree.hpp" | ||||
|  | ||||
| using namespace cv; | ||||
|  | ||||
| static void help() | ||||
| @@ -91,3 +103,5 @@ Mat DrawCorrespondences(const Mat& img1, const vector<KeyPoint>& features1, cons | ||||
|  | ||||
|     return img_corr; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -1,8 +1,20 @@ | ||||
| #include "opencv2/opencv_modules.hpp" | ||||
| #include <stdio.h> | ||||
| #include "opencv2/core/core.hpp" | ||||
| #include "opencv2/features2d/features2d.hpp" | ||||
| #include "opencv2/highgui/highgui.hpp" | ||||
| #include "opencv2/nonfree/nonfree.hpp" | ||||
|  | ||||
| #ifndef HAVE_OPENCV_NONFREE | ||||
|  | ||||
| int main(int, char**) | ||||
| { | ||||
|     printf("The sample requires nonfree module that is not available in your OpenCV distribution.\n"); | ||||
|     return -1; | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| # include "opencv2/core/core.hpp" | ||||
| # include "opencv2/features2d/features2d.hpp" | ||||
| # include "opencv2/highgui/highgui.hpp" | ||||
| # include "opencv2/nonfree/nonfree.hpp" | ||||
|  | ||||
| using namespace cv; | ||||
|  | ||||
| @@ -56,3 +68,5 @@ int main(int argc, char** argv) | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -4,12 +4,23 @@ | ||||
|  * @author A. Huaman | ||||
|  */ | ||||
|  | ||||
| #include "opencv2/opencv_modules.hpp" | ||||
| #include <stdio.h> | ||||
| #include <iostream> | ||||
| #include "opencv2/core/core.hpp" | ||||
| #include "opencv2/features2d/features2d.hpp" | ||||
| #include "opencv2/highgui/highgui.hpp" | ||||
| #include "opencv2/nonfree/features2d.hpp" | ||||
|  | ||||
| #ifndef HAVE_OPENCV_NONFREE | ||||
|  | ||||
| int main(int, char**) | ||||
| { | ||||
|     printf("The sample requires nonfree module that is not available in your OpenCV distribution.\n"); | ||||
|     return -1; | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| # include "opencv2/core/core.hpp" | ||||
| # include "opencv2/features2d/features2d.hpp" | ||||
| # include "opencv2/highgui/highgui.hpp" | ||||
| # include "opencv2/nonfree/features2d.hpp" | ||||
|  | ||||
| using namespace cv; | ||||
|  | ||||
| @@ -28,7 +39,7 @@ int main( int argc, char** argv ) | ||||
|   Mat img_2 = imread( argv[2], CV_LOAD_IMAGE_GRAYSCALE ); | ||||
|  | ||||
|   if( !img_1.data || !img_2.data ) | ||||
|   { std::cout<< " --(!) Error reading images " << std::endl; return -1; } | ||||
|   { printf(" --(!) Error reading images \n"); return -1; } | ||||
|  | ||||
|   //-- Step 1: Detect the keypoints using SURF Detector | ||||
|   int minHessian = 400; | ||||
| @@ -97,4 +108,6 @@ int main( int argc, char** argv ) | ||||
|  * @function readme | ||||
|  */ | ||||
| void readme() | ||||
| { std::cout << " Usage: ./SURF_FlannMatcher <img1> <img2>" << std::endl; } | ||||
| { printf(" Usage: ./SURF_FlannMatcher <img1> <img2>\n"); } | ||||
|  | ||||
| #endif | ||||
| @@ -4,13 +4,24 @@ | ||||
|  * @author A. Huaman | ||||
|  */ | ||||
|  | ||||
| #include "opencv2/opencv_modules.hpp" | ||||
| #include <stdio.h> | ||||
| #include <iostream> | ||||
| #include "opencv2/core/core.hpp" | ||||
| #include "opencv2/features2d/features2d.hpp" | ||||
| #include "opencv2/highgui/highgui.hpp" | ||||
| #include "opencv2/calib3d/calib3d.hpp" | ||||
| #include "opencv2/nonfree/features2d.hpp" | ||||
|  | ||||
| #ifndef HAVE_OPENCV_NONFREE | ||||
|  | ||||
| int main(int, char**) | ||||
| { | ||||
|     printf("The sample requires nonfree module that is not available in your OpenCV distribution.\n"); | ||||
|     return -1; | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| # include "opencv2/core/core.hpp" | ||||
| # include "opencv2/features2d/features2d.hpp" | ||||
| # include "opencv2/highgui/highgui.hpp" | ||||
| # include "opencv2/calib3d/calib3d.hpp" | ||||
| # include "opencv2/nonfree/features2d.hpp" | ||||
|  | ||||
| using namespace cv; | ||||
|  | ||||
| @@ -29,7 +40,7 @@ int main( int argc, char** argv ) | ||||
|   Mat img_scene = imread( argv[2], CV_LOAD_IMAGE_GRAYSCALE ); | ||||
|  | ||||
|   if( !img_object.data || !img_scene.data ) | ||||
|   { std::cout<< " --(!) Error reading images " << std::endl; return -1; } | ||||
|   { printf(" --(!) Error reading images \n"); return -1; } | ||||
|  | ||||
|   //-- Step 1: Detect the keypoints using SURF Detector | ||||
|   int minHessian = 400; | ||||
| @@ -121,4 +132,6 @@ int main( int argc, char** argv ) | ||||
|  * @function readme | ||||
|  */ | ||||
| void readme() | ||||
| { std::cout << " Usage: ./SURF_Homography <img1> <img2>" << std::endl; } | ||||
| { printf(" Usage: ./SURF_Homography <img1> <img2>\n"); } | ||||
|  | ||||
| #endif | ||||
| @@ -4,12 +4,23 @@ | ||||
|  * @author A. Huaman | ||||
|  */ | ||||
|  | ||||
| #include "opencv2/opencv_modules.hpp" | ||||
| #include <stdio.h> | ||||
| #include <iostream> | ||||
| #include "opencv2/core/core.hpp" | ||||
| #include "opencv2/features2d/features2d.hpp" | ||||
| #include "opencv2/highgui/highgui.hpp" | ||||
| #include "opencv2/nonfree/features2d.hpp" | ||||
|  | ||||
| #ifndef HAVE_OPENCV_NONFREE | ||||
|  | ||||
| int main(int, char**) | ||||
| { | ||||
|     printf("The sample requires nonfree module that is not available in your OpenCV distribution.\n"); | ||||
|     return -1; | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| # include "opencv2/core/core.hpp" | ||||
| # include "opencv2/features2d/features2d.hpp" | ||||
| # include "opencv2/highgui/highgui.hpp" | ||||
| # include "opencv2/nonfree/features2d.hpp" | ||||
|  | ||||
| using namespace cv; | ||||
|  | ||||
| @@ -70,3 +81,5 @@ int main( int argc, char** argv ) | ||||
|  */ | ||||
| void readme() | ||||
| { std::cout << " Usage: ./SURF_descriptor <img1> <img2>" << std::endl; } | ||||
|  | ||||
| #endif | ||||
| @@ -4,12 +4,23 @@ | ||||
|  * @author A. Huaman | ||||
|  */ | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include "opencv2/opencv_modules.hpp" | ||||
| #include <iostream> | ||||
| #include "opencv2/core/core.hpp" | ||||
| #include "opencv2/features2d/features2d.hpp" | ||||
| #include "opencv2/highgui/highgui.hpp" | ||||
| #include "opencv2/nonfree/features2d.hpp" | ||||
|  | ||||
| #ifndef HAVE_OPENCV_NONFREE | ||||
|  | ||||
| int main(int, char**) | ||||
| { | ||||
|     std::cout << "The sample requires nonfree module that is not available in your OpenCV distribution." << std::endl; | ||||
|     return -1; | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| # include "opencv2/core/core.hpp" | ||||
| # include "opencv2/features2d/features2d.hpp" | ||||
| # include "opencv2/highgui/highgui.hpp" | ||||
| # include "opencv2/nonfree/features2d.hpp" | ||||
|  | ||||
| using namespace cv; | ||||
|  | ||||
| @@ -60,3 +71,5 @@ int main( int argc, char** argv ) | ||||
|  */ | ||||
| void readme() | ||||
| { std::cout << " Usage: ./SURF_detector <img1> <img2>" << std::endl; } | ||||
|  | ||||
| #endif | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Alexander Smorkalov
					Alexander Smorkalov