亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

詳解canvas多邊形(蜘蛛圖)的畫法示例

2024-08-26 00:20:23
字體:
來源:轉載
供稿:網友

蜘蛛圖的畫法:

在開始之前,我們需要知道canvas是如何進行圖像的繪制,canvas 元素用于在網頁上繪制圖形。HTML5 的 canvas 元素使用 JavaScript 在網頁上繪制2D圖像。 在矩形區域的畫布上,控制其每一像素,JavaScript 來繪制 2D圖形,逐像素進行渲染??梢酝ㄟ^多種方法使用canvas 元素繪制路徑、矩形、圓形、字符以及添加圖像。

* 注意!??!canvas 標簽本身是不具備繪圖功能,只能使用 JavaScript 在網頁上繪制圖像。

效果圖如下所示:

canvas畫多邊形,canvas,多邊形

1. 初始化js代碼

  //初始化  (function(){    var canvas = document.createElement('canvas');    document.body.appendChild(canvas);    canvas.height = mH;    canvas.width = mW;    mCtx = canvas.getContext('2d');    drawPolygon(mCtx); // 繪制多邊形邊    drawLines(mCtx); //頂點連線    drawText(mCtx); // 繪制文本    drawRegion(mCtx);  // 繪制數據    drawCircle(mCtx);  // 畫數據圓點  })();

上面代碼中,通過一個立即執行函數,進行對所有的設置進行初始化,對于canvas正六邊形的畫法,可參見canvas畫正六邊形

在蜘蛛圖中,我們可以進行拆分一下,通過畫六邊形,直線,圓圈的方式,分別進行完整個體的組件,然后通過方法進行統一調用繪制

如下面所示源代碼:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>蜘蛛圖canvas</title>    <style type="text/css">        canvas{        }    </style></head><body><script type="text/javascript">  var mW = 400;  var mH = 400;  var mData = [['法力', 77],['防御', 72],['生命值', 46],['物理傷害', 50],['回復值', 80],['耐力', 60]];  var mCount = mData.length; //邊數  var mCenter = mW /2; //中心點  var mRadius = mCenter - 100; //半徑(減去的值用于給繪制的文本留空間)  var mAngle = Math.PI * 2 / mCount; //角度  var mCtx = null;  var mColorPolygon = '#B8B8B8'; //多邊形顏色  var mColorLines = '#B8B8B8'; //頂點連線顏色  var mColorText = '#000000';  //初始化  (function(){    var canvas = document.createElement('canvas');    document.body.appendChild(canvas);    canvas.height = mH;    canvas.width = mW;    mCtx = canvas.getContext('2d');    drawPolygon(mCtx);    drawLines(mCtx);    drawText(mCtx);    drawRegion(mCtx);    drawCircle(mCtx);  })();  // 繪制多邊形邊  function drawPolygon(ctx){    ctx.save(); // save the default state    ctx.strokeStyle = mColorPolygon;    var r = mRadius/ mCount; //單位半徑    //畫6個圈    for(var i = 0; i < mCount; i ++){      ctx.beginPath(); //開始路徑      var currR = r * ( i + 1); //當前半徑      //畫6條邊      for(var j = 0; j < mCount; j ++) {        var x = mCenter + currR * Math.cos(mAngle * j);        var y = mCenter + currR * Math.sin(mAngle * j);        console.log('x:' + x, 'y:' + y);        ctx.lineTo(x, y);      }      ctx.closePath();  //閉合路徑      ctx.stroke();    }    ctx.restore(); // restore to the default state  }  //頂點連線  function drawLines(ctx){    ctx.save();    ctx.beginPath();    ctx.strokeStyle = mColorLines;    for(var i = 0; i < mCount; i ++){      var x = mCenter + mRadius * Math.cos(mAngle * i);      var y = mCenter + mRadius * Math.sin(mAngle * i);      ctx.moveTo(mCenter, mCenter);      ctx.lineTo(x, y);    }    ctx.stroke();    ctx.restore();  }  //繪制文本  function drawText(ctx){    ctx.save();    var fontSize = mCenter / 12;    ctx.font = fontSize + 'px Microsoft Yahei';    ctx.fillStyle = mColorText;    for(var i = 0; i < mCount; i ++){      var x = mCenter + mRadius * Math.cos(mAngle * i);      var y = mCenter + mRadius * Math.sin(mAngle * i);      if( mAngle * i >= 0 && mAngle * i <= Math.PI / 2 ){        ctx.fillText(mData[i][0], x, y + fontSize);      }else if(mAngle * i > Math.PI / 2 && mAngle * i <= Math.PI){        ctx.fillText(mData[i][0], x - ctx.measureText(mData[i][0]).width, y + fontSize);      }else if(mAngle * i > Math.PI && mAngle * i <= Math.PI * 3 / 2){        ctx.fillText(mData[i][0], x - ctx.measureText(mData[i][0]).width, y);      }else{        ctx.fillText(mData[i][0], x, y);      }    }    ctx.restore();  }  //繪制數據區域  function drawRegion(ctx){    ctx.save();    ctx.beginPath();    for(var i = 0; i < mCount; i ++){      var x = mCenter + mRadius * Math.cos(mAngle * i) * mData[i][1] / 100;      var y = mCenter + mRadius * Math.sin(mAngle * i) * mData[i][1] / 100;      ctx.lineTo(x, y);    }    ctx.closePath();    ctx.fillStyle = 'rgba(255, 0, 0, 0.5)';    ctx.fill();    ctx.restore();  }  //畫點  function drawCircle(ctx){    ctx.save();    var r = mCenter / 18;    for(var i = 0; i < mCount; i ++){      var x = mCenter + mRadius * Math.cos(mAngle * i) * mData[i][1] / 100;      var y = mCenter + mRadius * Math.sin(mAngle * i) * mData[i][1] / 100;      ctx.beginPath();      ctx.arc(x, y, r, 0, Math.PI * 2);      ctx.fillStyle = 'rgba(255, 0, 0, 0.8)';      ctx.fill();    }    ctx.restore();  }</script></body></html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。

 

