MATLAB生成GIF

MATLAB生成GIF

前言

使用MATLAB脚本生成GIF动图

代码段

需要更改的地方:

  • filename,文件名
  • delay_t,GIF图片间隔时间
  • legend_para,初值,终值,个数
  • 画图部分
  • axis,图像显示范围(先注释掉,用自动模式看大概的范围,再填入固定参数;前两个是横轴,后两个是纵轴)
  • title,标题显示当前参数
delay_t=0.1; %图片间隔时间
legend_para = [0 10 20]; %初值,终值,个数
gif_name = '测试';

legend_step = (legend_para(2) - legend_para(1))/legend_para(3);
filename = [gif_name,num2str(legend_para(1)),'-',num2str(legend_para(2)),',num=',num2str(legend_para(3)),'.gif'];   % 打开或者创建一个gif文件
gif_sta=0;
for K = legend_para(1):legend_step:legend_para(2)

    % 动画效果/画图
    % C_S = zpk([-5*K],[-1*K],1);
    % rlocus(C_S*q);

    C_S = zpk([-5*K],[-1*K],1);
    step(feedback(1*C_S*q,1))

    axis([0 10 0 1.5]) %固定坐标系范围,不同图像范围不同,先自动,再固定这个范围
    % title(['K = ' num2str(K)]);
    title(['K = ' num2str(roundn(K,-3))]);
    grid on;    % 开启网格
    
    % 写入gif过程
    drawnow;
    CurrFrame = getframe(gcf);   % 获取像素,否则无法显示动画
    im = frame2im(CurrFrame);   % 
    [A,map] = rgb2ind(im,256);  % 将RGB图像转换为索引图像

    if gif_sta == 0
        gif_sta = 1;
        imwrite(A,map,filename,'gif','LoopCount',Inf,'DelayTime',delay_t);  % DelayTime表示写入的时间间隔
    else
        imwrite(A,map,filename,'gif','WriteMode','append','DelayTime',delay_t);
    end

end
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值