MATLAB:图像水平、垂直、水平垂直镜像、转置、旋转变换(flipdim、mirror、transp、imrotate函数)
1、原图像经水平、垂直、水平垂直镜像设置通过mirror函数实现:
close all; %关闭当前所有图形窗口,清空工作空间变量,清除工作空间所有变量 clear all; clc; I=imread('cameraman.tif'); %输入图像 J1=mirror(I,1);%原图像的水平镜像 J2=mirror(I,2);%原图像的垂直镜像 J3=mirror(I,3);%原图像的水平垂直镜像 set(0,'defaultFigurePosition',[100,100,1000,500]);%修改图形图像位置的默认设置 set(0,'defaultFigureColor',[1 1 1])%修改图形背景颜色的设置 figure, subplot(1,2,1),imshow(I) ;%绘制原图像 subplot(1,2,2),imshow(J1);%绘制水平镜像后图像 figure, subplot(1,2,1),imshow(J2);%绘制垂直镜像后图像 subplot(1,2,2),imshow(J3);%绘制水平垂直镜像后图像
效果图如下:
以上的mirror函数针对的是低级版本的MATLAB,目前高级版本的MATLAB已经不支持mirror函数了,如果你的MATLAB用了mirror函数后出现各种报错,说明你的版本太高级了。需要用flipdim函数,参数设置跟mirror函数一样。示例代码如下:
close all; %关闭当前所有图形窗口,清空工作空间变量,清除工作空间所有变量 clear all; clc; I=imread('cameraman.tif'); %输入图像 J1=flipdim(I,1);%原图像的水平镜像 J2=flipdim(I,2);%原图像的垂直镜像 J3=flipdim(I,3);%原图像的水平垂直镜像 set(0,'defaultFigurePosition',[100,100,1000,500]);%修改图形图像位置的默认设置 set(0,'defaultFigureColor',[1 1 1])%修改图形背景颜色的设置 figure, subplot(1,2,1),imshow(I) ;%绘制原图像 subplot(1,2,2),imshow(J1);%绘制水平镜像后图像 figure, subplot(1,2,1),imshow(J2);%绘制垂直镜像后图像 subplot(1,2,2),imshow(J3);%绘制水平垂直镜像后图像
2、图像转置用了transp函数,实现代码如下:
close all; %关闭当前所有图形窗口,清空工作空间变量,清除工作空间所有变量 clear all; clc; I=imread('trees.tif'); %输入图像 J1=transp(I); %对原图像的转置 I1=imread('lenna.bmp'); %输入图像 J2=transp(I1); %对原图像的转置 set(0,'defaultFigurePosition',[100,100,1000,500]);%修改图形图像位置的默认设置 set(0,'defaultFigureColor',[1 1 1])%修改图形背景颜色的设置 figure, subplot(1,2,1),imshow(I);%绘制移动后图像 subplot(1,2,2),imshow(J1);%绘制移动后图像 figure, subplot(1,2,1),imshow(I1) subplot(1,2,2),imshow(J2)
效果图如下:
3、图像旋转用了imrotate函数,实现过程如下:
close all; %关闭当前所有图形窗口,清空工作空间变量,清除工作空间所有变量 clear all; clc; A=imread('office_2.jpg'); %读入图像 J1=imrotate(A, 30); %设置旋转角度,实现旋转并显示 J2=imrotate(A, -30); J3=imrotate(A,30,'bicubic','crop'); %设置输出图像大小,实现旋转图像并显示 J4=imrotate(A,30, 'bicubic','loose'); set(0,'defaultFigurePosition',[100,100,1000,500]);%修改图形图像位置的默认设置 set(0,'defaultFigureColor',[1 1 1])%修改图形背景颜色的设置 figure(1) %显示旋转处理结果 subplot(121),imshow(J1); subplot(122),imshow(J2); figure(2) subplot(121),imshow(J3); subplot(122),imshow(J4);
效果图如下:
本文来自博客园,作者:橙子牛奶糖(陈文燕),转载请注明原文链接:https://www.cnblogs.com/chenwenyan/p/6836578.html