Made samples build independent from nonfree module.
(cherry picked from commit bba8c0beac)
			
			
This commit is contained in:
		| @@ -68,8 +68,14 @@ endif() | |||||||
|  |  | ||||||
| add_subdirectory(c) | add_subdirectory(c) | ||||||
| add_subdirectory(cpp) | add_subdirectory(cpp) | ||||||
| add_subdirectory(ocl) | ocv_check_dependencies(opencv_ocl) | ||||||
| add_subdirectory(gpu) | if (OCV_DEPENDENCIES_FOUND) | ||||||
|  |   add_subdirectory(ocl) | ||||||
|  | endif() | ||||||
|  | ocv_check_dependencies(opencv_gpu) | ||||||
|  | if (OCV_DEPENDENCIES_FOUND) | ||||||
|  |   add_subdirectory(gpu) | ||||||
|  | endif() | ||||||
|  |  | ||||||
| # | # | ||||||
| # END OF BUILD CASE 2: Build samples with library binaries | # END OF BUILD CASE 2: Build samples with library binaries | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
| # ---------------------------------------------------------------------------- | # ---------------------------------------------------------------------------- | ||||||
|  |  | ||||||
| SET(OPENCV_C_SAMPLES_REQUIRED_DEPS opencv_core opencv_flann opencv_imgproc | SET(OPENCV_C_SAMPLES_REQUIRED_DEPS opencv_core opencv_flann opencv_imgproc | ||||||
|     opencv_highgui opencv_ml opencv_video opencv_objdetect opencv_photo opencv_nonfree |     opencv_highgui opencv_ml opencv_video opencv_objdetect opencv_photo | ||||||
|     opencv_features2d opencv_calib3d opencv_legacy opencv_contrib) |     opencv_features2d opencv_calib3d opencv_legacy opencv_contrib) | ||||||
|  |  | ||||||
| ocv_check_dependencies(${OPENCV_C_SAMPLES_REQUIRED_DEPS}) | ocv_check_dependencies(${OPENCV_C_SAMPLES_REQUIRED_DEPS}) | ||||||
|   | |||||||
| @@ -4,19 +4,31 @@ | |||||||
|  * Author: Liu Liu |  * Author: Liu Liu | ||||||
|  * liuliu.1987+opencv@gmail.com |  * liuliu.1987+opencv@gmail.com | ||||||
|  */ |  */ | ||||||
| #include "opencv2/objdetect/objdetect.hpp" |  | ||||||
| #include "opencv2/features2d/features2d.hpp" |  | ||||||
| #include "opencv2/highgui/highgui.hpp" |  | ||||||
| #include "opencv2/calib3d/calib3d.hpp" |  | ||||||
| #include "opencv2/nonfree/nonfree.hpp" |  | ||||||
| #include "opencv2/imgproc/imgproc_c.h" |  | ||||||
| #include "opencv2/legacy/legacy.hpp" |  | ||||||
| #include "opencv2/legacy/compat.hpp" |  | ||||||
|  |  | ||||||
| #include <iostream> | #include "opencv2/opencv_modules.hpp" | ||||||
| #include <vector> |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
|  |  | ||||||
|  | #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/objdetect/objdetect.hpp" | ||||||
|  | # include "opencv2/features2d/features2d.hpp" | ||||||
|  | # include "opencv2/highgui/highgui.hpp" | ||||||
|  | # include "opencv2/calib3d/calib3d.hpp" | ||||||
|  | # include "opencv2/nonfree/nonfree.hpp" | ||||||
|  | # include "opencv2/imgproc/imgproc_c.h" | ||||||
|  | # include "opencv2/legacy/legacy.hpp" | ||||||
|  | # include "opencv2/legacy/compat.hpp" | ||||||
|  |  | ||||||
|  | # include <vector> | ||||||
|  |  | ||||||
| using namespace std; | using namespace std; | ||||||
| static void help() | static void help() | ||||||
| { | { | ||||||
| @@ -320,3 +332,5 @@ int main(int argc, char** argv) | |||||||
|  |  | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #endif | ||||||
|   | |||||||
| @@ -1,12 +1,25 @@ | |||||||
| #include "opencv2/highgui/highgui.hpp" | #include "opencv2/opencv_modules.hpp" | ||||||
| #include "opencv2/core/core.hpp" |  | ||||||
| #include "opencv2/imgproc/imgproc.hpp" |  | ||||||
| #include "opencv2/features2d/features2d.hpp" |  | ||||||
| #include "opencv2/nonfree/nonfree.hpp" |  | ||||||
| #include "opencv2/legacy/legacy.hpp" |  | ||||||
|  |  | ||||||
| #include <iostream> | #include <iostream> | ||||||
| #include <fstream> |  | ||||||
|  | #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/highgui/highgui.hpp" | ||||||
|  | # include "opencv2/core/core.hpp" | ||||||
|  | # include "opencv2/imgproc/imgproc.hpp" | ||||||
|  | # include "opencv2/features2d/features2d.hpp" | ||||||
|  | # include "opencv2/nonfree/nonfree.hpp" | ||||||
|  | # include "opencv2/legacy/legacy.hpp" | ||||||
|  |  | ||||||
|  | # include <iostream> | ||||||
|  | # include <fstream> | ||||||
|  |  | ||||||
| using namespace std; | using namespace std; | ||||||
| using namespace cv; | using namespace cv; | ||||||
| @@ -164,3 +177,5 @@ int main( int argc, char **argv ) | |||||||
|  |  | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #endif | ||||||
|   | |||||||
| @@ -7,16 +7,28 @@ | |||||||
|  * |  * | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include "opencv2/imgproc/imgproc.hpp" | #include "opencv2/opencv_modules.hpp" | ||||||
| #include "opencv2/features2d/features2d.hpp" | #include <stdio.h> | ||||||
| #include "opencv2/highgui/highgui.hpp" |  | ||||||
| #include "opencv2/imgproc/imgproc_c.h" | #ifndef HAVE_OPENCV_NONFREE | ||||||
| #include "opencv2/nonfree/nonfree.hpp" |  | ||||||
| #include "opencv2/legacy/legacy.hpp" | int main(int, char**) | ||||||
| #include "opencv2/legacy/compat.hpp" | { | ||||||
|  |     printf("The sample requires nonfree module that is not available in your OpenCV distribution.\n"); | ||||||
|  |     return -1; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #else | ||||||
|  |  | ||||||
|  | # include "opencv2/imgproc/imgproc.hpp" | ||||||
|  | # include "opencv2/features2d/features2d.hpp" | ||||||
|  | # include "opencv2/highgui/highgui.hpp" | ||||||
|  | # include "opencv2/imgproc/imgproc_c.h" | ||||||
|  | # include "opencv2/nonfree/nonfree.hpp" | ||||||
|  | # include "opencv2/legacy/legacy.hpp" | ||||||
|  | # include "opencv2/legacy/compat.hpp" | ||||||
|  |  | ||||||
| #include <string> | #include <string> | ||||||
| #include <stdio.h> |  | ||||||
|  |  | ||||||
| static void help() | static void help() | ||||||
| { | { | ||||||
| @@ -116,3 +128,5 @@ Mat DrawCorrespondences(const Mat& img1, const vector<KeyPoint>& features1, cons | |||||||
|  |  | ||||||
|     return img_corr; |     return img_corr; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #endif | ||||||
|   | |||||||
| @@ -4,8 +4,9 @@ | |||||||
| # ---------------------------------------------------------------------------- | # ---------------------------------------------------------------------------- | ||||||
|  |  | ||||||
| SET(OPENCV_CPP_SAMPLES_REQUIRED_DEPS opencv_core opencv_flann opencv_imgproc | 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_highgui opencv_ml opencv_video opencv_objdetect opencv_photo | ||||||
|     opencv_features2d opencv_calib3d opencv_legacy opencv_contrib opencv_stitching opencv_videostab) |     opencv_features2d opencv_calib3d opencv_legacy opencv_contrib | ||||||
|  |     opencv_stitching opencv_videostab) | ||||||
|  |  | ||||||
| ocv_check_dependencies(${OPENCV_CPP_SAMPLES_REQUIRED_DEPS}) | ocv_check_dependencies(${OPENCV_CPP_SAMPLES_REQUIRED_DEPS}) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,29 +1,41 @@ | |||||||
| #include "opencv2/opencv_modules.hpp" | #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 <iostream> | ||||||
| #include <memory> |  | ||||||
| #include <functional> |  | ||||||
|  |  | ||||||
| #if defined WIN32 || defined _WIN32 | #ifndef HAVE_OPENCV_NONFREE | ||||||
| #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 | 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 cv; | ||||||
| using namespace std; | using namespace std; | ||||||
| @@ -2623,3 +2635,5 @@ int main(int argc, char** argv) | |||||||
|     } |     } | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #endif | ||||||
|   | |||||||
| @@ -1,8 +1,11 @@ | |||||||
|  | #include "opencv2/opencv_modules.hpp" | ||||||
| #include "opencv2/highgui/highgui.hpp" | #include "opencv2/highgui/highgui.hpp" | ||||||
| #include "opencv2/calib3d/calib3d.hpp" | #include "opencv2/calib3d/calib3d.hpp" | ||||||
| #include "opencv2/imgproc/imgproc.hpp" | #include "opencv2/imgproc/imgproc.hpp" | ||||||
| #include "opencv2/features2d/features2d.hpp" | #include "opencv2/features2d/features2d.hpp" | ||||||
| #include "opencv2/nonfree/nonfree.hpp" | #ifdef HAVE_OPENCV_NONFREE | ||||||
|  | # include "opencv2/nonfree/nonfree.hpp" | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #include <iostream> | #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" |      << "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" |      << argv[0] << " [detectorType] [descriptorType] [matcherType] [matcherFilterType] [image] [evaluate(0 or 1)]\n" | ||||||
|      << "Example of case1:\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" |      << "\n" | ||||||
|      << "Case2: both images are given. If ransacReprojThreshold>=0 then homography matrix are calculated\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" |      << argv[0] << " [detectorType] [descriptorType] [matcherType] [matcherFilterType] [image1] [image2] [ransacReprojThreshold]\n" | ||||||
|      << "\n" |      << "\n" | ||||||
|      << "Matches are filtered using homography matrix in case1 and case2 (if ransacReprojThreshold>=0)\n" |      << "Matches are filtered using homography matrix in case1 and case2 (if ransacReprojThreshold>=0)\n" | ||||||
|      << "Example of case2:\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" |      << "\n" | ||||||
|      << "Possible detectorType values: see in documentation on createFeatureDetector().\n" |      << "Possible detectorType values: see in documentation on createFeatureDetector().\n" | ||||||
|      << "Possible descriptorType values: see in documentation on createDescriptorExtractor().\n" |      << "Possible descriptorType values: see in documentation on createDescriptorExtractor().\n" | ||||||
| @@ -239,7 +242,11 @@ int main(int argc, char** argv) | |||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | #ifdef HAVE_OPENCV_NONFREE | ||||||
|     cv::initModule_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; |     bool isWarpPerspective = argc == 7; | ||||||
|     double ransacReprojThreshold = -1; |     double ransacReprojThreshold = -1; | ||||||
|   | |||||||
| @@ -49,9 +49,21 @@ | |||||||
| // | // | ||||||
| //M*/ | //M*/ | ||||||
|  |  | ||||||
|  | #include "opencv2/opencv_modules.hpp" | ||||||
|  | #include <iostream> | ||||||
|  |  | ||||||
| #include "opencv2/opencv.hpp" | #ifndef HAVE_OPENCV_NONFREE | ||||||
| #include "opencv2/nonfree/nonfree.hpp" |  | ||||||
|  | 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 cv; | ||||||
| using namespace std; | using namespace std; | ||||||
| @@ -212,3 +224,5 @@ int main(int argc, char * argv[]) { | |||||||
|  |  | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #endif | ||||||
|   | |||||||
| @@ -34,15 +34,27 @@ | |||||||
| //  or tort (including negligence or otherwise) arising in any way out of | //  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. | //  the use of this software, even if advised of the possibility of such damage. | ||||||
|  |  | ||||||
|  | #include "opencv2/opencv_modules.hpp" | ||||||
| #include <iostream> | #include <iostream> | ||||||
| #include <string> |  | ||||||
| #include <vector> |  | ||||||
|  |  | ||||||
| #include <opencv2/core/core.hpp> | #ifndef HAVE_OPENCV_NONFREE | ||||||
| #include <opencv2/highgui/highgui.hpp> |  | ||||||
| #include <opencv2/features2d/features2d.hpp> | int main(int, char**) | ||||||
| #include <opencv2/nonfree/features2d.hpp> | { | ||||||
| #include <opencv2/legacy/legacy.hpp> |     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; | using namespace cv; | ||||||
|  |  | ||||||
| @@ -126,3 +138,5 @@ int main( int argc, char** argv ) { | |||||||
|     imshow("matches", imgMatch); |     imshow("matches", imgMatch); | ||||||
|     waitKey(0); |     waitKey(0); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #endif | ||||||
|   | |||||||
| @@ -1,11 +1,23 @@ | |||||||
| #include "opencv2/calib3d/calib3d.hpp" | #include "opencv2/opencv_modules.hpp" | ||||||
| #include "opencv2/features2d/features2d.hpp" |  | ||||||
| #include "opencv2/highgui/highgui.hpp" |  | ||||||
| #include "opencv2/imgproc/imgproc.hpp" |  | ||||||
| #include "opencv2/nonfree/nonfree.hpp" |  | ||||||
|  |  | ||||||
| #include <cstdio> | #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; | using namespace cv; | ||||||
|  |  | ||||||
| static void help() | static void help() | ||||||
| @@ -91,3 +103,5 @@ Mat DrawCorrespondences(const Mat& img1, const vector<KeyPoint>& features1, cons | |||||||
|  |  | ||||||
|     return img_corr; |     return img_corr; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #endif | ||||||
|   | |||||||
| @@ -1,8 +1,20 @@ | |||||||
|  | #include "opencv2/opencv_modules.hpp" | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include "opencv2/core/core.hpp" |  | ||||||
| #include "opencv2/features2d/features2d.hpp" | #ifndef HAVE_OPENCV_NONFREE | ||||||
| #include "opencv2/highgui/highgui.hpp" |  | ||||||
| #include "opencv2/nonfree/nonfree.hpp" | 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; | using namespace cv; | ||||||
|  |  | ||||||
| @@ -56,3 +68,5 @@ int main(int argc, char** argv) | |||||||
|  |  | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #endif | ||||||
|   | |||||||
| @@ -4,12 +4,23 @@ | |||||||
|  * @author A. Huaman |  * @author A. Huaman | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  | #include "opencv2/opencv_modules.hpp" | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <iostream> |  | ||||||
| #include "opencv2/core/core.hpp" | #ifndef HAVE_OPENCV_NONFREE | ||||||
| #include "opencv2/features2d/features2d.hpp" |  | ||||||
| #include "opencv2/highgui/highgui.hpp" | int main(int, char**) | ||||||
| #include "opencv2/nonfree/features2d.hpp" | { | ||||||
|  |     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; | using namespace cv; | ||||||
|  |  | ||||||
| @@ -28,7 +39,7 @@ int main( int argc, char** argv ) | |||||||
|   Mat img_2 = imread( argv[2], CV_LOAD_IMAGE_GRAYSCALE ); |   Mat img_2 = imread( argv[2], CV_LOAD_IMAGE_GRAYSCALE ); | ||||||
|  |  | ||||||
|   if( !img_1.data || !img_2.data ) |   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 |   //-- Step 1: Detect the keypoints using SURF Detector | ||||||
|   int minHessian = 400; |   int minHessian = 400; | ||||||
| @@ -97,4 +108,6 @@ int main( int argc, char** argv ) | |||||||
|  * @function readme |  * @function readme | ||||||
|  */ |  */ | ||||||
| void 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 |  * @author A. Huaman | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  | #include "opencv2/opencv_modules.hpp" | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <iostream> |  | ||||||
| #include "opencv2/core/core.hpp" | #ifndef HAVE_OPENCV_NONFREE | ||||||
| #include "opencv2/features2d/features2d.hpp" |  | ||||||
| #include "opencv2/highgui/highgui.hpp" | int main(int, char**) | ||||||
| #include "opencv2/calib3d/calib3d.hpp" | { | ||||||
| #include "opencv2/nonfree/features2d.hpp" |     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; | using namespace cv; | ||||||
|  |  | ||||||
| @@ -29,7 +40,7 @@ int main( int argc, char** argv ) | |||||||
|   Mat img_scene = imread( argv[2], CV_LOAD_IMAGE_GRAYSCALE ); |   Mat img_scene = imread( argv[2], CV_LOAD_IMAGE_GRAYSCALE ); | ||||||
|  |  | ||||||
|   if( !img_object.data || !img_scene.data ) |   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 |   //-- Step 1: Detect the keypoints using SURF Detector | ||||||
|   int minHessian = 400; |   int minHessian = 400; | ||||||
| @@ -121,4 +132,6 @@ int main( int argc, char** argv ) | |||||||
|  * @function readme |  * @function readme | ||||||
|  */ |  */ | ||||||
| void 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 |  * @author A. Huaman | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  | #include "opencv2/opencv_modules.hpp" | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <iostream> |  | ||||||
| #include "opencv2/core/core.hpp" | #ifndef HAVE_OPENCV_NONFREE | ||||||
| #include "opencv2/features2d/features2d.hpp" |  | ||||||
| #include "opencv2/highgui/highgui.hpp" | int main(int, char**) | ||||||
| #include "opencv2/nonfree/features2d.hpp" | { | ||||||
|  |     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; | using namespace cv; | ||||||
|  |  | ||||||
| @@ -70,3 +81,5 @@ int main( int argc, char** argv ) | |||||||
|  */ |  */ | ||||||
| void readme() | void readme() | ||||||
| { std::cout << " Usage: ./SURF_descriptor <img1> <img2>" << std::endl; } | { std::cout << " Usage: ./SURF_descriptor <img1> <img2>" << std::endl; } | ||||||
|  |  | ||||||
|  | #endif | ||||||
| @@ -4,12 +4,23 @@ | |||||||
|  * @author A. Huaman |  * @author A. Huaman | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include <stdio.h> | #include "opencv2/opencv_modules.hpp" | ||||||
| #include <iostream> | #include <iostream> | ||||||
| #include "opencv2/core/core.hpp" |  | ||||||
| #include "opencv2/features2d/features2d.hpp" | #ifndef HAVE_OPENCV_NONFREE | ||||||
| #include "opencv2/highgui/highgui.hpp" |  | ||||||
| #include "opencv2/nonfree/features2d.hpp" | 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; | using namespace cv; | ||||||
|  |  | ||||||
| @@ -60,3 +71,5 @@ int main( int argc, char** argv ) | |||||||
|  */ |  */ | ||||||
| void readme() | void readme() | ||||||
| { std::cout << " Usage: ./SURF_detector <img1> <img2>" << std::endl; } | { std::cout << " Usage: ./SURF_detector <img1> <img2>" << std::endl; } | ||||||
|  |  | ||||||
|  | #endif | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| SET(OPENCV_OCL_SAMPLES_REQUIRED_DEPS opencv_core opencv_flann opencv_imgproc opencv_highgui | SET(OPENCV_OCL_SAMPLES_REQUIRED_DEPS opencv_core opencv_flann opencv_imgproc opencv_highgui | ||||||
|                                      opencv_ml opencv_video opencv_objdetect opencv_features2d |                                      opencv_ml opencv_video opencv_objdetect opencv_features2d | ||||||
|                                      opencv_calib3d opencv_legacy opencv_contrib opencv_ocl |                                      opencv_calib3d opencv_legacy opencv_contrib opencv_ocl) | ||||||
|                                      opencv_nonfree) |  | ||||||
|  |  | ||||||
| ocv_check_dependencies(${OPENCV_OCL_SAMPLES_REQUIRED_DEPS}) | ocv_check_dependencies(${OPENCV_OCL_SAMPLES_REQUIRED_DEPS}) | ||||||
|  |  | ||||||
| @@ -52,7 +51,7 @@ if(BUILD_EXAMPLES AND OCV_DEPENDENCIES_FOUND) | |||||||
| endif() | endif() | ||||||
|  |  | ||||||
| if (OCV_DEPENDENCIES_FOUND AND INSTALL_C_EXAMPLES AND NOT WIN32) | if (OCV_DEPENDENCIES_FOUND AND INSTALL_C_EXAMPLES AND NOT WIN32) | ||||||
|   file(GLOB install_list *.c *.cpp *.jpg *.png *.data makefile.* build_all.sh *.dsp *.cmd *.txt) |   file(GLOB install_list *.c *.cpp *.jpg *.png *.data makefile.* *.txt) | ||||||
|   install(FILES ${install_list} |   install(FILES ${install_list} | ||||||
|           DESTINATION "${OPENCV_SAMPLES_SRC_INSTALL_PATH}/ocl" |           DESTINATION "${OPENCV_SAMPLES_SRC_INSTALL_PATH}/ocl" | ||||||
|           PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT samples) |           PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT samples) | ||||||
|   | |||||||
| @@ -1,11 +1,22 @@ | |||||||
|  | #include "opencv2/opencv_modules.hpp" | ||||||
| #include <iostream> | #include <iostream> | ||||||
| #include <stdio.h> |  | ||||||
| #include "opencv2/core/core.hpp" | #ifndef HAVE_OPENCV_NONFREE | ||||||
| #include "opencv2/highgui/highgui.hpp" |  | ||||||
| #include "opencv2/ocl/ocl.hpp" | int main(int, char**) | ||||||
| #include "opencv2/nonfree/ocl.hpp" | { | ||||||
| #include "opencv2/calib3d/calib3d.hpp" |     std::cout << "The sample requires nonfree module that is not available in your OpenCV distribution." << std::endl; | ||||||
| #include "opencv2/nonfree/nonfree.hpp" |     return -1; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #else | ||||||
|  |  | ||||||
|  | # include "opencv2/core/core.hpp" | ||||||
|  | # include "opencv2/highgui/highgui.hpp" | ||||||
|  | # include "opencv2/ocl/ocl.hpp" | ||||||
|  | # include "opencv2/nonfree/ocl.hpp" | ||||||
|  | # include "opencv2/calib3d/calib3d.hpp" | ||||||
|  | # include "opencv2/nonfree/nonfree.hpp" | ||||||
|  |  | ||||||
| using namespace cv; | using namespace cv; | ||||||
| using namespace cv::ocl; | using namespace cv::ocl; | ||||||
| @@ -326,3 +337,5 @@ int main(int argc, char* argv[]) | |||||||
|     waitKey(0); |     waitKey(0); | ||||||
|     return EXIT_SUCCESS; |     return EXIT_SUCCESS; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #endif | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Alexander Smorkalov
					Alexander Smorkalov