图像的重映射,和初中学过的函数映射差不多是一个概念,大概就是把一幅图像中的像素点按照某种特定的关系重新排列;生活中最常接触的比如像上面这幅图中的镜像,还有爱自拍的你肯定会发现我们手机前置镜头和后置摄像头拍摄出来的图片是不一样的,这些效果都可以通过重映射是来实现。
相关API:
注:最后两个参数可以忽略不写,即选择默认参数;
实验代码:
#include <iostream>
#include <opencv2/opencv.hpp>
using namespace cv;
using namespace std;
int main()
{
Mat img, dst;
Mat map_x, map_y;
img = imread("E:/chongqing.jpg");
if (!img.data)
{
printf("Fault to load image!\n\r");
return -1;
}
imshow("原图", img);
//创建和原始图一样的效果图,x重映射图,y重映射图
dst.create(img.size(), img.type());
map_x.create(img.size(), CV_32FC1);
map_y.create(img.size(), CV_32FC1);
//双层循环,遍历每一个像素点,改变map_x & map_y的值
for (int i = 0; i < img.rows; i++)
{
for (int j = 0; j < img.cols; j++)
{
if (i<img.rows/2)
{
//将图像的下半部分映射到新建图像的上半部分
map_y.at<float>(i, j) = static_cast<float>(img.rows-i);
map_x.at<float>(i, j) = static_cast<float>(j);
}
else
{
//将图像的下半部分映射到新建图像的下半部分
map_y.at<float>(i, j) = static_cast<float>(i);
map_x.at<float>(i, j) = static_cast<float>(j);
}
}
}
remap(img, dst, map_x, map_y, CV_INTER_LINEAR);
imshow("天空之镜", dst);
waitKey(0);
return 0;
}
注:
1.我对map_x和map_y的理解就是:因为一个像素点是由x,y两个参数确定的,对于函数而言,可以有y=f(x);所以对图像来说就得是g(x,y)=h(f(x,y)),我们在这里需要做的就是确定映射图像和原图像像素点之间的映射关系,即新的行(map_y)和列(map_x)与原图像的行(i)和列(j)之间的对应关系;
运行结果:
这是之前在重庆拍的夜景,弄个“天空之镜”的效果还是灰常不错的,请欣赏:
更多关于OpenCV重映射相关的知识参考下面的博客:
传送门:https://blog.csdn.net/poem_qianmo/article/details/30974513