适用于Python的OpenCV 2.4.9,找不到棋盘(相机校准教程) [英] OpenCV 2.4.9 for Python, cannot find chessboard (camera calibration tutorial)

查看:95
本文介绍了适用于Python的OpenCV 2.4.9,找不到棋盘(相机校准教程)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试根据以下问题是功能findChessboardCorners在我尝试的图像上找不到任何棋盘.我用了很多-甚至只是普通的棋盘图案.无论如何,什么也没检测到.

The problem is that function findChessboardCorners cannot find any chessboard on images I tried. I used a lot of them - even just plain chessboard pattern. In any case, nothing was detected.

这是代码(与上面的链接几乎相同):

Here is the code (almost the same as from link above):

import numpy as np
import cv2
import glob

# termination criteria
criteria = (cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 30, 0.001)

# prepare object points, like (0,0,0), (1,0,0), (2,0,0) ....,(6,5,0)
objp = np.zeros((6*7,3), np.float32)
objp[:,:2] = np.mgrid[0:7,0:6].T.reshape(-1,2)

# Arrays to store object points and image points from all the images.
objpoints = [] # 3d point in real world space
imgpoints = [] # 2d points in image plane.

images = glob.glob('*.png')

for fname in images:
    img = cv2.imread(fname)
    gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)

    # Find the chess board corners
    ret, corners = cv2.findChessboardCorners(gray, (7,6),None)

    # If found, add object points, image points (after refining them)
    if ret == True:
        objpoints.append(objp)

        corners2 = cv2.cornerSubPix(gray,corners,(11,11),(-1,-1),criteria)
        imgpoints.append(corners2)

        # Draw and display the corners
        img = cv2.drawChessboardCorners(img, (7,6), corners2,ret)
        cv2.imshow('img',img)
        cv2.waitKey(500)

cv2.destroyAllWindows()

我所做的唯一更改是我从.jpg文件切换为.png文件-由于某种原因,函数读取无法读取jpg图像(这是其他主题的另一个奇怪问题).

The only change I made is that i switched from .jpg files to .png files - for some reason, function imread cannot read jpg images (that's another strange problem for other topic).

预先感谢您的建议!

图片参考:

推荐答案

仅适用于其他可能会走这条路的Python新手.工作代码:

Just for other Python newbies that may go down this road. Working code:

import numpy as np
import cv2
import glob

# termination criteria
criteria = (cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 30, 0.001)
# Arrays to store object points and image points from all the images.
imgpoints = [] # 2d points in image plane.
images = glob.glob('*.png')

for fname in images:
    img = cv2.imread(fname)
    gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
    ret = False
    # Find the chess board corners
    ret, corners = cv2.findChessboardCorners(gray, (7,7))
    # If found, add object points, image points (after refining them)
    if ret == True:
        cv2.cornerSubPix(gray, corners, (11,11), (-1,-1), criteria)
        imgpoints.append(corners)
        # Draw and display the corners
        cv2.drawChessboardCorners(img, (7,7), corners, ret)
        cv2.imshow('img',img)
        cv2.waitKey(0)
cv2.destroyAllWindows()

两个要点:

  1. 您必须仔细计算图案的尺寸. (7,7)用于通常的棋盘.

  1. You have to carefully count dimension of you pattern. (7,7) is for usual chessboard.

img = cv2.drawChessboardCorners(img, (7,6), corners2,ret)行不起作用,您必须将其更改为cv2.drawChessboardCorners(img, (7,6), corners2,ret)(函数不会返回图像).

Line img = cv2.drawChessboardCorners(img, (7,6), corners2,ret) doesn't work, you have to change it to cv2.drawChessboardCorners(img, (7,6), corners2,ret) (function doesn't return image).

感谢AldurDisciple!

Thanks to AldurDisciple!

这篇关于适用于Python的OpenCV 2.4.9,找不到棋盘(相机校准教程)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