我正在唱歌cv::undistort,但它会裁剪图像。我想要所有未失真的图像,以便未失真的尺寸大于原始尺寸,如下所示:

我想我需要使用cv::getOptimalNewCameraMatrix,但我的试验没有运气..有帮助吗?
我正在唱歌cv::undistort,但它会裁剪图像。我想要所有未失真的图像,以便未失真的尺寸大于原始尺寸,如下所示:

我想我需要使用cv::getOptimalNewCameraMatrix,但我的试验没有运气..有帮助吗?
仅作记录:您应该使用cv::getOptimalNewCameraMatrix并将 alpha 参数设置为 1。Alpha 0 仅显示图像上的有效点,alpha 1 显示所有原始点以及黑色区域。cv::getOptimalNewCameraMatrix aslo 还为您提供了一个 ROI,可以从 cv::undistort 裁剪结果。
这段代码可以解决问题:
void loadUndistortedImage(std::string fileName, Mat & outputImage, 
    Mat & cameraMatrix, Mat & distCoeffs) {
    Mat image = imread(fileName, CV_LOAD_IMAGE_GRAYSCALE);
    // setup enlargement and offset for new image
    double y_shift = 60;
    double x_shift = 70;
    Size imageSize = image.size();
    imageSize.height += 2*y_shift;
    imageSize.width += 2*x_shift;
    // create a new camera matrix with the principal point 
    // offest according to the offset above
    Mat newCameraMatrix = cameraMatrix.clone();
    newCameraMatrix.at<double>(0, 2) += x_shift; //adjust c_x by x_shift
    newCameraMatrix.at<double>(1, 2) += y_shift; //adjust c_y by y_shift
    // create undistortion maps
    Mat map1;
    Mat map2;
    initUndistortRectifyMap(cameraMatrix, distCoeffs, Mat(), 
        newCameraMatrix, imageSize, CV_16SC2, map1, map2);
    //remap
    remap(image, outputImage, map1, map2, INTER_LINEAR);
}
请参阅http://docs.opencv.org/2.4/modules/calib3d/doc/camera_calibration_and_3d_reconstruction.html 和http://docs.opencv.org/2.4/modules/imgproc/doc/geometric_transformations.html
最好的方法是子类化 OpenCV 的类并重载方法 undistort(),以便访问您需要的所有图像。