主体
二维:(以e.^(-1)为例)
· 二维静态图
% 绘制的图像参数
x = linspace(0,13,100);
y = exp(-x) ;
% 绘制图像
plot(x,y,'Color','#2F4F4F','LineWidth',1);
· 二维动态图
for i=1:length(x)
if i == 1
l=plot(x(i),y1(i),'Color','#483D8B','LineWidth',3);%e
res_x=x(i);
res_y1=y1(i);
else
l = plot([res_x x(i)],[res_y1 y1(i)],'Color','#483D8B','LineWidth',3);%e
res_x=x(i);
res_y1=y1(i);
end
pause(0.05);
end
注:
图中的光滑曲线并非矢量图,而是由多个折线段的累加而成,
此处plot内部的参数使用了res_x / res_y1 变量来记录上一次折线段的 “末” 坐标,
再与此次的坐标 x(i) , y1(i) 结合绘制新的折线段,
pause — 暂停0.05秒,便于观察每一次折线段的叠加过程
(若x过大,则pause内部的参数也可作出相应的调整)
依据前面理论,由此便可得到动态曲线的生成过程————动态图
分析:
一张图片
plot()...
多张图片
for i = ...
plot()...
end
实质:多张图片的叠加,同动画生成的原理
三维:(以旋转单叶双曲面为例)
· 三维静态图
a = 1; % 实轴长度
b = 2; % 虚轴长度
x_values = linspace(-2,2,20);
theta = linspace(0, 2*pi, 30);
% 创建网格
[Theta,X] = meshgrid(theta,x_values);
% 坐标系转换
X_rotated = a .* cosh(X) .* cos(Theta);
Y_rotated = a .* cosh(X) .* sin(Theta);
Z_rotated = b .* sinh(X);
% 绘制三维图
Fig_1 = surf(X_rotated, Y_rotated, Z_rotated,"FaceAlpha",.6,"LineWidth",0.7);
· 三维动态图
a = 1; % 实轴长度
b = 2; % 虚轴长度
x_values = linspace(-2,2,20);
for i=0:0.1:2
%% theta = linspace(0, 2*pi, 30) ——> linspace(0, i*pi, 30)
theta = linspace(0, i*pi, 30);
% 创建网格
[Theta,X] = meshgrid(theta,x_values);
% 坐标系转换
X_rotated = a .* cosh(X) .* cos(Theta);
Y_rotated = a .* cosh(X) .* sin(Theta);
Z_rotated = b .* sinh(X);
% 绘制三维图
Fig_1 = surf(X_rotated, Y_rotated, Z_rotated,"FaceAlpha",.6,"LineWidth",0.7);
end
分析:
一张图片
surf()...
多张图片
for i = ...
surf()...
end
实质:多张图片的叠加,同动画生成的原理
小结
如此将静态图的生成“放慢”,便成为了动态图
希望这篇博客对于数据动态可视化的绘制有所帮助