0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

分享两个OpenCV图像处理与分析的问题

OpenCV学堂 来源:OpenCV学堂 作者:gloomyfish 2022-08-22 09:40 次阅读

01

问题一:寻找靶心

cc1f6f48-2156-11ed-ba43-dac502259ad0.jpg

图一

02

问题二:寻找其中的缺失点

cc2b1a50-2156-11ed-ba43-dac502259ad0.png

图二

解决方法

01

寻找靶心

仔细观察图一,可以看到两个最直接的是靶心有十字交叉线,而在OpenCV形态学处理中,支持十字交叉结构元素,所以我们可以先检测两条线,然后获取十字交叉结构,最后对结构进行轮廓分析,获取中心点,即可获得最终的靶心位置,最终寻找到的靶心位置图示如下:

cc50fc02-2156-11ed-ba43-dac502259ad0.png

获取水平与垂直线如下:

cc64914a-2156-11ed-ba43-dac502259ad0.png

获取十字交叉线如下:

cc734aaa-2156-11ed-ba43-dac502259ad0.png

代码实现如下:

 1image=cv.imread("D:/images/zsxq/cross.jpg")
 2cv.imshow("input",image)
 3gray=cv.cvtColor(image,cv.COLOR_BGR2GRAY)
 4ret,binary=cv.threshold(gray,0,255,cv.THRESH_OTSU|cv.THRESH_BINARY_INV)
 5se1=cv.getStructuringElement(cv.MORPH_CROSS,(50,1))
 6se2=cv.getStructuringElement(cv.MORPH_CROSS,(1,50))
 7hline=cv.morphologyEx(binary,cv.MORPH_OPEN,se1)
 8vline=cv.morphologyEx(binary,cv.MORPH_OPEN,se2)
 9contours,hireachy=cv.findContours(hline,cv.RETR_EXTERNAL,cv.CHAIN_APPROX_SIMPLE)
