在pycharm使用opencv完成矩形识别并返回坐标

import cv2
import numpy as np

#定义形状检测函数
def ShapeDetection(img):
    contours, _ = cv2.findContours(img,cv2.RETR_LIST,cv2.CHAIN_APPROX_NONE)  #寻找轮廓点
    for obj in contours:
        area = cv2.contourArea(obj)  #计算轮廓内区域的面积
        # cv2.drawContours(imgContour, obj, -1, (255, 0, 0), 4)  #绘制轮廓线
        perimeter = cv2.arcLength(obj,True)  #计算轮廓周长
        approx = cv2.approxPolyDP(obj,0.03*perimeter,True)  #获取轮廓角点坐标
        CornerNum = len(approx)   #轮廓角点的数量

        #轮廓对象分类

        if (CornerNum == 4) :
            x, y, w, h = cv2.boundingRect(approx)  # 获取坐标值和宽度、高度
            if w > 40 and h > 30:
                cv2.drawContours(imgContour, [approx], -1, (255, 0, 0), 4)  #绘制轮廓线
                for i in range(4):
                    # 计算角点的坐标
                    pt = tuple(approx[i][0])
                    cv2.circle(imgContour, pt, 5, (0, 255, 0), -1)  # 绘制角点

                    # 可选:显示角点的坐标
                    cv2.putText(imgContour, str(pt), (pt[0] + 10, pt[1] + 10),
                                cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 0, 255), 1)
                    print(approx[i][0])

                    # 绘制矩形类型和名称
                cv2.putText(imgContour, "Rectangel", (x + (w // 2), y + (h // 2)),
                            cv2.FONT_HERSHEY_COMPLEX, 0.6, (0, 0, 0), 1)

path = 'B.png'
img = cv2.imread(path)
imgContour = img.copy()

imgGray = cv2.cvtColor(img,cv2.COLOR_RGB2GRAY)  #转灰度图
imgBlur = cv2.GaussianBlur(imgGray,(5,5),1)  #高斯模糊
imgCanny = cv2.Canny(imgBlur,60,60)  #Canny算子边缘检测
ShapeDetection(imgCanny)  #形状检测

cv2.imshow("Original img", img)
# cv2.imshow("imgGray", imgGray)
# cv2.imshow("imgBlur", imgBlur)
# cv2.imshow("imgCanny", imgCanny)
cv2.imshow("shape Detection", imgContour)


cv2.waitKey(0)

运行结果如下

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Pycharm使用OpenCV,首先需要确保已经安装好了PythonOpenCV。然后,你需要将OpenCVPython关联起来。你可以在OpenCV安装目录下找到"cv2.pyd"文件,该文件位于"opencv\build\python\2.7\x64"目录下(如果是32位系统,则在"x86"目录下)。将该文件复制到Python的安装目录下的"Lib\site-packages"文件夹中。 接下来,在Pycharm中进行设置。首先,打开Pycharm,点击"File",然后选择"Settings"(或者使用快捷键Ctrl+Alt+S)。在设置界面中,找到"Project Interpreter"选项。点击右上角的齿轮图标,选择"Add"。在弹出的窗口中,选择已安装的Python解释器,并点击"OK"。 完成上述步骤后,你就可以在Pycharm使用Python编写OpenCV的代码了。你可以创建一个新的Python文件,然后导入cv2模块。接下来,你可以使用OpenCV的各种功能和方法来处理图像或视频。例如,你可以使用cv2.imread()函数读取图像,使用cv2.cvtColor()函数将图像转换为灰度图像,并使用cv2.imshow()函数显示图像。最后,使用cv2.waitKey()函数等待用户按下键盘上的任意键,然后使用cv2.destroyAllWindows()函数关闭窗口。 下面是一个简单的代码示例: ```python import cv2 img = cv2.imread("Nyist.jpg") GrayImage = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) cv2.imshow("Image", img) cv2.imshow("grayImage", GrayImage) cv2.waitKey(0) cv2.destroyAllWindows() ``` 这段代码将读取名为"Nyist.jpg"的图像,并将其转换为灰度图像,然后显示原图像和灰度图像。你可以根据自己的需求修改和扩展这段代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值