相机标定后获取角点坐标

相机标定后获取角点坐标


matlab自带的Camera Calibrator只能对象图片进行标定,但是却不显示标定板各个角点的坐标。通过查找源码可以找到其获取坐标的函数。

即detectCheckerboardPoints() 函数

 

points = detectCheckerboardPoints(img);

points即为角点坐标

clear;clc;
img= imread('1.img');
points = detectCheckerboardPoints(img);
num = size(points);
imshow(img);hold on;
for i=1:num
     plot(points(i,1),points(i,2),'.','LineWidth',2);hold on;
end

得到结果

角点坐标就存在工作区points

  • 8
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
以下是使用 OpenCV 进行相机标定角点检测代码,其中假设使用的棋盘格为 9x6 的: ```python import numpy as np import cv2 # 棋盘格尺寸(单位:毫米) CHESSBOARD_SQUARE_SIZE = 20 # 棋盘格大小 CHESSBOARD_SIZE = (9, 6) # 获取棋盘格角点 def get_chessboard_corners(image): gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) ret, corners = cv2.findChessboardCorners(gray, CHESSBOARD_SIZE, None) if ret: corners = cv2.cornerSubPix(gray, corners, (11, 11), (-1, -1), criteria=(cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 30, 0.001)) return ret, corners # 读取一组图片进行标定 def calibrate_camera(images): # 预期的标定角点数量 expected_corners_count = CHESSBOARD_SIZE[0] * CHESSBOARD_SIZE[1] # 准备用于标定的数据 object_points = [] image_points = [] # 准备物体坐标系中的点 objp = np.zeros((expected_corners_count, 3), np.float32) objp[:, :2] = np.mgrid[0:CHESSBOARD_SIZE[0], 0:CHESSBOARD_SIZE[1]].T.reshape(-1, 2) * CHESSBOARD_SQUARE_SIZE # 遍历每张图片进行处理 for image in images: # 获取角点 ret, corners = get_chessboard_corners(image) if not ret: continue # 确保找到了预期数量的角点 if len(corners) != expected_corners_count: continue # 保存物体坐标系中的点和图像平面中的点 object_points.append(objp) image_points.append(corners) # 进行相机标定 ret, mtx, dist, rvecs, tvecs = cv2.calibrateCamera(object_points, image_points, images[0].shape[:2], None, None) return ret, mtx, dist, rvecs, tvecs ``` 这段代码首先定义了棋盘格的尺寸和大小,然后定义了 `get_chessboard_corners` 函数用于获取图像中的棋盘格角点。这里使用了 OpenCV 的 `findChessboardCorners` 方法来找到棋盘格,然后使用 `cornerSubPix` 方法对角点进行亚像素级别的精确化处理。 接下来定义了 `calibrate_camera` 函数来进行相机标定。这个函数首先准备了用于标定的数据,包括物体坐标系中的点和图像平面中的点。然后遍历输入的图片,使用 `get_chessboard_corners` 函数获取角点,并且将找到的角点保存到物体坐标系中的点和图像平面中的点中。最后使用 `calibrateCamera` 方法进行相机标定,得到相机的内参和外参。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值