10mask=np.zeros_like(hline)
11max=-1
12index=0
13forcntinrange(len(contours)):
14x,y,w,h=cv.boundingRect(contours[cnt])
15ifmax< w:
16        max = w
17        index = cnt
18cv.drawContours(mask, contours, index, (255), -1, 8)
19
20cv.imshow("vline", vline)
21contours, hireachy = cv.findContours(vline, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)
22max = -1
23index = 0
24for cnt in range(len(contours)):
25    x, y, w, h = cv.boundingRect(contours[cnt])
26    if max < h and x < int(gray.shape[1]*0.75):
27        max = h
28        index = cnt
29
30cv.drawContours(mask, contours, index, (255), -1, 8)
31cv.imshow("mask", mask)
32
33se3 = cv.getStructuringElement(cv.MORPH_CROSS, (13, 13))
34mask = cv.morphologyEx(mask, cv.MORPH_OPEN, se3)
35cv.imshow("corss", mask)
36contours, hireachy = cv.findContours(mask, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)
37for cnt in range(len(contours)):
38    x, y, w, h = cv.boundingRect(contours[cnt])
39    print(x, y, w, h)
40    cx = (x + w//2)
41    cy = (y + h//2)
42    cv.circle(image, (cx, cy), 4, (0, 0, 255), 4, 8, 0)
43cv.imshow("result", image)
44cv.imwrite("D:/find_cross.png", image)
45cv.waitKey(0)
46cv.destroyAllWindows()

02

寻找缺失

仔细观察图二,缺失是偶发情况,针对这种情况下,要完成计数与缺失位置标定!我感觉我的密集恐惧症已经开始犯了!首先需要获取这些位置,通过二值话与轮廓发现搞定,然后根据这些轮廓位置,重新绘制统一的圆形标记,轮廓发现对每个圆形标记进行上下左右位置最近领搜索,返回间隔距离,-1表示边界,根据间隔距离设置阈值查找缺失,最终运行结果如下:

cc81afd2-2156-11ed-ba43-dac502259ad0.png

从原图得到的标记图如下:

cca33f62-2156-11ed-ba43-dac502259ad0.png

代码实现如下:

 1image=cv.imread("D:/images/zsxq/zsxq_40.png")
 2gray=cv.cvtColor(image,cv.COLOR_BGR2GRAY)
 3ret,binary=cv.threshold(gray,0,255,cv.THRESH_OTSU|cv.THRESH_BINARY_INV)
 4cv.imshow("binary",binary)
 5contours,hireachy=cv.findContours(binary,cv.RETR_EXTERNAL,cv.CHAIN_APPROX_SIMPLE)
 6mask=np.zeros_like(binary)
 7forcntinrange(len(contours)):
 8area=cv.contourArea(contours[cnt])
 9ifarea< 50:
10        continue
11    x, y, w, h = cv.boundingRect(contours[cnt])
12    if (y + h) >(binary.shape[0]-10):
13continue
14cx=(x+w//2)
15cy=(y+h//2)
16cv.circle(mask,(cx,cy),4,(255),4,8,0)
17cv.imshow("mask",mask)
18contours,hireachy=cv.findContours(mask,cv.RETR_EXTERNAL,cv.CHAIN_APPROX_SIMPLE)
19forcntinrange(len(contours)):
20x,y,w,h=cv.boundingRect(contours[cnt])
21cx=(x+w//2)
22cy=(y+h//2)
23left=find_neighborhood(mask,cx,cy,1)
24right=find_neighborhood(mask,cx,cy,2)
25#top=find_neighborhood(mask,cx,cy,3)
26#bottom=find_neighborhood(mask,cx,cy,4)
27ifleft==-1orright==-1:#ortop==-1orbottom==-1:
28continue
29dx=right-left
30#dy=top-bottom
31#print(dx,dy)
32ifdx>15:
33cv.circle(image,(cx+left+10,cy),4,(0,0,255),4,8,0)
34
35cv.imshow("test",image)
36cv.imwrite("D:/find_miss.png",image)
37cv.waitKey(0)
38cv.destroyAllWindows()


审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • OpenCV
    +关注

    关注

    30

    文章

    626

    浏览量

    41250
  • 图像分析
    +关注

    关注

    0

    文章

    82

    浏览量

    18664

原文标题:OpenCV二值图像分析之寻找缺失与靶心

文章出处:【微信号:CVSCHOOL,微信公众号:OpenCV学堂】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    从时域和频域两个角度对信号进行分析

    一般来说,我们会从时域和频域两个角度,分别对信号进行分析。 时域 时域是真实世界存在的域,按时间顺序呈现。例如,在某个时钟信号的时域图中,可以观察到两个重要的参数,波形的周期和上升沿: 时钟周期即
    的头像 发表于 11-19 10:18 108次阅读
    从时域和频域<b class='flag-5'>两个</b>角度对信号进行<b class='flag-5'>分析</b>

    OpenCV教程之OpenCV图像阈值处理

    阈值的基本概念是为了简化图像以进行分析。当我们将图像转换为灰度图像时,必须记住灰度图像仍然至少有255
    的头像 发表于 11-16 10:16 159次阅读
    <b class='flag-5'>OpenCV</b>教程之<b class='flag-5'>OpenCV</b><b class='flag-5'>图像</b>阈值<b class='flag-5'>处理</b>

    图像识别技术包括自然语言处理

    图像识别技术与自然语言处理是人工智能领域的两个重要分支,它们在很多方面有着密切的联系,但也存在一些区别。 一、图像识别技术与自然语言处理的关
    的头像 发表于 07-16 10:54 620次阅读

    OpenCV图像识别C++代码

    安装OpenCV库 首先,您需要在您的计算机上安装OpenCV库。您可以从OpenCV官网下载预编译的库或从源代码编译。安装完成后,确保将OpenCV的头文件和库文件添加到您的项目中。
    的头像 发表于 07-16 10:42 1755次阅读

    opencv图像识别有什么算法

    OpenCV(Open Source Computer Vision Library)是一开源的计算机视觉和机器学习软件库,提供了大量的图像处理和计算机视觉相关的算法。以下是一些常见
    的头像 发表于 07-16 10:40 807次阅读

    opencv-python和opencv一样吗

    不一样。OpenCV(Open Source Computer Vision Library)是一开源的计算机视觉和机器学习软件库,它提供了大量的图像和视频处理功能。
    的头像 发表于 07-16 10:38 949次阅读

    opencv的主要功能有哪些

    OpenCV(Open Source Computer Vision Library)是一开源的计算机视觉库,提供了大量的计算机视觉算法和工具。以下是OpenCV的主要功能: 图像
    的头像 发表于 07-16 10:35 1323次阅读

    什么是机器视觉opencv?它有哪些优势?

    机器视觉(Machine Vision)是一种利用计算机和图像处理技术来模拟人类视觉系统的功能,实现对图像的识别、分析和理解的技术。OpenCV
    的头像 发表于 07-16 10:33 670次阅读

    esp32能不能直接跑opencv?有没有在板子上面做图像处理的库?

    esp32能不能直接跑opencv,有没有在板子上面做图像处理的库
    发表于 06-13 06:59

    如何实现PIL和OpenCV之间图像数据的转换呢?

    PIL图像数据格式转换成OpenCV图像数据格式
    的头像 发表于 02-25 13:43 1145次阅读

    arcgis中如何关联两个属性表

    在ArcGIS中,关联两个属性表是一重要的操作,可以通过此操作将两个表中的数据关联起来,以便进行分析和查询。下面是详细介绍如何在ArcGIS中实现属性表的关联。 首先,我们需要明确
    的头像 发表于 02-25 11:01 3976次阅读

    使用图像处理OpenCV从摄像头获取数据并在PyQt5上显示出来

    OpenCV能够处理图像、视频、深度图像等各种类型的视觉数据
    的头像 发表于 01-05 17:32 2339次阅读
    使用<b class='flag-5'>图像</b><b class='flag-5'>处理</b>库<b class='flag-5'>OpenCV</b>从摄像头获取数据并在PyQt5上显示出来

    二值图像分析的典型案例

    最近一直有人向我提问很多二值图像分析相关的问题,特别选择了两个典型的轮廓分析问题。进行分析与编码实现与演示,废话不多说,先看第一
    的头像 发表于 12-06 10:54 501次阅读

    OpenCV4.8 CUDA编程代码教程

    OpenCV4支持通过GPU实现CUDA加速执行,实现对OpenCV图像处理程序的加速运行,当前支持加速的模块包括如下。
    的头像 发表于 12-05 09:56 980次阅读
    <b class='flag-5'>OpenCV</b>4.8 CUDA编程代码教程

    两个硬盘2系统开机切换

    切换两个硬盘上的系统是一种常见的行为,可以让用户在不同的操作系统之间进行切换,以满足不同的需求。在本文中,我们将详细介绍如何配置和使用两个硬盘上的系统进行切换。本文将分为以下几个部分进行讨论:硬件
    的头像 发表于 11-28 15:08 7353次阅读