OpenCV笔记5——图像的重映射

在这里插入图片描述
图像的重映射,和初中学过的函数映射差不多是一个概念,大概就是把一幅图像中的像素点按照某种特定的关系重新排列;生活中最常接触的比如像上面这幅图中的镜像,还有爱自拍的你肯定会发现我们手机前置镜头和后置摄像头拍摄出来的图片是不一样的,这些效果都可以通过重映射是来实现。

相关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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值