/*
* ====================================================
* 功能:折角检测。检测原理:计算纸张的理论四角顶点,到实际轮廓最小距离。当任意顶点到轮廓最小距离超过阈值,则判定为折角
* 作者:刘丁维
* 生成时间:2020/10/30
* 最近修改时间:2020/10/30
* 版本号:v1.0
* ====================================================
*/
#ifndef IMAGE_APPLY_DOGEAR_DETECTION_H
#define IMAGE_APPLY_DOGEAR_DETECTION_H
#include "ImageApply.h"
class CImageApplyDogEarDetection :public CImageApply
{
public:
///
/// 折角检测默认构造函数,threshold = 40, zoom = 1.0, distance = 50
///
CImageApplyDogEarDetection();
///
/// 折角检测构造函数
///
/// 二值化阈值
/// 原图缩放比例,对于大尺寸图像而言通过zoom缩小图像可减少计算量。默认值1.0(不缩放)
/// 理论顶点到实际轮廓最小距离的阈值,大于该阈值则判定为折角,默认值50(像素)
CImageApplyDogEarDetection(double threshlod, double zoom = 1.0, double distance = 50);
virtual ~CImageApplyDogEarDetection(void);
///
/// 获取检测结果。该函数须在调用apply之后使用。
///
/// true为折角,false为不折角
inline bool getResult() { return m_result; }
virtual void apply(cv::Mat& pDib, int side);
private:
virtual void apply(std::vector& mats, bool isTwoSide);
private:
double m_threshold;
double m_zoom;
double m_distance;
bool m_result;
};
#endif // IMAGE_APPLY_DOGEAR_DETECTION_H