注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久久久久av| 欧美日韩成人在线播放| 国产精品91久久| 91精品久久久久久久久不口人| 成人av.网址在线网站| yellow中文字幕久久| 庆余年2免费日韩剧观看大牛| 国产啪精品视频网站| 久久久精品久久久久| 成人午夜高潮视频| 国产午夜精品一区二区三区| 在线视频中文亚洲| 欧美怡红院视频一区二区三区| 国产精品视频精品| 国产精品高潮呻吟久久av野狼| 久久久久久久av| 色综合视频一区中文字幕| 69av成年福利视频| 日韩av在线播放资源| 中文字幕久久久av一区| 国产97人人超碰caoprom| 操日韩av在线电影| 精品久久中文字幕久久av| 成人乱色短篇合集| 中文字幕不卡在线视频极品| 欧美日韩国产成人在线观看| 最近中文字幕2019免费| 久久久久久久久网站| 欧美精品在线观看91| 国产视频观看一区| 91精品国产高清久久久久久91| 成人av番号网| 久久精品国产99国产精品澳门| 精品人伦一区二区三区蜜桃免费| 亚洲成人激情视频| 91超碰caoporn97人人| 国产精品91在线观看| 亚洲黄色www网站| 色综合天天狠天天透天天伊人| 国产91精品久久久| 一区二区三欧美| 正在播放亚洲1区| 亚洲精品自在久久| 欧美黑人国产人伦爽爽爽| 青草青草久热精品视频在线网站| 日韩暖暖在线视频| 日韩精品视频在线| 成人福利在线观看| 九九久久久久久久久激情| 青青青国产精品一区二区| 欧美日韩精品在线观看| 欧美激情一级精品国产| 亚洲福利在线播放| 亚洲欧美一区二区三区在线| 国产亚洲激情在线| 国产精品亚洲网站| 久久av在线播放| 日韩在线中文字幕| 成人欧美一区二区三区在线湿哒哒| 欧美午夜激情视频| 国产69久久精品成人| 国产一区二区三区在线视频| 欧美第一淫aaasss性| 午夜伦理精品一区| 国产精品99久久99久久久二8| 久久香蕉国产线看观看网| 日韩美女视频中文字幕| 国产免费一区二区三区在线能观看| 亚洲国产成人91精品| 精品偷拍一区二区三区在线看| 正在播放国产一区| 国产美女91呻吟求| 国产成人久久精品| 久久综合免费视频影院| 久久精品国产视频| 欧美日韩美女视频| 日韩欧美国产网站| 91九色精品视频| 亚洲最大成人在线| 亚洲精品一区二区在线| 中文字幕日韩免费视频| 亚洲一区二区日本| 日韩成人在线网站| 欧美性猛交xxxx富婆| 亚洲精品国产精品自产a区红杏吧| 欧美激情按摩在线| 性欧美视频videos6一9| 日韩av在线影院| 欧美美女操人视频| 日韩欧美精品免费在线| 91美女福利视频高清| 91麻豆国产精品| 亚洲欧美中文字幕在线一区| 亚洲色图欧美制服丝袜另类第一页| 欧美综合在线观看| 国产精品日韩欧美大师| 国产精品国产亚洲伊人久久| 国产精品丝袜高跟| 久久人人爽亚洲精品天堂| 黑人欧美xxxx| 91精品啪在线观看麻豆免费| 亚洲毛片在线看| 色婷婷久久av| 日本a级片电影一区二区| 国产亚洲美女精品久久久| 久久久女人电视剧免费播放下载| 9.1国产丝袜在线观看| 欧美视频不卡中文| 777午夜精品福利在线观看| 高清在线视频日韩欧美| 日本一区二区不卡| 97久久精品人人澡人人爽缅北| 青青精品视频播放| 欧美精品第一页在线播放| 日韩美女视频免费看| 亚洲精品福利视频| 欧美在线一区二区三区四| 欧美在线国产精品| 一区二区成人av| 亚洲性生活视频| 亚洲自拍av在线| 国产91色在线| 亚洲人成啪啪网站| 色妞色视频一区二区三区四区| 亚洲精品视频久久| 美女扒开尿口让男人操亚洲视频网站| 国产网站欧美日韩免费精品在线观看| 久久全国免费视频| 亚洲男人av电影| 97超级碰在线看视频免费在线看| 亚洲伊人第一页| 欧美日韩爱爱视频| 亚洲午夜未满十八勿入免费观看全集| 久久九九免费视频| 欧洲日本亚洲国产区| 91天堂在线视频| 久久精品亚洲热| 久久中国妇女中文字幕| 国产精品电影久久久久电影网| 久久这里有精品视频| 在线日韩欧美视频| 91情侣偷在线精品国产| 欧美成人午夜激情在线| 日韩精品免费在线视频观看| 91精品国产电影| 国产欧美va欧美va香蕉在| 成人激情电影一区二区| 国产精品自拍小视频| 亚洲精品wwwww| 欧美多人爱爱视频网站| 欧美一乱一性一交一视频| 尤物yw午夜国产精品视频| 中文字幕综合在线| 久久理论片午夜琪琪电影网| 成人福利在线观看| 欧美激情网站在线观看| 日韩精品视频免费在线观看| 欧美日韩国产在线播放| 日韩免费观看av| 91情侣偷在线精品国产| 国模精品视频一区二区三区| 精品视频www| 国产mv免费观看入口亚洲| 91精品啪在线观看麻豆免费|