opencv复现Halcon太阳能硅片缺陷检测例程

2024-02-04 12:10

本文主要是介绍opencv复现Halcon太阳能硅片缺陷检测例程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 效果
  • 代码

效果

OK的:
在这里插入图片描述

NG的:
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

代码

   #define show(image)          cv::namedWindow(#image,cv::WINDOW_NORMAL);\cv::imshow(#image, image)int i = 1;while(1){cv::Mat src;QString  dir("D:\\QtProject\\Opencv_Example\\solar_cell\\solar_cell_");QString path;if(i>9)path = QString("%1%2%3").arg(dir).arg(i++).arg(".png");elsepath = QString("%1%2%3%4").arg(dir).arg("0").arg(i++).arg(".png");cout<<path.toStdString()<<endl;src = cv::imread(path.toStdString(), cv::IMREAD_COLOR);if (src.empty()) {cout << "Cannot load image" << endl;return;}show(src);cout<<__func__<<src.channels();cv::Mat rgbImages[3];cv::split(src,rgbImages);
//        cv::imshow("r",rgbImages[0]);
//        cv::imshow("g",rgbImages[1]);show(rgbImages[2]);cv::Mat bImageNot;cv::bitwise_not(rgbImages[2], bImageNot);show(bImageNot);cv::Mat ImageBinary;cv::threshold(bImageNot, ImageBinary, 159, 255, cv::THRESH_BINARY);show(ImageBinary);std::vector<std::vector<cv::Point> > contoursDefect;std::vector<cv::Vec4i> hierarchyDefect;cv::Mat regionOut = cv::Mat::zeros(ImageBinary.size(), ImageBinary.type());cv::Mat regionIn = cv::Mat::zeros(ImageBinary.size(), ImageBinary.type());cv::Mat goodSmallRegion = cv::Mat::zeros(ImageBinary.size(), ImageBinary.type());cv::Mat goodLongRegion = cv::Mat::zeros(ImageBinary.size(), ImageBinary.type());//cv::cvtColor(ImageBinary, canves,cv::COLOR_RGBA2RGB);cv::findContours(ImageBinary, contoursDefect, hierarchyDefect, cv::RETR_TREE, cv::CHAIN_APPROX_NONE);for (size_t i = 0; i < contoursDefect.size(); i++){cv::Mat contour(contoursDefect.at(i));//第i个轮廓double area = contourArea(contour);cv::RotatedRect minRect = cv::minAreaRect(contour);cv::Rect rect = minRect.boundingRect2f();if (area >= 3500 && area <= 5000 && rect.width >= 130 && rect.width <= 300){cv::drawContours(goodSmallRegion, contoursDefect, i, cv::Scalar(255), -1);}if (area >= 6000 && area <= 10000 && rect.width >= 350 && rect.width <= 550){cv::drawContours(goodLongRegion, contoursDefect, i, cv::Scalar(255), -1);}if(hierarchyDefect[i][3] == -1 && area > 15000){cv::drawContours(regionOut, contoursDefect, i, cv::Scalar(255), -1);}if(hierarchyDefect[i][3] != -1 && area > 15000){cv::drawContours(regionIn, contoursDefect, i, cv::Scalar(255), -1);}}show(goodSmallRegion);show(goodLongRegion);show(regionOut);show(regionIn);cv::Mat result;void morphologyOperate(goodSmallRegion, goodLongRegion, regionOut, regionIn, result);}

这篇关于opencv复现Halcon太阳能硅片缺陷检测例程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/677454

相关文章

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

c/c++的opencv实现图片膨胀

《c/c++的opencv实现图片膨胀》图像膨胀是形态学操作,通过结构元素扩张亮区填充孔洞、连接断开部分、加粗物体,OpenCV的cv::dilate函数实现该操作,本文就来介绍一下opencv图片... 目录什么是图像膨胀?结构元素 (KerChina编程nel)OpenCV 中的 cv::dilate() 函

qtcreater配置opencv遇到的坑及实践记录

《qtcreater配置opencv遇到的坑及实践记录》我配置opencv不管是按照网上的教程还是deepseek发现都有些问题,下面是我的配置方法以及实践成功的心得,感兴趣的朋友跟随小编一起看看吧... 目录电脑环境下载环境变量配置qmake加入外部库测试配置我配置opencv不管是按照网上的教程还是de

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展