答案 0 :(得分:0)
我也在寻找相同类型的功能。我找不到它,所以我自己实现了它。这是C ++代码。
首先,您需要使用焦距和中心对图像点进行标准化
rpt(0)=(pt_x-cx)/ fx
rpt(1)=(pt_y-cy)/ fy
然后扭曲归一化的图像点
double x = rpt(0), y = rpt(1);
//determining the radial distortion
double r2 = x*x + y*y;
double icdist = 1 / (1 - ((D.at<double>(4) * r2 + D.at<double>(1))*r2 + D.at<double>(0))*r2);
//determining the tangential distortion
double deltaX = 2 * D.at<double>(2) * x*y + D.at<double>(3) * (r2 + 2 * x*x);
double deltaY = D.at<double>(2) * (r2 + 2 * y*y) + 2 * D.at<double>(3) * x*y;
x = (x + deltaX)*icdist;
y = (y + deltaY)*icdist;
然后您可以使用投影的中心和焦距来平移和缩放点