Files
deepin-ocr/3rdparty/opencv-4.5.4/samples/swift/ios/FaceDetection/FaceDetection/DetectionBasedTracker.mm
wangzhengyang 718c41634f feat: 切换后端至PaddleOCR-NCNN,切换工程为CMake
1.项目后端整体迁移至PaddleOCR-NCNN算法,已通过基本的兼容性测试
2.工程改为使用CMake组织,后续为了更好地兼容第三方库,不再提供QMake工程
3.重整权利声明文件,重整代码工程,确保最小化侵权风险

Log: 切换后端至PaddleOCR-NCNN,切换工程为CMake
Change-Id: I4d5d2c5d37505a4a24b389b1a4c5d12f17bfa38c
2022-05-10 10:22:11 +08:00

86 lines
2.5 KiB
Plaintext

//
// DetectionBasedTracker.mm
//
// Created by Giles Payne on 2020/04/05.
//
#import "DetectionBasedTracker.h"
#import "Mat.h"
#import "Rect2i.h"
#import "CVObjcUtil.h"
class CascadeDetectorAdapter: public cv::DetectionBasedTracker::IDetector
{
public:
CascadeDetectorAdapter(cv::Ptr<cv::CascadeClassifier> detector):IDetector(), Detector(detector) {}
void detect(const cv::Mat &Image, std::vector<cv::Rect> &objects)
{
Detector->detectMultiScale(Image, objects, scaleFactor, minNeighbours, 0, minObjSize, maxObjSize);
}
virtual ~CascadeDetectorAdapter() {}
private:
CascadeDetectorAdapter();
cv::Ptr<cv::CascadeClassifier> Detector;
};
struct DetectorAgregator
{
cv::Ptr<CascadeDetectorAdapter> mainDetector;
cv::Ptr<CascadeDetectorAdapter> trackingDetector;
cv::Ptr<cv::DetectionBasedTracker> tracker;
DetectorAgregator(cv::Ptr<CascadeDetectorAdapter>& _mainDetector, cv::Ptr<CascadeDetectorAdapter>& _trackingDetector):mainDetector(_mainDetector), trackingDetector(_trackingDetector) {
CV_Assert(_mainDetector);
CV_Assert(_trackingDetector);
cv::DetectionBasedTracker::Parameters DetectorParams;
tracker = cv::makePtr<cv::DetectionBasedTracker>(mainDetector, trackingDetector, DetectorParams);
}
};
@implementation DetectionBasedTracker {
DetectorAgregator* agregator;
}
- (instancetype)initWithCascadeName:(NSString*)cascadeName minFaceSize:(int)faceSize {
self = [super init];
if (self) {
auto mainDetector = cv::makePtr<CascadeDetectorAdapter>(cv::makePtr<cv::CascadeClassifier>(cascadeName.UTF8String));
auto trackingDetector = cv::makePtr<CascadeDetectorAdapter>(
cv::makePtr<cv::CascadeClassifier>(cascadeName.UTF8String));
agregator = new DetectorAgregator(mainDetector, trackingDetector);
if (faceSize > 0) {
agregator->mainDetector->setMinObjectSize(cv::Size(faceSize, faceSize));
}
}
return self;
}
- (void)dealloc
{
delete agregator;
}
- (void)start {
agregator->tracker->run();
}
- (void)stop {
agregator->tracker->stop();
}
- (void)setFaceSize:(int)size {
agregator->mainDetector->setMinObjectSize(cv::Size(size, size));
}
- (void)detect:(Mat*)imageGray faces:(NSMutableArray<Rect2i*>*)faces {
std::vector<cv::Rect> rectFaces;
agregator->tracker->process(*((cv::Mat*)imageGray.nativePtr));
agregator->tracker->getObjects(rectFaces);
CV2OBJC(cv::Rect, Rect2i, rectFaces, faces);
}
@end