计算机视觉第五课:给每个物体画 bounding box

电脑自动找到物体,并且给每个物体画一个矩形检测框,和人脸识别、YOLO 检测的逻辑一模一样!

一、先上代码

python 复制代码
import cv2
import numpy as np

# 1. 读取图片
img = cv2.imread("test.jpg")

# 2. 预处理(灰度+模糊+Canny边缘)
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
blur = cv2.GaussianBlur(gray, (5, 5), 0)
canny = cv2.Canny(blur, 50, 150)

# 3. 寻找轮廓
contours, _ = cv2.findContours(canny, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

# 4. 遍历每一个轮廓,给每个物体画框(核心!)
for cnt in contours:
    # 过滤掉太小的噪点(面积<100的忽略)
    area = cv2.contourArea(cnt)
    if area > 100:
        # 获取物体的 左上角x,y + 宽度w + 高度h
        x, y, w, h = cv2.boundingRect(cnt)
        
        # 画矩形检测框(绿色,粗细2)
        cv2.rectangle(img, (x, y), (x + w, y + h), (0, 255, 0), 2)
        
        # 标上文字:物体
        cv2.putText(img, "Object", (x, y-10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0,255,0), 2)

# 5. 显示结果
cv2.imshow("Canny", canny)
cv2.imshow("最终检测效果", img)

cv2.waitKey(0)
cv2.destroyAllWindows()

二、知识点

  1. 过滤噪点
python 复制代码
area = cv2.contourArea(cnt)
if area > 100:
  • 计算物体面积
  • 太小的直接忽略,避免乱框杂点
  • 你可以改成 200500 更严格
  1. 获取物体坐标(最重要)
python 复制代码
x, y, w, h = cv2.boundingRect(cnt)
  • x, y:物体左上角坐标
  • w:宽度
  • h:高度所有目标检测都是靠这 4 个数字定位!
  1. 画检测框
python 复制代码
cv2.rectangle(img, (x, y), (x+w, y+h), (0,255,0), 2)

这就是人脸识别、车牌识别里框出目标的代码!

三、运行效果

相关推荐
z小猫不吃鱼1 小时前
10 GPT-3 论文精读:Few-shot Learning 为什么会出现?
人工智能·语言模型·自然语言处理·gpt-3
XiaoLin laile1 小时前
【无标题】
网络·数据库·人工智能
weixin_397574091 小时前
向量空间携手山东信研院共建实验室,工业AI按下加速键
人工智能
DisonTangor1 小时前
跃阶星辰开源Step 3.7 Flash:原生多模态,最高生成速度400 Tokens/s
人工智能·语言模型·数据挖掘·开源·aigc
lili00121 小时前
Claude自动修Bug配置优化与避坑指南
java·人工智能·python·bug·ai编程
Szime1 小时前
靠谱的终端工厂采购电子元器件供应链哪家更适合研发型企业?
人工智能·python
圣殿骑士-Khtangc1 小时前
SuperSplat 架构深度解析:8.2K Star 的浏览器端 3D 高斯泼溅编辑器,PlayCanvas 如何用纯 WebGL 重新定义三维内容工作流
人工智能
Mem0rin1 小时前
[Agent基础]Agent、消息和聊天模板
人工智能·transformer
智信中科张炜2 小时前
全球及中国二板注塑机市场前景形势分析报告
人工智能