OpenCV 案例六【道路裂缝检测】

目录:

一、环境准备

1、Anaconda 环境配置

环境配置参考前面章节:

OpenCV 案例一【人脸检测】

2、图像处理方法介绍

主要用到了自适应阈值二值化(Adaptive Thresholding)方法,主要作用是:

对经过预处理(去噪、增强对比度)的灰度图像,采用自适应阈值方法,将其转换为二值图像,目的是突出图像中的裂缝。如:图片中的裂缝会被设置为白色(255),而背景会是黑色(0)。由于代码中使用了 cv2.THRESH_BINARY_INV,进行反转,因为裂缝通常是黑色的,最终效果是裂缝被设置成白色。

二、代码案例

python 复制代码
import cv2
import numpy as np
import matplotlib.pyplot as plt

# 设置中文字体
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False

# 读取图像并灰度化
image_path = 'road_2.png'
image = cv2.imread(image_path)

gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

# 图像预处理
blurred = cv2.GaussianBlur(gray, (5, 5), 0)

# 使用 CLAHE 增强对比度
clahe = cv2.createCLAHE(clipLimit=2.0, tileGridSize=(8, 8))
enhanced = clahe.apply(blurred)

# 二值化:提取裂缝
_, binary = cv2.threshold(enhanced, 0, 255, cv2.THRESH_BINARY_INV + cv2.THRESH_OTSU)

# 形态学操作:去噪 + 连接裂缝
kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (3, 3))

# 开运算:去除小噪点
opening = cv2.morphologyEx(binary, cv2.MORPH_OPEN, kernel, iterations=2)

# 闭运算:连接断裂的细小裂缝
closing = cv2.morphologyEx(opening, cv2.MORPH_CLOSE, kernel, iterations=3)

# 轮廓检测:提取裂缝区域
contours, _ = cv2.findContours(closing, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

# 创建一个掩膜,用于画出最终的裂缝区域
crack_mask = np.zeros_like(gray)

# 过滤小区域,假设小于 min_area 的为噪声
min_area = 50
for cnt in contours:
    if cv2.contourArea(cnt) > min_area:
        cv2.drawContours(crack_mask, [cnt], -1, 255, thickness=cv2.FILLED)

# 统计裂缝像素
crack_pixel_count = np.sum(crack_mask == 255)
total_pixels = crack_mask.size
crack_ratio = crack_pixel_count / total_pixels

# 设定阈值
crack_threshold = 1000

# 判断并打印结果
if crack_pixel_count > crack_threshold:
    print("该道路图像中存在裂缝")
else:
    print("该道路图像中未发现明显裂缝")

print(f"检测到的裂缝像素数:{crack_pixel_count},占比约:{crack_ratio:.4%}")

# 在原图上标记
result = image.copy()
result[crack_mask == 255] = [0, 0, 255]

# 可视化
plt.figure(figsize=(15, 10))

plt.subplot(2, 3, 1), plt.imshow(cv2.cvtColor(image, cv2.COLOR_BGR2RGB))
plt.title('原始图像'), plt.axis('off')

plt.subplot(2, 3, 2), plt.imshow(gray, cmap='gray')
plt.title('灰度图'), plt.axis('off')

plt.subplot(2, 3, 3), plt.imshow(enhanced, cmap='gray')
plt.title('增强后(CLAHE)'), plt.axis('off')

plt.subplot(2, 3, 4), plt.imshow(binary, cmap='gray')
plt.title('二值化图像'), plt.axis('off')

plt.subplot(2, 3, 5), plt.imshow(closing, cmap='gray')
plt.title('形态学处理后'), plt.axis('off')

plt.subplot(2, 3, 6), plt.imshow(cv2.cvtColor(result, cv2.COLOR_BGR2RGB))
plt.title('检测到的裂缝(红色)'), plt.axis('off')

plt.tight_layout()
plt.show()

三、运行效果


相关推荐
集芯微电科技有限公司2 小时前
PC5204集成700V/7.5A 400mΩ增强型氮化镓GaN HEMT驱动器具有高功率密度运行
数据结构·人工智能·单片机·嵌入式硬件·神经网络·机器学习·生成对抗网络
熊猫钓鱼>_>2 小时前
Puppeteer深度解析:Chrome自动化的艺术与实践
前端·人工智能·chrome·自动化·云计算·puppeteer·mcp
GIOTTO情2 小时前
Infoseek字节探索舆情处置技术落地实战——以2026年3月连锁餐饮舆情事件为例
人工智能
bst@微胖子2 小时前
OpenCV 案例五【动物识别】
人工智能·opencv·计算机视觉
熊猫钓鱼>_>2 小时前
Playwright与Puppeteer实战教程:让AI拥有“看懂“网页的能力
人工智能·ai·puppeteer·playwright·jina·skills·agent skills
TDengine (老段)2 小时前
TDengine IDMP 组态面板 —— 图元
大数据·数据库·人工智能·物联网·时序数据库·tdengine
进击ing小白2 小时前
OpenCv之图像缩放翻转和拼接
人工智能·opencv·计算机视觉
小妖同学学AI2 小时前
AI数字人,赋予教学新的生命力
人工智能
天云数据2 小时前
OpenClaw-RL:边聊边学的统一智能体强化学习框架
人工智能