OpenCV:基于Shi-Tomasi角点检测算法

一、使用OpenCV检测角点

在OpenCV中,角点检测可以通过cv2.goodFeaturesToTrack()函数实现,该函数基于Shi-Tomasi角点检测算法。

  • maxCorners是检测到的角点的最大数目,
  • qualityLevel是角点质量的阈值,
  • minDistance是检测到的角点之间的最小欧氏距离。

调整这些参数可以改变检测到的角点的数量和质量。

二、代码

# -*- coding: utf-8 -*-
"""
Created on Sat May 18 16:16:37 2024

E:\OpenCV\Ky_Jy12.py
"""

import cv2
import numpy as np
 
# 读取图像
image = cv2.imread(r'D:\OpenCVpic\bb1.jpg')
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)  # 转换为灰度图
 
# 角点检测
corners = cv2.goodFeaturesToTrack(gray, maxCorners=1000, qualityLevel=0.01, minDistance=10)
corners = np.int0(corners)
 
# 在图像上绘制角点
for i in corners:
    x, y = i.ravel()
    cv2.circle(image, (x, y), 3, 255, -1)
 
# 显示图像
#cv2.imshow('Corners', image)
# 缩小显示
new_img = cv2.resize(image, None, fx=0.5, fy=0.5)
cv2.imshow('Corners Lines', new_img)

cv2.waitKey(0)
cv2.destroyAllWindows()

三、运行结果

img

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值