- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
MATLAB绘制动态图片教程
Matlab除了强大的矩阵运算,仿真分析外,绘图功能也是相当的强大,静态画图没什么问题,由于Matlab本身的多线程编程缺陷,想要动态的画图,并且能够很好的在GUI中得到控制,还不是一件很容易的事情,下面总结几种方法。
一.AXIS移动坐标系
这种方法是最简单的一种方法,适合于数据已经全部生成的场合,先画图,然后移动坐标轴。实例代码如下:
%%
%先画好,然后更改坐标系
%在命令行中使用Ctrl+C 结束
t=0:0.1:100*pi;
m=sin(t);
plot(t,m);x=-2*pi;
axis([x,x+4*pi,-2,2]);gridon
while1
ifxmax(t)break;
endx=x+0.1;
axis([x,x+4*pi,-2,2]);%移动坐标系
pause(0.1);end
二.HoldOn 模式
此种方法比较原始,适合于即时数据,原理是先画上一帧,接着保留原始图像,追加下一幀图像,此种方式比较繁琐,涉及画图细节,并且没有完整并连续的Line对象数据。
例如:
%%
%HoldOn 法
% 此种方法只能点,或者分段划线
holdofft=0;m=0;
t1=[00.1];%要构成序列
m1=[sin(t1);cos(t1)];
p=plot(t,m,*,t1,m1(1,:),-r,t1,m1(2,:),-b,MarkerSize,5);x=-1.5*pi;
axis([xx+2*pi-1.51.5]);gridon;
fori=1:100holdon
t=0.1*i;%下一个点
m=t-floor(t);
t1=t1+0.1;%下一段线(组)m1=[sin(t1);cos(t1)];
p=plot(t,m,*,t1,m1(1,:),-r,t1,m1(2,:),-b,MarkerSize,5);x=x+0.1;
axis([xx+2*pi-1.51.5]);pause(0.01);
end
三.Plot 背景擦除模式
这种模式比较适合画动画,效率比较高,刷新闪烁小,适合即时
数据,最终的Line结构数据完整。
了解此方法之前要搞清楚Plot函数的原型是什么:Plot函数,输入为X-Y(-X)坐标元组、以及“属性”-“值对,输出为一个列向量(每条曲线岁对应的Line结构Handle,每一行代表一个线条的handles),每一线条都有XData,YData向量。如果你画了2条线,那么会返回2×1的向量。
重新画图不需要重新书写Plot,只需要刷新图像即可,使用
drawnow函数。
完整实例如下:
画一个点的动画:
%%
%采用背景擦除的方法,动态的划点,并且动态改变坐标系
%t,m 均为一行,并且不能为多行
t=0;m=0;
p=plot(t,m,*,...EraseMode,background,MarkerSize,5);
x=-1.5*pi;
axis([xx+2*pi-1.51.5]);gridon;
fori=1:1000
t=0.1*i; %两个变量均不追加m=sin(0.1*i);set(p,XData,t,YData,m)x=x+0.1;
drawnow
axis([xx+2*pi-1.51.5]);pause(0.1);
end
动态多条曲线(即时数据)
%%
%采用背景擦除的方法,动态的划线,并且动态改变坐标系
% 多行划线
t=[0]
m=[sin(t);cos(t)]
p=plot(t,m,...EraseMode,background,MarkerSize,5);
x=-1.5*pi;
axis([xx+2*pi-1.51.5]);gridon;
fori=1:1000
t=[t0.1*i]; %Matrix1*(i+1)
m=[m[sin(0.1*i);cos(0.1*i)]];%Matrix2*(i+1)
set(p(1),XData,t,YData,m(1,:))
set(p(2),XData,t,YData,m(2,:))drawnow
x=x+0.1;
axis([xx+2*pi-1.51.5]);pause(0.5);
end
上面的这几个画图方式的示例只是简单的for循环,是单线程的,如果是涉及到GUI的编程,那么请使用Timer来完成这件事情,Timer 是我在Matlab 中实现多线程唯一方法(没有找到别的方法)。
您可能关注的文档
最近下载
- 上海新型烟草制品研究院有限公司笔试试题2025.docx VIP
- 重庆市江津区2022-2023学年六年级上学期期末检测英语试题.docx VIP
- 异质结(HJT)太阳能电池浆料用超细球形银包铜粉.pdf VIP
- 黔东南州2023年秋季学期六年级期末质量监测道德与法治试卷.docx VIP
- JGJ∕T 326-2014 机械式停车库工程技术规范(附条文说明).pdf VIP
- 周世勋《量子力学教程》+习题解.pdf
- 第四章 光现象(知识清单)-2024人教版八年级物理上册(挖空版).pdf VIP
- 马克思主义基本原理概论简答题.doc VIP
- 2020年高考英语【省市名校好题精选】二轮训练: 语法填空(附答案与详解).doc VIP
- 学校线上教学工作总结讲话(校长).doc VIP
原创力文档


文档评论(0)