日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

JavaScript动画实例:运动的字母特效

發布時間:2023/12/15 综合教程 21 生活家
生活随笔 收集整理的這篇文章主要介紹了 JavaScript动画实例:运动的字母特效 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

已知圓的坐標方程為:

X=R*SIN(θ)

Y=R*COS(θ) (0≤θ≤2π)

給定初始坐標位置(X,Y),按照圓的坐標方程,從角度angle = 0開始,每間隔angleSpeed = 0.2求得一個坐標值(x,y),將這個坐標值作為偏移變化量,分別加到初始坐標位置上,即在(X+x,Y+y)處填充字母“A”。填充15個字母后,清除畫布,重新從初始坐標位置開始動畫過程。

編寫如下的HTML代碼。

<html>

<head>

<title>旋轉的字母(一)</title>

</head>

<body>

<canvas id="myCanvas" width="600" height="600"></canvas>

<script>

var canvas = document.getElementById('myCanvas');

var ctx = canvas.getContext('2d');

var w2 = Math.floor(canvas.width/ 2);

var h2 = Math.floor(canvas.height/ 2);

var pi2 = Math.PI * 2;

ctx.font = "36px Impact";

ctx.translate(w2, h2);

var char = "A";

var x =0;

var y =0;

var radius = 30;

var angle = 0;

var angleSpeed = 0.2;

var color='rgba(0,255,255,0.9)';

var age = 0;

function animate()

{

ctx.fillStyle=color;

ctx.fillText(char, x, y);

x += Math.cos(angle) * radius;

y += Math.sin(angle) * radius;

angle += angleSpeed;

age++;

if (age >= 15)

{

ctx.clearRect(-canvas.width,-canvas.height,2*canvas.width,2*canvas.height);

x = 0;

y = 0;

angle = 0;

age=0;

}

}

setInterval('animate()',100);

</script>

</body>

</html>

在瀏覽器中打開包含這段HTML代碼的html文件,可以看到在瀏覽器窗口中呈現出如圖1所示的動畫效果。

圖1 angleSpeed = 0.2的字母運動效果

若將上面程序中的語句“var angleSpeed = 0.2;”改寫為“var angleSpeed = 0.45;”,其余部分保持不變,則在瀏覽器窗口中呈現出如圖2所示的動畫效果。

圖2 angleSpeed = 0.45的字母運動效果

由圖1和圖2看出,輸出的字母“A”看起來沿著一個圓周線,但字母均是朝向正上方,能否讓字母朝著圓周線的方向呢?這需要在輸出字母的時候適當旋轉坐標。將程序中的語句

ctx.fillText(char, x, y);

改寫為:

ctx.translate(x, y);

ctx.rotate(angle + pi2 / 4);

ctx.fillText(char, -13,10);

ctx.rotate(-angle-pi2 / 4);

ctx.translate(-x, -y);

其余部分保持不變,則在瀏覽器窗口中呈現出如圖3所示的動畫效果。

圖3 沿著圓周線運動的字母

由圖3看出,字母“A”的運動軌跡是確定的。若在角度angle的變化中加入隨機因素會怎樣呢?編寫如下的HTML文件。

<html>

<head>

<title>旋轉的字母(二)</title>

</head>

<body>

<canvas id="myCanvas" width="600" height="600"></canvas>

<script>

var canvas = document.getElementById('myCanvas');

var ctx = canvas.getContext('2d');

var w2 = Math.floor(canvas.width/ 2);

var h2 = Math.floor(canvas.height/ 2);

var pi2 = Math.PI * 2;

ctx.font = "36px Impact";

ctx.translate(w2, h2);

var char = "A";

var x =0;

var y =0;

var radius = 30;

var angle = pi2*0.05;

var angleSpeed = 0.2;

var color='rgba(0,255,255,0.9)';

var age = 0;

function animate()

