 e845184843
			
		
	
	e845184843
	
	
	
		
			
			* #1538 from StevenPuttemans:bugfix_3283 * #1545 from alalek:ocl_test_fix_rng * #1551 from alalek:cmake_install_win * #1570 from ilya-lavrenov:ipp_warn_fix * #1573 from alalek:perf_simple_strategy * #1574 from alalek:svm_workaround * #1576 from alalek:ocl_fix_cl_double * #1577 from ilya-lavrenov:ocl_setto_opencl12 * #1578 from asmorkalov:android_fd_cp_fix * #1579 from ilya-lavrenov:ocl_norm * #1582 from sperrholz:ocl-arithm-additions * #1586 from ilya-lavrenov:ocl_setto_win_fix * #1589 from ilya-lavrenov:pr1582_fix * #1591 from alalek:ocl_remove_cl_hpp_h * #1592 from alalek:ocl_program_cache_update * #1593 from ilya-lavrenov:ocl_war_on_double * #1594 from ilya-lavrenov:ocl_perf * #1595 from alalek:cl_code_cleanup * #1596 from alalek:test_fix_run_py * #1597 from alalek:ocl_fix_cleanup * #1598 from alalek:ocl_fix_build_mac * #1599 from ilya-lavrenov:ocl_mac_kernel_warnings * #1601 from ilya-lavrenov:ocl_fix_tvl1_and_sparse * #1602 from alalek:ocl_test_dump_info * #1603 from ilya-lavrenov:ocl_disable_svm_noblas * #1605 from alalek:ocl_fixes * #1606 from ilya-lavrenov:ocl_imgproc * #1607 from ilya-lavrenov:ocl_fft_cleanup * #1608 from alalek:fix_warn_upd_haar * #1609 from ilya-lavrenov:ocl_some_optimization * #1610 from alalek:ocl_fix_perf_kalman * #1612 from alalek:ocl_fix_string_info * #1614 from ilya-lavrenov:ocl_svm_misprint * #1616 from ilya-lavrenov:ocl_cvtColor * #1617 from ilya-lavrenov:ocl_info * #1622 from a0byte:2.4 * #1625 from ilya-lavrenov:to_string Conflicts: cmake/OpenCVConfig.cmake cmake/OpenCVDetectPython.cmake cmake/OpenCVGenConfig.cmake modules/core/CMakeLists.txt modules/nonfree/src/surf.ocl.cpp modules/ocl/include/opencv2/ocl/ocl.hpp modules/ocl/include/opencv2/ocl/private/util.hpp modules/ocl/perf/main.cpp modules/ocl/src/arithm.cpp modules/ocl/src/cl_operations.cpp modules/ocl/src/cl_programcache.cpp modules/ocl/src/color.cpp modules/ocl/src/fft.cpp modules/ocl/src/filtering.cpp modules/ocl/src/gemm.cpp modules/ocl/src/haar.cpp modules/ocl/src/imgproc.cpp modules/ocl/src/matrix_operations.cpp modules/ocl/src/pyrlk.cpp modules/ocl/src/split_merge.cpp modules/ocl/src/svm.cpp modules/ocl/test/main.cpp modules/ocl/test/test_fft.cpp modules/ocl/test/test_moments.cpp modules/ocl/test/test_objdetect.cpp modules/ocl/test/test_optflow.cpp modules/ocl/test/utility.hpp modules/python/CMakeLists.txt modules/ts/include/opencv2/ts.hpp modules/ts/src/ts_perf.cpp samples/android/face-detection/jni/DetectionBasedTracker_jni.cpp
		
			
				
	
	
		
			252 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			252 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <DetectionBasedTracker_jni.h>
 | |
| #include <opencv2/core/core.hpp>
 | |
| #include <opencv2/contrib/detection_based_tracker.hpp>
 | |
| 
 | |
| #include <string>
 | |
| #include <vector>
 | |
| 
 | |
| #include <android/log.h>
 | |
| 
 | |
| #define LOG_TAG "FaceDetection/DetectionBasedTracker"
 | |
| #define LOGD(...) ((void)__android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__))
 | |
| 
 | |
| using namespace std;
 | |
| using namespace cv;
 | |
| 
 | |
| inline void vector_Rect_to_Mat(vector<Rect>& v_rect, Mat& mat)
 | |
| {
 | |
|     mat = Mat(v_rect, true);
 | |
| }
 | |
| 
 | |
| class CascadeDetectorAdapter: public DetectionBasedTracker::IDetector
 | |
