JavaScript?Canvas繪制六邊形網(wǎng)格
更新時間:2022年01月17日 07:54:10 作者:vectoru
這篇文章主要為大家詳細介紹了JavaScript?Canvas繪制六邊形網(wǎng)格,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了JavaScript Canvas繪制六邊形網(wǎng)格的具體代碼,供大家參考,具體內(nèi)容如下
使用Canvas繪制六邊形網(wǎng)格。
主要思路是先畫給定中心點的六邊形,然后二重循環(huán)遍歷所有中心點,畫所有的六邊形。
<!DOCTYPE HTML> <html> <body> <canvas id="myCanvas" width="300" height="150"> ? ? <p>你的瀏覽器不支持Canvas</p> </canvas> <br> <p id='p1'></p> <script type="text/javascript"> "use strict"; var canvas=document.getElementById('myCanvas'); if (canvas.getContext) { ? ? var k=3; ? ? var d=30; ? ? var w=Math.sqrt(3)*d; ? ? var h=3/2*d; ? ? canvas.width=2*k*w; ? ? canvas.height=2*k*h+h/2; ? ? var o=[canvas.width/2,canvas.height/2]; ? ? document.getElementById('p1').innerHTML='畫布寬'+canvas.width+',高'+canvas.height; ? ? var ctx=canvas.getContext('2d'); ? ? ctx.fillStyle='AntiqueWhite'; ? ? ctx.fillRect(0,0,canvas.width,canvas.height); ? ? ctx.strokeStyle='blue'; ? ? ctx.beginPath(); ? ? var vs=[[0,d],[-w/2,d/2],[-w/2,-d/2], ? ? ? ? ? ? [0,-d],[w/2,-d/2],[w/2,d/2]]; ? ? function one(xo,yo){ ? ? ? ? ctx.moveTo(xo+vs[5][0],yo+vs[5][1]); ? ? ? ? for(var i=0;i<vs.length;i++){ ? ? ? ? ? ? ctx.lineTo(xo+vs[i][0],yo+vs[i][1]); ? ? ? ? } ? ? } ? ? for(var i=-k+1;i<k;i++){ ? ? ? ? for(var j=0;j<2*k-1-Math.abs(i);j++){ ? ? ? ? ? ? one(o[0]+(-k+1+Math.abs(i)/2+j)*w,o[1]+h*i); ? ? ? ? } ? ? } ? ? ctx.stroke(); } else{ ? ? console.log('你的瀏覽器不支持Canvas'); } </script> </body> </html>
效果如下:
更新:增加了一些選項,邊長和顏色可以設置。網(wǎng)頁的圖標也用六邊形畫出。
<!DOCTYPE HTML> <html> <head> <title>六邊形網(wǎng)格</title> <link id="link" rel="shortcut icon" type="image/x-icon"> <style> #bc1,#bc2{width:25px;} #bj,#xt,#tc{width:20px;} </style> </head> <body> <p>設置大六邊形邊長: <input id='bc1' value="3" onchange="generate()"> 小六邊形<br> 設置小六邊形邊長: <input id='bc2' value="24" onchange="generate()"> 像素(px)<br> 設置背景色 <input type="color" id="bj" value="#c8ffff" onchange="generate()"/> 設置線條色 <input type="color" id="xt" value="#0000ff" onchange="generate()"/> 設置填充色 <input type="color" id="tc" value="#faebd7" onchange="generate()"/></p> <p id='p1'></p> <canvas id="myCanvas" width="300" height="150"> <p>你的瀏覽器不支持Canvas</p> </canvas> <script type="text/javascript"> "use strict"; document.getElementById('bc1').value=2; generate(); link.href=myCanvas.toDataURL({format:'image/png', quality:1}); document.getElementById('bc1').value=3; generate(); function generate(){ ? ? var bc1=document.getElementById('bc1').value; ? ? var bc2=document.getElementById('bc2').value; ? ? var k=Number(bc1); ? ? var d=Number(bc2); ? ? var bj=document.getElementById('bj').value; ? ? var xt=document.getElementById('xt').value; ? ? var tc=document.getElementById('tc').value; ? ? var canvas=document.getElementById('myCanvas'); ? ? if(bc1>200){ ? ? ? ? var c=confirm('六邊形個數(shù)過多時網(wǎng)頁會卡,是否繼續(xù)?'); ? ? ? ? if(!c){ ? ? ? ? ? ? return; ? ? ? ? } ? ? } ? ? if(canvas.getContext) { ? ? ? ? var w=Math.sqrt(3)*d; ? ? ? ? var h=3/2*d; ? ? ? ? var count=3*k*k-3*k+1; ? ? ? ? canvas.width=2*k*w; ? ? ? ? canvas.height=2*k*h+h/2; ? ? ? ? var o=[canvas.width/2,canvas.height/2]; ? ? ? ? document.getElementById('p1').innerHTML='畫布寬'+canvas.width+'px,高'+canvas.height+'px,含有'+count+'個小六邊形'; ? ? ? ? var ctx=canvas.getContext('2d'); ? ? ? ? ctx.fillStyle=bj; ? ? ? ? ctx.fillRect(0,0,canvas.width,canvas.height); ? ? ? ? ctx.beginPath(); ? ? ? ? var vs=[[0,d],[-w/2,d/2],[-w/2,-d/2],[0,-d],[w/2,-d/2],[w/2,d/2]]; ? ? ? ? function one(xo,yo){ ? ? ? ? ? ? ctx.beginPath(); ? ? ? ? ? ? ctx.moveTo(xo+vs[5][0],yo+vs[5][1]); ? ? ? ? ? ? for(var i=0;i<vs.length;i++){ ? ? ? ? ? ? ? ? ctx.lineTo(xo+vs[i][0],yo+vs[i][1]); ? ? ? ? ? ? } ? ? ? ? ? ? ctx.strokeStyle=xt; ? ? ? ? ? ? ctx.lineWidth=2; ? ? ? ? ? ? ctx.stroke(); ? ? ? ? ? ? ctx.fillStyle=tc; ? ? ? ? ? ? ctx.fill(); ? ? ? ? } ? ? ? ? for(var i=-k+1;i<k;i++){ ? ? ? ? ? ? for(var j=0;j<2*k-1-Math.abs(i);j++){ ? ? ? ? ? ? ? ? one(o[0]+(-k+1+Math.abs(i)/2+j)*w,o[1]+h*i); ? ? ? ? ? ? } ? ? ? ? } ? ? } ? ? else{ ? ? ? ? console.log('你的瀏覽器不支持Canvas'); ? ? } } </script> </body> </html>
效果如下:
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
為什么JavaScript中0.1 + 0.2 != 0.3
這篇文章主要給大家介紹了關于為什么JavaScript中0.1 + 0.2 != 0.3的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-12-12如何通過遞歸方法實現(xiàn)用json-diff渲染json字符串對比結(jié)果
JsonDiff是一個高性能json差異發(fā)現(xiàn)工具,它幾乎可以發(fā)現(xiàn)任何JSON結(jié)構(gòu)的差異,并且將錯誤信息反饋給用戶,下面這篇文章主要給大家介紹了關于如何通過遞歸方法實現(xiàn)用json-diff渲染json字符串對比結(jié)果的相關資料,需要的朋友可以參考下2022-12-12十個優(yōu)秀的Ajax/Javascript實例網(wǎng)站收集
今天,要向大家推薦10個相當棒的Ajax和Javascript國外資源網(wǎng)站或博客,它們提供了相當多的高質(zhì)量Ajax、Javascript實例及教程,喜歡Ajax和Javascript的朋友絕對不能錯過。2010-03-03