{

ctx.fillStyle=color;

ctx.translate(x, y);

ctx.rotate(angle + pi2 / 4);

ctx.fillText(char, -13, 10);

ctx.rotate(-angle-pi2 / 4);

ctx.translate(-x, -y);

x += Math.cos(angle) * radius;

y += Math.sin(angle) * radius;

angle += angleSpeed;

age++;

if (Math.random() > 0.75) // 加入隨機變化

{

angleSpeed *= -1;

}

if (age >= 15)

{

ctx.clearRect(-canvas.width,-canvas.height,2*canvas.width,2*canvas.height);

x = 0;

y = 0;

angle = pi2*0.05;

angleSpeed = 0.2;

age=0;

}

}

setInterval('animate()',100);

</script>

</body>

</html>

在瀏覽器中打開包含這段HTML代碼的html文件,可以看到在瀏覽器窗口中呈現出如圖4所示的動畫效果。此時字母的運動軌跡就隨機變化著了。

圖4 有著隨機變化的沿著圓周線運動的字母

進一步我們考慮,能否將圖4的字母軌跡按一個圓周相似地繪制5條呢?采用一個循環加上適當的坐標旋轉即可。編寫如下的HTML文件。

<html>

<head>

<title>旋轉的字母(三)</title>

</head>

<body>

<canvas id="myCanvas" width="600" height="600"></canvas>

<script>

var canvas = document.getElementById('myCanvas');

var ctx = canvas.getContext('2d');

var w2 = Math.floor(canvas.width/ 2);

var h2 = Math.floor(canvas.height/ 2);

var pi2 = Math.PI * 2;

ctx.font = "36px Impact";

ctx.translate(w2, h2);

var char = "A";

var x =30;

var y =30;

var radius = 30;

var angle = pi2*0.05;

var angleSpeed = 0.2;

color='rgba(0,255,255,0.9)';

age = 0;

symmetry =5;

function animate()

{

for (i = 0;i<symmetry; i++)

{

ctx.fillStyle=color;

ctx.translate(x, y);

ctx.rotate(angle + pi2 / 4);

ctx.fillText(char, -13, 10);

ctx.rotate(-angle-pi2 / 4);

ctx.translate(-x, -y);

ctx.rotate(pi2 / symmetry);

}

x += Math.cos(angle) * radius;

y += Math.sin(angle) * radius;

angle += angleSpeed;

age++;

if (Math.random() > 0.75)

{

angleSpeed *= -1;

}

if (age >= 15)

{

ctx.clearRect(-canvas.width,-canvas.height,2*canvas.width,2*canvas.height);

x = 30;

y = 30;

angle = pi2*0.05;

angleSpeed = 0.2;

age=0;

}

}

setInterval('animate()',100);

</script>

</body>

</html>

在瀏覽器中打開包含這段HTML代碼的html文件,可以看到在瀏覽器窗口中呈現出如圖5所示的動畫效果。

圖5 字母“A”的5條相似運動軌跡

更進一步,我們將上面程序中的初始坐標位置(x,y)、初始角度angle、角度變化量angleSpeed、字母填充顏色color和相似軌跡條數symmetry均采用隨機數的方式確定初值,例如:

x = rand(-w2/2,w2/2);

y = rand(-h2/2,h2/2);

angle = Math.random() * pi2;

angleSpeed = Math.random() * 1 - 0.5;

color='rgba('+rand(0,255)+','+rand(0,255)+','+rand(0,255)+',0.9)';

symmetry =rand(3,10);

編寫如下的HTML代碼。

<html>

<head>

<title>旋轉的字母(四)</title>

</head>

<body>

<canvas id="myCanvas" width="600" height="600"></canvas>

<script>

var canvas = document.getElementById('myCanvas');

var ctx = canvas.getContext('2d');

var w2 = Math.floor(canvas.width/ 2);

var h2 = Math.floor(canvas.height/ 2);

var pi2 = Math.PI * 2;

ctx.font = "36px Impact";

ctx.translate(w2, h2);

function rand(min,max)

{

return Math.floor(Math.random()*(max-min)+min)

}

var char = "A";

var x,y,radius,angle,angleSpeed,color,age,symmetry;

function reset()

