c – 从OpenCV中旋转的图像旋转后点

我有旋转烦恼.
我想做的是这样的:

>旋转图像
>检测旋转图像上的特征(点)
>旋转点,使我可以拥有对应于初始图像的点坐标

我有点困在第三步.

我设法用下面的代码旋转图像:

cv::Mat M(2,3,CV_32FC1);
cv::Point2f center((float)dst_img.rows / 2.0f,(float)dst_img.cols / 2.0f);
M = cv::getRotationMatrix2D(center,rotateAngle,1.0);
cv::warpAffine(dst_img,rotated,M,cv::Size(rotated.cols,rotated.rows));

我尝试用这个代码回转点:

float xp = r.x * std::cos( PI * (-rotateAngle) / 180 ) - r.y * sin(PI * (rotateAngle) / 180);
float yp = r.x * sin(PI * (-rotateAngle) / 180) + r.y * cos(PI * (rotateAngle) / 180);

这是不值得的工作,但点不会恢复良好的形象.有一个偏移.

感谢您的帮助

解决方法

如果M是从cv :: getRotationMatrix2D得到的旋转矩阵,可以使用此矩阵旋转cv :: Point p,您可以执行以下操作:
cv::Point result;
result.x = M.at<double>(0,0)*p.x + M.at<double>(0,1)*p.y + M.at<double>(0,2);
result.y = M.at<double>(1,0)*p.x + M.at<double>(1,1)*p.y + M.at<double>(1,2);

如果要旋转一个点,则生成M的逆矩阵,或者使用cv :: getRotationMatrix2D(center,-rotateAngle,scale)生成反向旋转矩阵.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...