Opencv轮廓检测,简单识别斑马线

该代码示例展示了如何利用OpenCV库对图像进行处理,包括灰度转换、高斯滤波、二值化、腐蚀和膨胀操作,以检测并突出显示图像中的斑马线轮廓。通过轮廓检测函数findContours找到斑马线的轮廓,并在原图上绘制出来。程序运行时会显示处理过程的各个阶段,用户可以通过按q键退出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Opencv轮廓检测,简单识别斑马线

原图
轮廓检测后的效果

import cv2#导入cv2模块
import numpy as np

#定义两个核 (kernel_Ero用于腐蚀,kernel_Dia用于膨胀)

kernel_Ero = np.ones((3,1),np.uint8)
kernel_Dia = np.ones((3,5),np.uint8)
img = cv2.imread("zippa_line.jpg")
cv2.imshow('img',img)
print(img.shape)
#灰度值转换,转为单通道模式
img_Gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
print(imgGray.shape)
#高斯滤波去噪
imgBlur = cv2.GaussianBlur(imgGray,(5,5),0)
#阈值处理,二值化
ret,thresh = cv2.threshold(imgBlur,200,255,cv2.THRESH_BINARY)
#腐蚀
imgEro = cv2.erode(thresh,kernel_Ero,iterations=2)
#膨胀
imgDia = cv2.dilate(imgEro,kernel_Dia,iterations=4)

#轮廓检测
contouts, hierarchy = cv2.findContours(imgDia,cv2.RETR_TREE,cv2.CHAIN_APPROX_NONE)
cv2.drawContours(img,contouts, -1, (0, 255, 0), 3)

while True:
    # cv2.imshow('bin', binary)
    cv2.imshow('ing', img)
    cv2.imshow('img', imgGray)
    if cv2.waitKey(20) & 0xff == ord('q'):#按q退出程序
        break
        cv2.waitKey(0)
        cv2.destroyAllWindows()

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

悸尢

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值