{

x = rand(-w2/2,w2/2);

y = rand(-h2/2,h2/2);

radius = 30;

angle = Math.random() * pi2;

angleSpeed = Math.random() * 1 - 0.5;

color='rgba('+rand(0,255)+','+rand(0,255)+','+rand(0,255)+',0.9)';

age = 0;

symmetry =rand(3,10);

}

reset();

function animate()

{

for (i = 0;i<symmetry; i++)

{

ctx.fillStyle=color;

ctx.translate(x, y);

ctx.rotate(angle + pi2 / 4);

ctx.fillText(char, -13, 10);

ctx.rotate(-angle-pi2 / 4);

ctx.translate(-x, -y);

ctx.rotate(pi2 / symmetry);

}

x += Math.cos(angle) * radius;

y += Math.sin(angle) * radius;

angle += angleSpeed;

age++;

if (Math.random() > 0.75)

{

angleSpeed *= -1;

}

if (age >= 18)

{

ctx.clearRect(-canvas.width,-canvas.height,2*canvas.width,2*canvas.height);

reset();

}

}

setInterval('animate()',50);

</script>

</body>

</html>

在瀏覽器中打開包含這段HTML代碼的html文件,可以看到在瀏覽器窗口中呈現出如圖6所示的動畫效果。

圖6 字母“A”的隨機運動

最后,我們在圖6的基礎上考慮,能否搞多個字母有周期地組合進行運動,以此得到字母的運動特效呢?編寫如下的HTML文件。

<html>

<head>

<title>旋轉的字母(五)</title>

</head>

<body>

<canvas id="myCanvas" width="600" height="600"></canvas>

<script>

var canvas = document.getElementById('myCanvas');

var ctx = canvas.getContext('2d');

var w2 = Math.floor(canvas.width/ 2);

var h2 = Math.floor(canvas.height/ 2);

var pi2 = Math.PI * 2;

ctx.font = "36px Impact";

ctx.translate(w2, h2);

var srcChar =["A","B","C","D","E","F"];

var particles = [];

var eIndex = 0;

var rCnt=0;

function rand(min,max)

{

return Math.floor(Math.random()*(max-min)+min)

}

function resetPart(part)

{

part.char = srcChar[eIndex++];

if (eIndex>=srcChar.length)

{

eIndex=0;

}

part.x = rand(-w2/2,w2/2);

part.y = rand(-h2/2,h2/2);

part.radius = 30;

part.angle = Math.random() * pi2;

part.angleSpeed = Math.random() * 1 - 0.5;

part.color='rgba('+rand(0,255)+','+rand(0,255)+','+rand(0,255)+',0.9)';

part.age = 0;

part.symmetry =rand(3,10);

}

var count=2;

for (var i=0;i<count;i++)

{

var part;

part = {};

resetPart(part);

rCnt++;

particles.push(part);

}

function animate()

{

for (i =0;i<particles.length; i++)

{

part = particles[i];

for (j = 0;j<part.symmetry; j++)

{

ctx.fillStyle=part.color;

ctx.translate(part.x, part.y);

ctx.rotate(part.angle + pi2 / 4);

ctx.fillText(part.char, -13, 10);

ctx.rotate(-part.angle-pi2 / 4);

ctx.translate(-part.x, -part.y);

ctx.rotate(pi2 / part.symmetry);

}

part.x += Math.cos(part.angle) * part.radius;

part.y += Math.sin(part.angle) * part.radius;

part.angle += part.angleSpeed;

part.age++;

if (Math.random() > 0.75)

{

part.angleSpeed *= -1;

}

if (part.age >= 18)

{

resetPart(part);

rCnt++;

if (rCnt==6)

{

rCnt=0;

ctx.clearRect(-canvas.width,-canvas.height,2*canvas.width,2*canvas.height);

}

}

}

}

setInterval('animate()',50);

</script>

</body>

</html>

在瀏覽器中打開包含這段HTML代碼的html文件,可以看到在瀏覽器窗口中呈現出如圖7所示的動畫效果。

圖7 字母的運動特效

總結

以上是生活随笔為你收集整理的JavaScript动画实例:运动的字母特效的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。