数组?列表?矩阵?or 向量?(求助贴)

先上个图片
在这里插入图片描述
我用opencv得到了四个点得坐标但它的形式为<class ‘numpy.ndarray’>
不知道它是什么,做了测试

a.nparry = ([[[ 55 , 49]],

 [[ 55 ,220]],

 [[290, 220]],

 [[290 , 49]]])

print(a)
# print(a.shape)

不能够输出 print(a.shape)
而且蓝色部分想变为reshape((4, 2))也不行

import cv2
import numpy as np

webcam = False
path = '12.png'
filter=4
minArea=1000
while True:
    if webcam:success,img = cap.read()# 选择实时与否
    else: img = cv2.imread(path)

    imgGray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
    imgBlur = cv2.GaussianBlur(imgGray,(5,5),1)
    imgCanny = cv2.Canny(imgBlur,100,100)
    kernel = np.ones((5,5))
    imgDial = cv2.dilate(imgCanny,kernel,iterations=3)
    imgThre = cv2.erode(imgDial,kernel,iterations=2)
    cv2.imshow('Canny',imgThre)
    contours,hiearchy = cv2.findContours(imgThre,cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)
    finalCountours = []#创建最终列表
    for i in contours:
        area = cv2.contourArea(i)
        if area > minArea:
            peri = cv2.arcLength(i,True)
            approx = cv2.approxPolyDP(i,0.02*peri,True)
            bbox = cv2.boundingRect(approx)#左上角得坐标以及宽和高即得到边框
            if filter > 0:
                if len(approx) == filter:
                    finalCountours.append([len(approx), area, approx, bbox, i])
            else:
                finalCountours.append([len(approx), area, approx, bbox, i])
        finalCountours = sorted(finalCountours, key=lambda x: x[2], reverse=True)#依照面积排轮廓最大轮廓到最小
        for con in finalCountours:
            cv2.drawContours(img, con[4], -1, (0, 0, 255), 3)#con[4]是bbx
            cv2.imshow("1",img)
            # print(bbox)
            # print(len(finalCountours))
            biggest = finalCountours[0][2]#已经降序排列过了[0]为最大轮廓,即最大轮廓得四个角的坐标print(approx)
            myPoints = biggest.reshape((4, 2))
            print(biggest)
            print(type(biggest))
            print(biggest.shape)
            # myPoints = biggest
            add = myPoints.sum(1)  # w求和
            print(myPoints)
            print(add)
            # print(myPoints.shape)
            # print(approx)
    # return img, finalCountours






    # print(contours)
    #     # print(peri)
    #     print(bbox)
    #     # print(approx)
    #     # print(len(approx))
    # print(finalCountours)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值