zl程序教程

您现在的位置是:首页 >  后端

当前栏目

图像转置的MATLAB和OpenCV源码

OpencvMATLAB源码 图像 转置
2023-09-11 14:15:39 时间

注意,图像转置和图像旋转是两回事,图像转置只是把图像的行坐标和列坐标互换,程序实现起来非常简单!而图像旋转则是将图像旋转多少度!

图像转置的英文为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;  

}  

运行结果如下图所示: