matlab中使用plot函数动态画图方法

matlab中使用plot函数动态画图方法

ID:1955047

大小:21.55 KB

页数:5页

时间:2017-11-13

matlab中使用plot函数动态画图方法_第1页
matlab中使用plot函数动态画图方法_第2页
matlab中使用plot函数动态画图方法_第3页
matlab中使用plot函数动态画图方法_第4页
matlab中使用plot函数动态画图方法_第5页
资源描述:

《matlab中使用plot函数动态画图方法》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、Matlab中使用Plot函数动态画图方法总结本文来自:MATLAB爱好者论坛(MATLABFAN)作者:admin日期:2009-8-1711:23阅读:550人打印收藏大中小Plot,Matlab,函数,动态,画图Matlab除了强大的矩阵运算,仿真分析外,绘图功能也是相当的强大,静态画图没什么问题,由于Matlab本身的多线程编程缺陷,想要动态的画图,并且能够很好的在GUI中得到控制,还不是一件很容易的事情,下面总结几种方法。一.AXIS移动坐标系  这种方法是最简单的一种方法,适合于数据已经全部生成的场合,先画图,然后移动坐标

2、轴。实例代码如下:1.%%2.%先画好,然后更改坐标系3.%在命令行中使用Ctrl+C结束4.t=0:0.1:100*pi;5.m=sin(t);6.plot(t,m);7.x=-2*pi;8.axis([x,x+4*pi,-2,2]);9.gridon10.while111.ifx>max(t)12.break;13.end14.x=x+0.1;15.axis([x,x+4*pi,-2,2]);%移动坐标系16.pause(0.1);17.end复制代码二.HoldOn模式        此种方法比较原始,适合于即时数据,原理是先画

3、上一帧,接着保留原始图像,追加下一幀图像,此种方式比较繁琐,涉及画图细节,并且没有完整并连续的Line对象数据。  例如:1.%%2.%HoldOn法3.%此种方法只能点,或者分段划线4.holdoff5.t=0;6.m=0;7.t1=[00.1];%要构成序列8.m1=[sin(t1);cos(t1)];9.p=plot(t,m,'*',t1,m1(1,:),'-r',t1,m1(2,:),'-b','MarkerSize',5);  10.x=-1.5*pi;11.axis([xx+2*pi-1.51.5]);12.gridon;

4、13.14.fori=1:10015.  holdon16.  t=0.1*i;%下一个点17.  m=t-floor(t);18.  t1=t1+0.1;%下一段线(组)19.  m1=[sin(t1);cos(t1)];20.  p=plot(t,m,'*',t1,m1(1,:),'-r',t1,m1(2,:),'-b','MarkerSize',5);  21.  x=x+0.1;22.  axis([xx+2*pi-1.51.5]);23.  pause(0.01);24.end复制代码三.Plot背景擦除模式    这种模式

5、比较适合画动画,效率比较高,刷新闪烁小,适合即时数据,最终的Line结构数据完整。    了解此方法之前要搞清楚Plot函数的原型是什么:Plot函数,输入为X-Y(-X)坐标元组、以及“属性”-“值对,输出为一个列向量(每条曲线岁对应的Line结构Handle,每一行代表一个线条的handles),每一线条都有XData,YData向量。如果你画了2条线,那么会返回2×1的向量。重新画图不需要重新书写Plot,只需要刷新图像即可,使用drawnow函数。完整实例如下:1.画一个点的动画:1.%%2.%采用背景擦除的方法,动态的划点,

6、并且动态改变坐标系3.%t,m均为一行,并且不能为多行4.t=0;5.m=0;6.p=plot(t,m,'*',...7.  'EraseMode','background','MarkerSize',5);8.x=-1.5*pi;9.axis([xx+2*pi-1.51.5]);10.gridon;11.12.fori=1:100013.  t=0.1*i;    %两个变量均不追加14.  m=sin(0.1*i);15.  set(p,'XData',t,'YData',m)16.  x=x+0.1;  17.  drawnow

7、18.  axis([xx+2*pi-1.51.5]);1.  pause(0.1);2.end复制代码2.动态多条曲线(即时数据)1.%%2.%采用背景擦除的方法,动态的划线,并且动态改变坐标系3.%多行划线4.5.t=[0]6.m=[sin(t);cos(t)]7.p=plot(t,m,...8.  'EraseMode','background','MarkerSize',5);9.x=-1.5*pi;10.axis([xx+2*pi-1.51.5]);11.gridon;12.13.14.fori=1:100015.  t=[

8、t0.1*i];            %Matrix1*(i+1)16.  m=[m[sin(0.1*i);cos(0.1*i)]];%Matrix2*(i+1)17.  set(p(1),'XData',t,'YDa

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。