一、引言
Matlab具有強大的可視功能,也可以用其制作動畫。最簡單的實現動畫的方法就是用設定好目標圖元的動作路線,之后使用循環語句和暫停命令pause來實現更新圖元的位置,這樣動畫就制作完成了。
本文以三只小燕子(可以理解為一家三口,哈哈)在某個區域內飛翔為例,帶你一步一步學習簡易動畫的制作。
二、制作簡易動畫步驟
1、繪制動畫的目標圖形
1)繪制一只小燕子,可以使用正弦曲線拼接的方法(有點簡單,像簡易硬筆畫),具體做法是:
取0~pi之間的正弦曲線做燕子的翅膀
0~pi/2之間的曲線當做右翅膀
pi/2~pi之間的曲線當做左翅膀
代碼如下:
x1 = [ 0:0.01:1/2 ] * pi;%右側翅膀橫坐標
y1 = sin( x1 ); %右側翅膀縱坐標
x2 = [ 1/2:0.001:1 ] * pi;%左側翅膀橫坐標
y2 = sin( x2 ); %左側翅膀縱坐標
p1 = plot( (x1+pi)/2, (y1+3)/2, 'k' );%右翅膀在右側,所以需要“+pi”
hold on
p2 = plot( x2/2, (y2+3)/2, 'k' );
axis( [ -8, 10, 0, 10 ] )
繪圖結果:(有點孤單)
2)繪制另外兩只小燕子,仿照上面的做法即可,代碼如下:
p3 = plot( (x1+pi)/2+2, (y1+3)/3, 'k' );
p4 = plot( x2/2+2, (y2+3)/3 , 'k' );
p5 = plot( (x1+pi)/3-2, (y1+3)/3, 'k' );
p6 = plot( x2/3-2, (y2+3)/3, 'k' );
結果如下圖所示:
到這里是不是發現了,畫小燕子原來如此簡單。當然了說是鴻雁那就更像了。
2、設定場景
1)給矩形區域增加背景色
%給矩形區域添加背景色
axis( [ -8, 10, 0, 10 ] )
set( gca, 'color', [ 1, 1, 0.9 ] );%gca表示當前圖形區域
2)再畫個紅太陽
%繪制紅太陽
t = (0:0.1:2) * pi;
x = 0.5 * cos(t) + 8;
y = 0.5 * sin(t) + 9;
fill( x, y, 'r' )
axis equal
axis( [ -8, 10, 0, 10 ] )%此語句是用來重新調整繪圖區域
此時得到的圖像窗口如下圖所示:
3)再畫兩座上(這樣看著是不是背景更豐富一點)
%繪制兩座高山
xh = [ -8 : 0.2 : 8 ];
yh1 = 2 * exp( -(xh + 5).^2 / 2 );
fill( xh, yh1, 'b' )
hold on
yh2 = 1.5 * exp( -xh.^2 / 4 );
area( xh, yh2, 'FaceColor', [ 0.1, 0.1, 0.9 ] );
此時動畫的背景就變成了如下圖所示,看起來是不是比上一步的圖好看了一點。當然了你也可設計的更漂亮一些。
3、規劃運動路線
假設小燕子沿著正弦曲線或者余弦曲線運動
path_x = [-2 : 0.01 : 2] *pi;%橫坐標
path_y1 = sin( dir ); %第一只小燕子的飛行路線
path_y2 = cos( dir ); %第二只小燕子的飛行路線
path_y3 = cos( fliplr(dir) );%第三只小燕子的飛行路線
4、運動設計
把三只小燕子分布放到指定的初始位置,然后用set命令修改每只小燕子對應的圖像句柄(p1,p2)、(p3,p4)和(p5,p6)的位置坐標即可實現小燕子的位置改變了。再加上循環語句和暫停命令pause,就是可以實現小燕子的飛行動畫。代碼如下(以飛行5個周期為例,也可以修改周期的值,或者直接改為死循環也可以):
hight = 2;%設定小燕子的初始高度
period = 5; %運動周期
k = 0;
len = length( path_x );
while k < periodfor i = 1 : lenset( p1, 'Xdata', path_x(i) +(x1+pi)/2, 'Ydata', path_y1(i)+2 + (y1+3)/2 + hight );set( p2, 'Xdata', path_x(i) + x2/2, 'Ydata', path_y1(i) + 2 + (y2+3)/2 + hight );set( p3, 'Xdata', path_x(i)-2 + (x1+pi)/2, 'Ydata', path_y2(i)+2 + (y1+3)/3 + hight );set( p4, 'Xdata', path_x(i)-2 + x2/2, 'Ydata', path_y2(i) + 2 + (y2+3)/3 + hight );set( p5, 'Xdata', path_x(len-i+1) + (x1+pi)/3, 'Ydata', path_y3(i) + 2 + (y1+3)/3 + hight );set( p6, 'Xdata', path_x(len-i+1) + x2/3, 'Ydata', path_y3(i) + 2 + (y2+3)/3 + hight );pause(0.02);endpath_x = fliplr( path_x );%逆向返回飛行k = k + 1;
end
至此,關于小燕子在某個場景中飛行的簡單動畫就繪制完成了。
飛行中兩個場景如下:
三、完整的代碼
%取0~pi之間的正弦曲線做燕子的翅膀
%0~pi/2之間的曲線當做右翅膀
%pi/2~pi之間的曲線當做左翅膀
clear all
clc
x1 = [ 0:0.01:1/2 ] * pi;%右側翅膀橫坐標
y1 = sin( x1 ); %右側翅膀縱坐標
x2 = [ 1/2:0.001:1 ] * pi;%左側翅膀橫坐標
y2 = sin( x2 ); %左側翅膀縱坐標
p1 = plot( (x1+pi)/2, (y1+3)/2, 'k' );%右翅膀在右側,所以需要“+pi”
hold on
p2 = plot( x2/2, (y2+3)/2, 'k' );
axis( [ -8, 10, 0, 10 ] ) %規劃處矩形區域p3 = plot( (x1+pi)/2+2, (y1+3)/3 + 3, 'k' );
p4 = plot( x2/2+2, (y2+3)/3 + 3 , 'k' );p5 = plot( (x1+pi)/3-2, (y1+3)/3 + 1, 'k' );
p6 = plot( x2/3-2, (y2+3)/3 + 1, 'k' );%給矩形區域添加背景色
axis( [ -8, 10, 0, 10 ] )
%set( gcf, 'doublebuffer', 'on');
set( gca, 'color', [ 1, 1, 0.9 ] );%gca表示當前圖形區域%繪制紅太陽
t = (0:0.1:2) * pi;
x = 0.5 * cos(t) + 8;
y = 0.5 * sin(t) + 9;
fill( x, y, 'r' )
axis equal
axis( [ -8, 10, 0, 10 ] )
%繪制兩座高山
xh = [ -8 : 0.2 : 8 ];
yh1 = 2 * exp( -(xh + 5).^2 / 2 );
fill( xh, yh1, 'b' )
hold on
yh2 = 1.5 * exp( -xh.^2 / 4 );
area( xh, yh2, 'FaceColor', [ 0.1, 0.1, 0.9 ] );%運動路線
path_x = [-2 : 0.01 : 2] *pi;%橫坐標
path_y1 = sin( path_x ); %第一只小燕子的飛行路線
path_y2 = cos( path_x ); %第二只小燕子的飛行路線
path_y3 = cos( fliplr(path_x) );%第三只小燕子的飛行路線
set( gcf, 'doublebuffer', 'on');
hight = 2;%設定小燕子的初始高度
period = 5; %運動周期
k = 0;
len = length( path_x );
while k < periodfor i = 1 : lenset( p1, 'Xdata', path_x(i) +(x1+pi)/2, 'Ydata', path_y1(i)+2 + (y1+3)/2 + hight );set( p2, 'Xdata', path_x(i) + x2/2, 'Ydata', path_y1(i) + 2 + (y2+3)/2 + hight );set( p3, 'Xdata', path_x(i)-2 + (x1+pi)/2, 'Ydata', path_y2(i)+2 + (y1+3)/3 + hight );set( p4, 'Xdata', path_x(i)-2 + x2/2, 'Ydata', path_y2(i) + 2 + (y2+3)/3 + hight );set( p5, 'Xdata', path_x(len-i+1) + (x1+pi)/3, 'Ydata', path_y3(i) + 2 + (y1+3)/3 + hight );set( p6, 'Xdata', path_x(len-i+1) + x2/3, 'Ydata', path_y3(i) + 2 + (y2+3)/3 + hight );pause(0.02);endpath_x = fliplr( path_x );%逆向返回飛行k = k + 1;
end
總結
以上是生活随笔為你收集整理的MATLAB制作简易小动画入门详解的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。