| {
 | |
| public:
 | |
|     CascadeDetectorAdapter(cv::Ptr<cv::CascadeClassifier> detector):
 | |
|             IDetector(),
 | |
|             Detector(detector)
 | |
|     {
 | |
|         LOGD("CascadeDetectorAdapter::Detect::Detect");
 | |
|         CV_Assert(detector);
 | |
|     }
 | |
| 
 | |
|     void detect(const cv::Mat &Image, std::vector<cv::Rect> &objects)
 | |
|     {
 | |
|         LOGD("CascadeDetectorAdapter::Detect: begin");
 | |
|         LOGD("CascadeDetectorAdapter::Detect: scaleFactor=%.2f, minNeighbours=%d, minObjSize=(%dx%d), maxObjSize=(%dx%d)", scaleFactor, minNeighbours, minObjSize.width, minObjSize.height, maxObjSize.width, maxObjSize.height);
 | |
|         Detector->detectMultiScale(Image, objects, scaleFactor, minNeighbours, 0, minObjSize, maxObjSize);
 | |
|         LOGD("CascadeDetectorAdapter::Detect: end");
 | |
|     }
 | |
| 
 | |
|     virtual ~CascadeDetectorAdapter()
 | |
|     {
 | |
|         LOGD("CascadeDetectorAdapter::Detect::~Detect");
 | |
|     }
 | |
| 
 | |
| private:
 | |
|     CascadeDetectorAdapter();
 | |
|     cv::Ptr<cv::CascadeClassifier> Detector;
 | |
| };
 | |
| 
 | |
| struct DetectorAgregator
 | |
| {
 | |
|     cv::Ptr<CascadeDetectorAdapter> mainDetector;
 | |
|     cv::Ptr<CascadeDetectorAdapter> trackingDetector;
 | |
| 
 | |
|     cv::Ptr<DetectionBasedTracker> tracker;
 | |
|     DetectorAgregator(cv::Ptr<CascadeDetectorAdapter>& _mainDetector, cv::Ptr<CascadeDetectorAdapter>& _trackingDetector):
 | |
|             mainDetector(_mainDetector),
 | |
|             trackingDetector(_trackingDetector)
 | |
|     {
 | |
|         CV_Assert(_mainDetector);
 | |
|         CV_Assert(_trackingDetector);
 | |
| 
 | |
|         DetectionBasedTracker::Parameters DetectorParams;
 | |
|         tracker = makePtr<DetectionBasedTracker>(mainDetector, trackingDetector, DetectorParams);
 | |
|     }
 | |
| };
 | |
| 
 | |
| JNIEXPORT jlong JNICALL Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeCreateObject
 | |
| (JNIEnv * jenv, jclass, jstring jFileName, jint faceSize)
 | |
| {
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeCreateObject enter");
 | |
|     const char* jnamestr = jenv->GetStringUTFChars(jFileName, NULL);
 | |
|     string stdFileName(jnamestr);
 | |
|     jlong result = 0;
 | |
| 
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeCreateObject");
 | |
| 
 | |
|     try
 | |
|     {
 | |
|         cv::Ptr<CascadeDetectorAdapter> mainDetector = makePtr<CascadeDetectorAdapter>(
 | |
|             makePtr<CascadeClassifier>(stdFileName));
 | |
|         cv::Ptr<CascadeDetectorAdapter> trackingDetector = makePtr<CascadeDetectorAdapter>(
 | |
|             makePtr<CascadeClassifier>(stdFileName));
 | |
|         result = (jlong)new DetectorAgregator(mainDetector, trackingDetector);
 | |
|         if (faceSize > 0)
 | |
|         {
 | |
|             mainDetector->setMinObjectSize(Size(faceSize, faceSize));
 | |
|             //trackingDetector->setMinObjectSize(Size(faceSize, faceSize));
 | |
|         }
 | |
|     }
 | |
|     catch(cv::Exception& e)
 | |
|     {
 | |
|         LOGD("nativeCreateObject caught cv::Exception: %s", e.what());
 | |
|         jclass je = jenv->FindClass("org/opencv/core/CvException");
 | |
|         if(!je)
 | |
|             je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, e.what());
 | |
|     }
 | |
|         catch (...)
 | |
|         {
 | |
|         LOGD("nativeCreateObject caught unknown exception");
 | |
|         jclass je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, "Unknown exception in JNI code of DetectionBasedTracker.nativeCreateObject()");
 | |
|         return 0;
 | |
|     }
 | |
| 
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeCreateObject exit");
 | |
|     return result;
 | |
| }
 | |
| 
 | |
| JNIEXPORT void JNICALL Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeDestroyObject
 | |
| (JNIEnv * jenv, jclass, jlong thiz)
 | |
| {
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeDestroyObject");
 | |
| 
 | |
|     try
 | |
|     {
 | |
|         if(thiz != 0)
 | |
|         {
 | |
|             ((DetectorAgregator*)thiz)->tracker->stop();
 | |
|             delete (DetectorAgregator*)thiz;
 | |
|         }
 | |
|     }
 | |
|     catch(cv::Exception& e)
 | |
|     {
 | |
|         LOGD("nativeestroyObject caught cv::Exception: %s", e.what());
 | |
|         jclass je = jenv->FindClass("org/opencv/core/CvException");
 | |
|         if(!je)
 | |
|             je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, e.what());
 | |
|     }
 | |
