【发布时间】:2017-05-04 18:16:19
【问题描述】:
我正在尝试使用 OpenCV 使鱼眼图像不失真。我已经校准了相机,并且还使用以下代码获得了不错的未失真图像(我刚刚发布了相关部分):
img = cv2.imread('img.jpeg') #image path of pic to distort
h,w = img.shape[:2]
Knew = cv2.fisheye.estimateNewCameraMatrixForUndistortRectify(K,D,(w,h),None)
Knew[(0,1), (0,1)] = .3* Knew[(0,1), (0,1)]
mapx, mapy = cv2.fisheye.initUndistortRectifyMap(K,D,None,Knew,(w,h),5)
img_undistorted = cv2.remap(img, mapx, mapy, cv2.INTER_LINEAR)
cv2.imshow('undistorted', img_undistorted)
cv2.waitKey(0)
cv2.destroyAllWindows()
这些照片仅用于演示目的。 我使用鱼眼镜头的映射功能来确定我在右侧裁剪的点。但是,如果我使用与上面相同的代码(以及相同的相机矩阵),输出是一个非常奇怪的扭曲图片。
我也考虑过先不失真然后裁剪,但是我无法准确计算出我必须以这种方式裁剪的点。所以我必须先裁剪图像。
那么我如何正确地消除不对称裁剪的鱼眼图像?
【问题讨论】:
标签: python opencv camera computer-vision fisheye