我正在尝试使用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()
这些照片仅供演示之用。 我使用鱼眼镜头的映射功能来确定我在右侧裁剪的点。但是,如果我使用与上面相同的代码(和相同的相机矩阵),输出是一个非常奇怪的扭曲图片。
我还考虑过首先不失真然后裁剪,但是我无法准确计算出我必须以这种方式裁剪的点。所以我必须首先裁剪图像。
那么我如何正确地取消未对称裁剪的鱼眼图像?
答案 0 :(得分:0)
移动和裁剪图像时,鱼群相机校准参数不适合新相机。
可能是你可以通过填充零值来尝试使iamge对称。 重点是使两个图像的中心点在同一位置。
参考:
http://answers.opencv.org/question/64614/fisheyeundistortimage-doesnt-work-what-wrong-with-my-code/