|     catch (...)
 | |
|     {
 | |
|         LOGD("nativeDestroyObject caught unknown exception");
 | |
|         jclass je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, "Unknown exception in JNI code of DetectionBasedTracker.nativeDestroyObject()");
 | |
|     }
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeDestroyObject exit");
 | |
| }
 | |
| 
 | |
| JNIEXPORT void JNICALL Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeStart
 | |
| (JNIEnv * jenv, jclass, jlong thiz)
 | |
| {
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeStart");
 | |
| 
 | |
|     try
 | |
|     {
 | |
|         ((DetectorAgregator*)thiz)->tracker->run();
 | |
|     }
 | |
|     catch(cv::Exception& e)
 | |
|     {
 | |
|         LOGD("nativeStart caught cv::Exception: %s", e.what());
 | |
|         jclass je = jenv->FindClass("org/opencv/core/CvException");
 | |
|         if(!je)
 | |
|             je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, e.what());
 | |
|     }
 | |
|     catch (...)
 | |
|     {
 | |
|         LOGD("nativeStart caught unknown exception");
 | |
|         jclass je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, "Unknown exception in JNI code of DetectionBasedTracker.nativeStart()");
 | |
|     }
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeStart exit");
 | |
| }
 | |
| 
 | |
| JNIEXPORT void JNICALL Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeStop
 | |
| (JNIEnv * jenv, jclass, jlong thiz)
 | |
| {
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeStop");
 | |
| 
 | |
|     try
 | |
|     {
 | |
|         ((DetectorAgregator*)thiz)->tracker->stop();
 | |
|     }
 | |
|     catch(cv::Exception& e)
 | |
|     {
 | |
|         LOGD("nativeStop caught cv::Exception: %s", e.what());
 | |
|         jclass je = jenv->FindClass("org/opencv/core/CvException");
 | |
|         if(!je)
 | |
|             je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, e.what());
 | |
|     }
 | |
|     catch (...)
 | |
|     {
 | |
|         LOGD("nativeStop caught unknown exception");
 | |
|         jclass je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, "Unknown exception in JNI code of DetectionBasedTracker.nativeStop()");
 | |
|     }
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeStop exit");
 | |
| }
 | |
| 
 | |
| JNIEXPORT void JNICALL Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeSetFaceSize
 | |
| (JNIEnv * jenv, jclass, jlong thiz, jint faceSize)
 | |
| {
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeSetFaceSize -- BEGIN");
 | |
| 
 | |
|     try
 | |
|     {
 | |
|         if (faceSize > 0)
 | |
|         {
 | |
|             ((DetectorAgregator*)thiz)->mainDetector->setMinObjectSize(Size(faceSize, faceSize));
 | |
|             //((DetectorAgregator*)thiz)->trackingDetector->setMinObjectSize(Size(faceSize, faceSize));
 | |
|         }
 | |
|     }
 | |
|     catch(cv::Exception& e)
 | |
|     {
 | |
|         LOGD("nativeStop caught cv::Exception: %s", e.what());
 | |
|         jclass je = jenv->FindClass("org/opencv/core/CvException");
 | |
|         if(!je)
 | |
|             je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, e.what());
 | |
|     }
 | |
|     catch (...)
 | |
|     {
 | |
|         LOGD("nativeSetFaceSize caught unknown exception");
 | |
|         jclass je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, "Unknown exception in JNI code of DetectionBasedTracker.nativeSetFaceSize()");
 | |
|     }
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeSetFaceSize -- END");
 | |
| }
 | |
| 
 | |
| 
 | |
| JNIEXPORT void JNICALL Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeDetect
 | |
| (JNIEnv * jenv, jclass, jlong thiz, jlong imageGray, jlong faces)
 | |
| {
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeDetect");
 | |
| 
 | |
|     try
 | |
|     {
 | |
|         vector<Rect> RectFaces;
 | |
|         ((DetectorAgregator*)thiz)->tracker->process(*((Mat*)imageGray));
 | |
|         ((DetectorAgregator*)thiz)->tracker->getObjects(RectFaces);
 | |
|         *((Mat*)faces) = Mat(RectFaces, true);
 | |
|     }
 | |
|     catch(cv::Exception& e)
 | |
|     {
 | |
|         LOGD("nativeCreateObject caught cv::Exception: %s", e.what());
 | |
|         jclass je = jenv->FindClass("org/opencv/core/CvException");
 | |
|         if(!je)
 | |
|             je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, e.what());
 | |
|     }
 | |
|     catch (...)
 | |
|     {
 | |
|         LOGD("nativeDetect caught unknown exception");
 | |
|         jclass je = jenv->FindClass("java/lang/Exception");
 | |
|         jenv->ThrowNew(je, "Unknown exception in JNI code DetectionBasedTracker.nativeDetect()");
 | |
|     }
 | |
|     LOGD("Java_org_opencv_samples_facedetect_DetectionBasedTracker_nativeDetect END");
 | |
| }
 |