您的位置:首页 > 运维架构

OpenCV中二维点求取进行仿射和透视变换之后的坐标点方法

2015-09-14 18:23 519 查看
我使用的是OpenCV 2.2版本。得到了一个透视矩阵,想把屏幕上的一个二维点经过这个透视矩阵进行变换,本身很简单的一个事情,却颇费了一番周折。原因是刚接触OpenCV,而且使用了OpenCV新添加的C++部分的矩阵类Mat,使用起来还真有点不顺手,因为OpenCV中没有向量的说法。一个矩阵变换一个向量就让我找了半天。

最终得以解决,还是使用了CvMat类而不是Mat类。代码如下:

///透视变换

1 CvPoint transformPoint(const CvPoint pointToTransform, const CvMat* matrix)

2 {

3 double coordinates[3] = {pointToTransform.x, pointToTransform.y, 1};

4 CvMat originVector = cvMat(3, 1, CV_64F, coordinates);

5 CvMat transformedVector = cvMat(3, 1, CV_64F, coordinates);

6 cvMatMul(matrix, &originVector, &transformedVector);

7 CvPoint outputPoint = cvPoint((int)(cvmGet(&transformedVector, 0, 0) / cvmGet(&transformedVector, 2, 0)), (int)(cvmGet(&transformedVector, 1, 0) / cvmGet(&transformedVector, 2, 0)));

8 return outputPoint;

9 }

///仿射变换

//objectXY原坐标; temp转换后坐标; angle角度大小.

cv::Point2f calDeta(float angle, cv::Point2f pointXY, cv::Point2f objectXY)

{

cv::Point2f resultPoint, temp;

double radian = 3.1415926*(angle/180.0);

temp.x = objectXY.x*cos(radian) + objectXY.y*sin(radian) + (1-cos(radian))*pointXY.x - sin(radian)*pointXY.y;

temp.y = -objectXY.x*sin(radian) + objectXY.y*cos(radian) + sin(radian)*pointXY.x + (1-cos(radian))*pointXY.y;

return temp;

}

这个函数一个很有用的地方就在于,原本二维图上的一个像素点位于(x,y)处,经过一个变换(仿射变换、透视变换)之后,求取它的新的坐标点(x', y')。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: