代码一:这是我第一次在网上找的源代码,虽然能实现左右翻转的效果,但是却有两个问题。
I=imread('d:\1.png');
I2=I(:,end:-1:1);
subplot(121);
imshow(I);
title('原始图像');
subplot(122);
imshow(I2);
title('反转后的图像');
这是代码一对应的效果图,形成了三个左右翻转以后的图像,并且在尺寸上还缩小了。这主要是因为图像是RGB的,是三通道的,但是操作却只针对了一通道。所以程序对每一个通道都进行了翻转然后显示出来。
代码二:
I=imread('./1.png');
subplot(121);
imshow(I);
title('原始图像');
%为什么会有k=1:3,那是因为现在的图像都有RGB三个通道
%因此需要在每个通道都进行翻转最终一起作用到翻转后的图像
%基于上面的理解,当我首先把图像经过灰度处理变成灰度图以后
%就可以不要分3层,而直接翻转。
for k=1:3
I2=fliplr(I(:,:,k));
end
subplot(122);
imshow(I2);
title('变换后的图像');
这是代码二对应的效果图。
代码三:
自己基于上面的理解,重新写了个代码。来实现同样的效果。当然我的程序只是针对灰度图像了。
%1)先将RGB图像灰度化,不管你这幅图片原始就是黑白或彩色,
%都是以RGB三三通道表示的图像
%2)直接将灰度化的图像用fliplr函数进行左右翻转
I=imread('./1.png');
subplot(121);
imshow(I);
I2=rgb2gray(I);
%subplot(132);
%imshow(I2);
I3=fliplr(I2(:,:));
subplot(122);
imshow(I3);
代码三对应的效果图。