在Matlab Appdesigner对Simulink输出图像的动态展示

概要

       在APPdesigner中,有时候会用它来展示咱们在Simulink中的一些研究成果,在自动化控制方面就会用到一些跟踪曲线的展示等等,之前遇到这个问题,在一些网站都没有找到办法将曲线动态展示出来,这篇博客就介绍一种刚刚摸索出来的方法。

       之前参考了两篇文章,对我有一些帮助,但是没解决将图像动态展示的问题,大家有需要可以参考一下:

分享一个gui或app designer实时显示simulink仿真波形和实时进度的方法

matlab app designer使用心得

Simulink设置

        前面的两篇文章用到了“To file”模块,这点启发了我,我也将数据通过该模块生成“mat”格式的文件,但是在绘图方面我采用了另外的方法,后面会说到,在模块的设置方面我也有些不同,数据的保存格式我采用了数组,这样在运行过后会在该文件夹下生成数据的“mat”格式文件,为了方面后面对数据进行提取来绘图,设置如图:

Appdesigner设置

        首先制作一个简易的界面来展示图像的绘制过程,如图。

        在按钮的回调函数中添加展示图像的回调函数,这里用两个坐标系是为了展示可以通过该方法同时对多附图进行动态绘制,不然一幅一幅绘制太慢不利于结果展示。

       绘制采用Matlab中animatedline函数,函数有多种动态绘制方式,我采用可以控制速度的方式,可以跟据展示的数据量来修改速度,达到更好的展示效果,感兴趣的可以去看看这个函数的帮助文档,试试不同的方式,链接如下:

animatedline帮助文档

       回调函数如下:

                %运行Simulink模型
                sim("sinruntime.slx");
                %加载数据
                load example.mat;
                %生成的数据是一个两行的矩阵,第一行为时间,第二行为数据,这里分别取他们的第一行 
                %和第二行
                x1=example(1,:);
                y1=example(2,:);
                x2=example(1,:);
                y2=example(2,:);

                %静态绘图,在跟踪效果展示时,可以用于展示跟踪包线,让展示效果更明显
                plot(app.UIAxes,x1,y1);
                %若两个坐标系同时进行画图,在这里加一个plot
                plot(app.UIAxes_2,x1,y1);

                %动态展示,采用animatedline函数进行绘制。
                h1=animatedline(app.UIAxes,'color','r','LineWidth',3);
                %若两个坐标系同时进行画图,在这里加一个
                h2=animatedline(app.UIAxes_2,'color','r','LineWidth',3);
                %控制速度
                a=tic;
                for i=1:(length(x2))%数据长度
                    addpoints(h1,x2(i),y2(i));
                    %若两个坐标系同时进行画图,在这里加一个
                    addpoints(h2,x2(i),y2(i));
                    b = toc(a);
                    if b>(1/1000000)%速度调节分母越大速度越慢,表示每1000000分之1秒更新一次图 
                                    %像,可以理解为游戏里的帧率,根据数据量多少可以自行调节。
                       drawnow
                       a = tic;
                    end
                 end
                 drawnow

效果展示

       用一个视频展示一下最终的效果,展示的信号比较简单,数据量较少,导致实现起来速度很快,设置到1000000分之一都很快,但是在我所作的项目中,设置到500分之一就已经有很好的效果,所以这就是为什么选择可调速度的这个方式来展示,对不同的数据可以通过调节速度来改善展示效果。

效果展示

  • 11
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 12
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值