#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <iostream>
int main()
{
cv::Mat srcImage = cv::imread("1.jpg");
if(!srcImage.data)
return -1;
// 输出矩阵定义
cv::Mat resultImage(srcImage.size(), srcImage.type());
// X与Y方向矩阵
cv::Mat xMapImage(srcImage.size(), CV_32FC1);
cv::Mat yMapImage(srcImage.size(), CV_32FC1);
int rows = srcImage.rows;
int cols = srcImage.cols;
for( int j = 0; j < rows; j++ )
{
for( int i = 0; i < cols; i++ )
{
// x与y均翻转
xMapImage.at<float>(j,i) = cols - i ;
yMapImage.at<float>(j,i) = rows - j ;
}
}
// 重映射操作
remap( srcImage, resultImage, xMapImage, yMapImage,
CV_INTER_LINEAR, cv::BORDER_CONSTANT,
cv::Scalar(0,0, 0) );
// 输出结果
cv::imshow("srcImage", srcImage);
cv::imshow("resultImage", resultImage);
cv::waitKey(0);
return 0;
}
remap 重映射
最新推荐文章于 2023-11-30 15:06:06 发布