OPENCV角点检测和亚像素级检测

 首先进行粗检测,函数goodFeaturesToTrack,存储进入corners中,然后cornerSubPix函数进行亚像素精确匹配,设置结束条件。

由于实际应用中线条较粗,因此

CORNER_BLOCKSIZE = 9;

CORNER_QUALITYLEVEL = 0.6;

其他参数可以微调。

    std::vector<cv::Point2f> corners;
    //double qualityLevel = 0.5;
    double minDistance = 10;
    int blockSize = CORNER_BLOCKSIZE, gradientSize = CORNER_BLOCKSIZE;
    bool useHarrisDetector = true;
    double k = 0.04;
    cv::Mat copy = img3.clone();
    cv::goodFeaturesToTrack( copy,
                         corners,
                         MAX_CORNERS,
                         CORNER_QUALITYLEVEL,
                         minDistance,
                         cv::Mat(),
                         blockSize,
                         gradientSize,
                         useHarrisDetector,
                         k );
    int radius = 4;
    for( size_t i = 0; i < corners.size(); i++ )
    {
        cv::circle( copy, corners[i], radius, cv::Scalar(rng.uniform(0,255), rng.uniform(0, 256), rng.uniform(0, 256)), cv::FILLED );
    } 

	cv::TermCriteria criteria = cv::TermCriteria(
					cv::TermCriteria::MAX_ITER + cv::TermCriteria::EPS,
					40,
					0.001);
 

	cv::cornerSubPix(img3, corners, cv::Size(CORNER_BLOCKSIZE, CORNER_BLOCKSIZE), cv::Size(-1, -1), criteria);
 
	for (int i = 0; i < corners.size(); i++)
	{
		cv::circle(img3, corners[i], radius, cv::Scalar(rng.uniform(0,255), rng.uniform(0, 256), rng.uniform(0, 256)), cv::FILLED );
  }
  

参考:https://docs.opencv.org/master/dd/d92/tutorial_corner_subpixels.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值