注意,图像转置和图像旋转是两回事,图像转置只是把图像的行坐标和列坐标互换,程序实现起来非常简单!而图像旋转则是将图像旋转多少度!
图像转置的英文为Transpose,而图像旋转的英文为Image Rotation 请注意区别!
下面给出图像转置的MATLAB和OpeCV源码!
源码中用到的图像的下载链接为 http://pan.baidu.com/s/1boKYKFX
首先上MATLAB源码
clear all;
close all;
clc;
A=imread('007_gray.png');
tform=maketform('affine',[0 1 0;1 0 0;0 0 1]);
B=imtransform(A,tform,'nearest');%B中存储的是经过水平镜像变换后的图像
subplot(1,2,1),imshow(A);
title('原图像');
subplot(1,2,2),imshow(B);
title('图像转置');
再上OpenCV的C源码(不使用MAT类)
#include <opencv2/opencv.hpp>
#include <opencv2/legacy/compat.hpp>
#include <fstream>
using namespace std;
#pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"")
void transpose_image(IplImage *src,IplImage *dst) //实现水平镜像变换
{
int M,N;
M=src->height;
N=src->width;
int i=0,j=0;
double temp1;
CvScalar s1;
for(i=0;i<M;i++)
{
for(j=0;j<N;j++)
{
temp1 = cvGet2D(src,i,j).val[0];
s1.val[0]=temp1;
cvSet2D(dst,j,i,s1);
}
}
}
int main()
{
int src_height,src_width;
IplImage *pSrcImage = cvLoadImage("007_gray.png", CV_LOAD_IMAGE_UNCHANGED);
src_height=pSrcImage->height;
src_width=pSrcImage->width;
CvSize dst_size;
dst_size.height=src_width;
dst_size.width=src_height;
IplImage *pOutImage = cvCreateImage(dst_size, IPL_DEPTH_8U,1);
transpose_image(pSrcImage,pOutImage);
const char *pstrWindowsATitle = "原图";
const char *pstrWindowsBTitle = "变换后的图";
//创建窗口
cvNamedWindow(pstrWindowsATitle, CV_WINDOW_AUTOSIZE);
cvNamedWindow(pstrWindowsBTitle, CV_WINDOW_AUTOSIZE);
//在指定窗口中显示图像
cvShowImage(pstrWindowsATitle, pSrcImage);
cvShowImage(pstrWindowsBTitle, pOutImage);
//等待按键事件
cvWaitKey();
cvDestroyWindow(pstrWindowsATitle);
cvDestroyWindow(pstrWindowsBTitle);
cvReleaseImage(&pSrcImage);
cvReleaseImage(&pOutImage);
return 0;
}
运行结果如下图所示:
再上OpenCV的C++源码(使用MAT类)
程序中使用到的图片的下载链接:http://pan.baidu.com/s/1dFv2MM9
//OpenCV版本2.4.9
//交流QQ2487872782
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
int main()
{
cv::Mat srcImage = cv::imread("pool.jpg");
if(!srcImage.data)
return -1;
// 图像转置
cv::Mat resultImage;
cv::transpose(srcImage, resultImage);
cv::imshow("srcImage", srcImage);
cv::imshow("转置后的图像", resultImage);
cv::waitKey(0);
return 0;
}
运行结果如下图所示: