我正在编写一个 GLSL 着色器来使用模型、视图和投影矩阵进行 3D 顶点的投影。
我用这个作为投影矩阵。但是我没有得到扭曲的图像。为了扭曲我使用的观点:
vec4 distort(vec4 pos){
// normalize
float z = pos[2];
float z_inv = 1 / z;
float x1 = pos[0] * z_inv;
float y1 = pos[1] * z_inv;
// precalculations
float x1_2 = x1 * x1;
float y1_2 = y1 * y1;
float x1_y1 = x1 * y1;
float r2 = x1_2 + y1_2;
float r4 = r2 * r2;
float r6 = r4 * r2;
// rational distortion factor
float r_dist = (1 + k1 * r2 + k2 * r4 + k3 * r6)
/ (1 + k4 * r2 + k5 * r4 + k6 * r6);
// full (rational + tangential) distortion
float x2 = x1 * r_dist + 2 * p1 * x1_y1 + p2 * (r2 + 2 * x1_2);
float y2 = y1 * r_dist + 2 * p2 * x1_y1 + p1 * (r2 + 2 * y1_2);
// denormalize for projection (which is a linear operation)
return vec4(x2*z, y2*z, z, pos[3]);}
投影如下:
vec4 view_pos = modelView * vec4(aPos, 1.0);
vec4 dist_pos = distort(view_pos);
gl_Position = projection * dist_pos;
问题是当相机靠近物体时,我得到的 3d 点投影非常糟糕。有没有办法检查该点是否可失真,我正在使用的失真函数是否有问题(我正在尝试使用 OpenCV 失真)?