当前位置:网站首页>Opencv learning log 15 count the number of solder joints and output

Opencv learning log 15 count the number of solder joints and output

2022-07-06 15:43:00 @Spring sauce

Preface

This article is mainly about opencv How to count and output the number of solder joints in .

One 、 Code

#include <opencv2/opencv.hpp>
#include <iostream>
using namespace cv;

int main()
{
    
	cv::Mat srcMat = imread("C://Users//john//Desktop//1.jpg", 0);
	cv::Mat resMat;
	cv::Mat resover;
	cv::Mat resover_dec;
	cv::Mat resover_sign;
	cv::Mat Matstate;
	cv::Mat center;
	cv::Mat kernel(14, 14, CV_8UC1);
	// imshow("src", srcMat);
	threshold(srcMat, resMat, 100, 255, THRESH_OTSU);  // Dajin law 
	bitwise_not(resMat, resover);
	imshow("resover", resover);
	morphologyEx(resover, resover_dec, 2, kernel, Point(0, 0), 1, BORDER_CONSTANT, morphologyDefaultBorderValue());// corrosion 
	imshow("resover_dec", resover_dec);
	connectedComponentsWithStats(resover_dec, resover_sign, Matstate, center, 8, CV_32S);  // Connected domain markers  
	int line = 0;
	int dotnum = 0;
	int i;
	line = Matstate.rows;
	for (i = 0; i < Matstate.rows; i++)
	{
    
		if (Matstate.at<int>(i, 4) >= 100)
		{
    

			dotnum = dotnum + 1;
			cv::Rect rect;
			rect.x = Matstate.at<int>(i, 0);
			rect.y = Matstate.at<int>(i, 1);
			rect.width = Matstate.at<int>(i, 2);
			rect.height = Matstate.at<int>(i, 3);
			rectangle(resover_dec, rect, CV_RGB(255, 255, 255), 1, 8, 0);
		}

	}
	std::cout << dotnum << std::endl;
	imshow("resover_dec", resover_dec);
	waitKey(0);
}

summary

1. The code can run directly , If you don't understand, please leave a message .

原网站

版权声明
本文为[@Spring sauce]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/02/202202131317245043.html