matlab,制作GIF动画(png转gif)

目标:将三幅图(png格式)制作成GIF

准备材料:三幅png格式的图
在这里插入图片描述

gif展现一个动态由悲到喜的过程

实现代码:

`%预定义变量
Picture_save = {0};                                                        
%初始化提高效率
filename = 'myGIF.gif';


%图像获取,图像类型转换
[P1, map]  = imread('1.png');     
picture1 = ind2rgb(P1,map);                                                
%索引图必须转换为真彩图,否则颜色不对
[P2, map]  = imread('2.png');
picture2 = ind2rgb(P2,map);
[P3, map]  = imread('3.png');
picture3 = ind2rgb(P3,map);

array = [{picture1}, {picture2} ,{picture3}];                              
%方便循环  

%保留帧数据
for idx = 1:3
    figure(idx)
    imshow(array{idx});                                                    
    %索引图转换为真彩图 ,{}访问数组里面的类型 ()访问元胞类型     
    Picture_save{idx} = frame2im(getframe(idx));                           
    %获取figure(idx)展示的效果,将其以图片数据保存
    close all
end

%制作GIF
%有个bug 在第一次播放的时候没有中间的那一帧,之后又有了
for idx = 1:3
    [A,map] = rgb2ind(Picture_save{idx},256);                              
    %imwrite不能显示三维图像,所以要进行转换
    if idx == 1
        imwrite(A,map,filename,'gif','LoopCount',Inf,'DelayTime',0.5);    
         %Inf 无限循环
    else
        imwrite(A,map,filename,'gif','WriteMode','append','DelayTime',0.5);
    end
end

close all`

以下是代码的截图
在这里插入图片描述

当然了,还有更简单的办法:

for idx = 1:3
    [A,map] = imread(strcat(num2str(idx),'.PNG'));                              %imwrite不能显示三维图像,所以要进行转换
    if idx == 1
        imwrite(A,map,'new.gif','LoopCount',Inf,'DelayTime',0.5);               %Inf 无限循环
    else
        imwrite(A,map,'new.gif','WriteMode','append','DelayTime',0.8);
    end
end

关于代码有遇到别的问题,或者有改进意见,欢迎评论。

在实现过程中我也遇到了很多问题,有些注释在代码中,有些遗漏了,希望可以在讨论中得到补充。

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MATLAB制作GIF动态图通常涉及到使用imwrite和imread函数以及pause或waitforbuttonpress等暂停命令来逐帧保存和显示图像。以下是一个简单的步骤指南: 1. **创建或读取图像序列**: - 使用`imread`读取单张图片,或者创建多张图片数组。 - 如果需要自动生成动画,可以用for循环或cell数组生成一系列图片。 ```matlab frames = {}; % 创建一个空cell数组存储帧 for i = 1:total_frames % 假设你有一个名为'frame_'与帧数相关的文件名列表 frame = imread('frame_' + num2str(i) + '.jpg'); % 替换为你的文件路径 frames{i} = frame; % 将帧添加到cell数组 end ``` 2. **保存每一帧**: - 使用`imwrite`保存每帧为临时文件,例如`.png`,因为MATLAB的内建功能不直接支持GIF格式。 ```matlab % 假定临时目录为'temp_dir' temp_dir = 'temp_dir'; if ~exist(temp_dir, 'dir') mkdir(temp_dir); end for i = 1:length(frames) filename = fullfile(temp_dir, ['frame' num2str(i) '.png']); imwrite(frames{i}, filename); end ``` 3. **合并为GIF**: - 使用系统调用或者外部工具(如ImageMagick)将PNG换为GIFMATLAB不直接支持这个操作。 ```matlab % 假定系统路径下有convert工具 [status, result] = system(['convert -delay 10 ' temp_dir '/*.png ' temp_dir '/animation.gif']); % 延迟时间10毫秒,替换为实际延迟值 if status ~= 0 error('Error converting to GIF'); end ``` 4. **清理临时文件**: - 完成GIF制作后,如果需要,删除临时PNG文件。 ```matlab files_to_delete = fullfile(temp_dir, 'frame_*.png'); delete(files_to_delete); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鄢广杰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值