成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

使用html5canvas實(shí)現(xiàn)心電圖移動(dòng)效果的方法

小編給大家分享一下使用html5 canvas實(shí)現(xiàn)心電圖移動(dòng)效果的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)建站專(zhuān)注于錫林郭勒盟網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供錫林郭勒盟營(yíng)銷(xiāo)型網(wǎng)站建設(shè),錫林郭勒盟網(wǎng)站制作、錫林郭勒盟網(wǎng)頁(yè)設(shè)計(jì)、錫林郭勒盟網(wǎng)站官網(wǎng)定制、小程序開(kāi)發(fā)服務(wù),打造錫林郭勒盟網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供錫林郭勒盟網(wǎng)站排名全網(wǎng)營(yíng)銷(xiāo)落地服務(wù)。

思路:

1、模擬點(diǎn)(如果你有真實(shí)的數(shù)據(jù),那就是把數(shù)據(jù)幻化成canvas對(duì)應(yīng)的坐標(biāo)點(diǎn))

模擬點(diǎn)時(shí)注意的點(diǎn)就是高起部分需要對(duì)稱(chēng)以及為了好看要隨機(jī)出現(xiàn)上上下下

2、畫(huà)線

畫(huà)線需要注意有一個(gè)勻速移動(dòng)的過(guò)程。

比如 A點(diǎn)到B點(diǎn),不是簡(jiǎn)單的A畫(huà)到B,而是A點(diǎn)到A1,A2....最后到B(這一塊按照比例移動(dòng)比較難)

3、畫(huà)線的一些效果,比如加上陰影(這里就可以自由發(fā)揮了)

具體代碼

<!DOCTYPE html>
 <html>
 <head>
     <meta charset="UTF-8">
     <title>心電圖</title>
     <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
     <style>
         html,body{
             width: 100%;
             height: 100%;
             margin: 0;
         }
         canvas{
             background: #000;
             width: 100%;
            height: 100%;
         }
     </style>
 </head>
 <body>
 <div id="canvas">
     <canvas id="can"></canvas>
 </div>
 <script>
     var can = document.getElementById('can'),
         pan,
         index = 0,
         flag = true,
         wid = document.body.clientWidth,
         hei = document.body.clientHeight,
         x = 0,
         y = hei/2,
         drawX = 0, 
         drawY = hei/2,
         drawXY = [],
         cDrawX = 0,
         i = 0,
         reX = 0,
         reY = 0;
     start();
     function start(){
         can.height = hei;
         can.width  = wid;
         pan = can.getContext("2d");
         pan.strokeStyle = "white";
         pan.lineJoin = "round";
         pan.lineWidth = 6;
         pan.shadowColor = "#228DFF";
         pan.shadowOffsetX = 0;
         pan.shadowOffsetY = 0;
         pan.shadowBlur = 20;
         pan.beginPath();
         pan.moveTo(x,y);
         drawXYS();
         index = setInterval(move,1);
     };

     function drawXYS(){
         if(drawX > wid){
         }else{
             if(drawY == hei/2){
                 if(flag){
                     flag = false;
                 }else{
                     var _y = Math.ceil(Math.random()*10);
                     _y = _y/2;
                     if(Number.isInteger(_y)){
                         drawY += Math.random()*180+30;
                     }else{
                         drawY -= Math.random()*180+30;
                     }
                     flag = true;
                 }
                 cDrawX = Math.random()*40+15;
             }else{
                 drawY = hei/2;
             }
             drawX += cDrawX;
             drawXY.push({
                 x : drawX,
                 y : drawY
             });
             drawXYS();
         }
     }

     function move(){
         var x = drawXY[i].x,
             y = drawXY[i].y;
         if(reX >= x - 1){
             reX = x;
             reY = y;
             i++;
             cc();
             return;
         }
         if(y > hei/2){
             if(reY >= y){
                 reX = x;
                 reY = y;
                 i++;
                 cc();
                 return;
             }
         }else if(y < hei/2){
             if(reY <= y){
                 reX = x;
                 reY = y;
                 i++;
                 cc();
                 return;
             }
         }else{
             reX = x;
             reY = y;
             i++;
             cc();
             return;
         }

         reX += 1;
         if(y == hei/2){
             reY = hei/2;
         }else{
             var c = Math.abs((drawXY[i].x-drawXY[i-1].x)/(drawXY[i].y-drawXY[i-1].y));
             var _yt = (reX-drawXY[i-1].x)/c;

             if(drawXY[i].y < drawXY[i-1].y){
                 reY = drawXY[i-1].y - _yt;
             }else{
                 reY = drawXY[i-1].y + _yt;
             }
         }
         cc();
     }

    function cc(){
        if(i == drawXY.length){
             pan.closePath();
             clearInterval(index);
             index = 0;
             x = 0;
             y = hei/2;
             flag = true;
             i = 0;
         }else{
             pan.lineTo(reX, reY);
             pan.stroke();
         }
    }
 
</script>
</body>
</html>

以上是使用html5 canvas實(shí)現(xiàn)心電圖移動(dòng)效果的方法的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

本文題目:使用html5canvas實(shí)現(xiàn)心電圖移動(dòng)效果的方法
本文網(wǎng)址:http://jinyejixie.com/article4/ggiiie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)網(wǎng)站營(yíng)銷(xiāo)、網(wǎng)站策劃、企業(yè)建站、微信小程序、關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

營(yíng)銷(xiāo)型網(wǎng)站建設(shè)
仪陇县| 武胜县| 井陉县| 辛集市| 滁州市| 湘西| 大冶市| 云南省| 东兰县| 湟中县| 东兰县| 莱芜市| 龙江县| 陕西省| 顺昌县| 淅川县| 大连市| 资阳市| 鄂伦春自治旗| 乐清市| 台北县| 滨州市| 油尖旺区| 株洲市| 习水县| 北京市| 溧阳市| 六安市| 汕尾市| 榕江县| 昭通市| 黄石市| 宜春市| 太湖县| 五河县| 调兵山市| 上栗县| 宝山区| 嘉义市| 双流县| 北宁市|