日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

JavaScript動畫實例:運動的字母特效

 頭號碼甲 2021-09-29

      已知圓的坐標(biāo)方程為:

          X=R*SIN(θ)

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

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

編寫如下的HTML代碼。

<html>

<head>

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

</head>

<body>

<canvas id="myCanvas" width="600" height="600" style="border:3px double #996633;background:black;"></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文件,可以看到在瀏覽器窗口中呈現(xiàn)出如圖1所示的動畫效果。

 

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

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

 

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

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

            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);

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

 

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

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

<html>

<head>

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

</head>

<body>

<canvas id="myCanvas" width="600" height="600" style="border:3px double #996633;background:black;"></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文件,可以看到在瀏覽器窗口中呈現(xiàn)出如圖4所示的動畫效果。此時字母的運動軌跡就隨機變化著了。

 

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

      進一步我們考慮,能否將圖4的字母軌跡按一個圓周相似地繪制5條呢?采用一個循環(huán)加上適當(dāng)?shù)淖鴺?biāo)旋轉(zhuǎn)即可。編寫如下的HTML文件。

<html>

<head>

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

</head>

<body>

<canvas id="myCanvas" width="600" height="600" style="border:3px double #996633;background:black;"></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文件,可以看到在瀏覽器窗口中呈現(xiàn)出如圖5所示的動畫效果。

 

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

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

       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>旋轉(zhuǎn)的字母(四)</title>

</head>

<body>

<canvas id="myCanvas" width="600" height="600" style="border:3px double #996633;background:black;"></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文件,可以看到在瀏覽器窗口中呈現(xiàn)出如圖6所示的動畫效果。

 

圖6   字母A的隨機運動

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

<html>

<head>

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

</head>

<body>

<canvas id="myCanvas" width="600" height="600" style="border:3px double #996633;background:black;"></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文件,可以看到在瀏覽器窗口中呈現(xiàn)出如圖7所示的動畫效果。

 

圖7  字母的運動特效

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約