opencv-python的简单练习

文章目录

识别信号灯

需要识别交通信号灯的颜色(红、黄、绿)。请设计一个简化的流程,说明如何使用OpenCV来识别交通信号灯的颜色。

思路分析‌:

1.读取包含交通信号灯的图像。

2.转换图像到HSV颜色空间。

3.分别为红、黄、绿三种颜色定义HSV范围,并创建三个掩膜。

4.对每个掩膜进行轮廓检测,识别出可能的信号灯区域。

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

lamp = cv2.imread("deng.png")
lamp_hsv = cv2.cvtColor(lamp, cv2.COLOR_BGR2HSV)

g_min = np.array([35,43,46])
g_max = np.array([77,255,255])
lamp_gmask = cv2.inRange(lamp_hsv, g_min, g_max)
lamp_gmask = cv2.erode(lamp_gmask, None, iterations=1)
lamp_gmask = cv2.dilate(lamp_gmask, None, iterations=10)

y_min = np.array([8,43,46])
y_max = np.array([20,255,255])
lamp_ymask = cv2.inRange(lamp_hsv, y_min, y_max)
lamp_ymask = cv2.erode(lamp_ymask, None, iterations=1)
lamp_ymask = cv2.dilate(lamp_ymask, None, iterations=10)

r_min = np.array([155,0,0])
r_max = np.array([170,255,255])
lamp_rmask = cv2.inRange(lamp_hsv, r_min, r_max)
lamp_rmask = cv2.erode(lamp_rmask, None, iterations=1)
lamp_rmask = cv2.dilate(lamp_rmask, None, iterations=10)

result = cv2.bitwise_and(lamp, lamp, mask=lamp_rmask)

cv2.imshow("result", result)
cv2.waitKey(0)


识别图案并且标记面积和周长

1.将图像转换为灰度图

2.对灰度图进行二值化处理

3.使用形态学变换去除噪声【开运算】

4.检测图像中的边缘

5.查找并绘制图像中的轮廓

6.逐一遍历轮廓,输出所有四边形的周长 和 面积。

python 复制代码
import cv2
# 读取图像
image = cv2.imread('02.png')
# 转换为灰度图
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
# 使用阈值化方法进行二值化
_, binary_image = cv2.threshold(gray_image, 127, 255, cv2.THRESH_BINARY)
# 定义结构元素
kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (3, 3))

# 开运算
opening = cv2.morphologyEx(binary_image, cv2.MORPH_OPEN, kernel)
# 使用Canny边缘检测
edges = cv2.Canny(opening, 100, 200)
# 查找轮廓
contours, _ = cv2.findContours(edges, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

# 绘制轮廓
cv2.drawContours(image, contours, -1, (0, 255, 0), 2)

for contour in contours:
    # 近似轮廓为多边形
    epsilon = 0.02 * cv2.arcLength(contour, True)
    approx = cv2.approxPolyDP(contour, epsilon, True)
    
    # 如果近似的多边形有四个顶点,则认为是四边形
    if len(approx) == 4:
        # 计算周长
        perimeter = cv2.arcLength(contour, True)
        # 计算面积
        area = cv2.contourArea(contour)
        # 在图像上显示周长和面积
        x, y, w, h = cv2.boundingRect(contour)
        cv2.putText(image, f': {perimeter:.2f}', (x, y - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.9, (0, 255, 0), 2)

cv2.imshow('Contours', image)   
cv2.waitKey(0)
相关推荐
曦月逸霜23 分钟前
啥是RAG 它能干什么?
人工智能·python·机器学习
AI医影跨模态组学29 分钟前
Lancet Digit Health(IF=24.1)广东省人民医院刘再毅&南方医科大学南方医院梁莉等团队:基于可解释深度学习模型预测胶质瘤分子改变
人工智能·深度学习·论文·医学·医学影像·影像组学
应用市场30 分钟前
AI 编程助手三强争霸(2026 版):Claude、Gemini、GPT 各自擅长什么?
人工智能·gpt
2301_769340671 小时前
如何在 Vuetify 中可靠捕获 Chip 关闭事件(包括键盘触发).txt
jvm·数据库·python
AC赳赳老秦1 小时前
供应链专员提效:OpenClaw自动跟踪物流信息、更新库存数据,异常自动提醒
java·大数据·服务器·数据库·人工智能·自动化·openclaw
脑极体1 小时前
从Token消耗到DAA增长,AI价值标尺正在重构
人工智能·重构
csdn小瓯1 小时前
LangGraph自适应工作流路由机制:从关键词匹配到智能决策的完整实现
人工智能·fastapi·langgraph
QYR-分析1 小时前
高功率飞秒激光器行业发展现状、市场机遇及未来趋势分析
大数据·人工智能
欲儿2 小时前
magicCamera—魔术师的 AR 卡牌应用
opencv·安卓·魔术师
AI医影跨模态组学2 小时前
J Clin Oncol(IF=43.4)美国Cedars-Sinai医学中心等团队:基于计算组织学人工智能的晚期胰腺癌化疗选择预测性生物标志物的开发与验证
人工智能·机器学习·论文·医学·医学影像·影像组学