假设我们拥有两组相同场景的图像,一组是处理前的图像,一组是处理后的。
我们选取两组图像的部分区域合在一起,生成一组动态的GIF,可以进行直观的对比。
实现结果如图所示:
这里需要我们做以下处理:
- 1.将两组图像分别截取出需要的长方形部分
- 2.将长方形部分各自截取出梯形区域
- 3.将两个梯形区域相加,添加分隔线
- 4.对多帧图像进行以上操作,生成GIF
1.将两组图像分别截取出需要的长方形部分
对两组图片截取的大小和位置应该是一样的。
filename = 'shizuo.gif';
for pic=0:20
img_denoised = imread(['E:\matlab_exercise\special_effects\original_data\denoised\frame',num2str(pic),'_denoised_SRGB.png']);
img_pre = imread(['E:\matlab_exercise\special_effects\original_data\noisy\frame',num2str(pic),'_srgb.png']);
a = img_pre(281:636,1:660,:);% (上下,左右)
b = img_denoised(281:636,1:660,:);% (上下,左右)
2.将长方形部分各自截取出梯形区域
得到了长方形区域以后,将梯形区域以外的部分涂成黑色(像素变为0)即可,另外,对于新的长方形区域,坐标从1开始计算,这样计算中间分隔线的位置会更加简单。
% 左上方变黑
for i = 1:356
a(i,1:508-i,:) = 0;
end
% 右下方变黑
for j = 1:356
b(j,508-j:660,:) = 0;
end
得到的效果如下图所示:
3.将两个梯形区域相加,添加分隔线
因为黑色区域的像素是0,所以上面两张图直接相加就可以得到拼在一起的图。
分割线用白色实现。
% 两张图相加进行拼接
re = a + b;
% 画出2像素的分隔线
for k = 1:356
re(k,507-k:508-k,:) = 255;
end
得到的效果如下图所示:
4.对多帧图像进行以上操作,生成GIF
%% 制作GIF
[I,map] = rgb2ind(re,256);
if pic==0
imwrite(I,map,filename,'gif','Loopcount',inf,'DelayTime',0.3);
else
imwrite(I,map,filename,'gif','WriteMode','append','DelayTime',0.3);
end
end
这样就得到本文最开头的效果了。