国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

JavaScript實(shí)現(xiàn)像雪花一樣的Hexaflake分形

瀏覽:98日期:2023-10-22 09:38:55

編寫(xiě)如下的函數(shù):

function drawHexagon(x,y,L) { ctx.beginPath(); ctx.moveTo(x-sqrt3/2*L,y-L/2); ctx.lineTo(x-sqrt3/2*L,y+L/2); ctx.lineTo(x,y+L); ctx.lineTo(x+sqrt3/2*L,y+L/2); ctx.lineTo(x+sqrt3/2*L,y-L/2); ctx.lineTo(x,y-L); ctx.closePath(); ctx.fillStyle = '#00FFFF'; ctx.fill(); }

函數(shù)中sqrt3的值為Math.sqrt(3)。該函數(shù)的功能是:以坐標(biāo)(x,y)為中心點(diǎn),繪制一個(gè)邊長(zhǎng)為L(zhǎng)的正六邊形并進(jìn)行填充,如下圖所示。

JavaScript實(shí)現(xiàn)像雪花一樣的Hexaflake分形

編寫(xiě)如下的調(diào)用語(yǔ)句:

var x=250; var y=250; var L=200; drawHexagon(x,y-2*L/3,L/3); drawHexagon(x,y,L/3); drawHexagon(x,y+2*L/3,L/3); drawHexagon(x-sqrt3/3*L,y+L/3,L/3); drawHexagon(x-sqrt3/3*L,y-L/3,L/3); drawHexagon(x+sqrt3/3*L,y+L/3,L/3); drawHexagon(x+sqrt3/3*L,y-L/3,L/3);

可以繪制出如下圖所示的7個(gè)小正六邊形,這7個(gè)小正六邊形正好填充在以(x,y)為中心邊長(zhǎng)為L(zhǎng)的大正六邊形中。

JavaScript實(shí)現(xiàn)像雪花一樣的Hexaflake分形

Hexaflake分形圖案的構(gòu)造過(guò)程是:以(x,y)為中心點(diǎn)繪制一個(gè)邊長(zhǎng)為L(zhǎng)的正六邊形并進(jìn)行顏色填充;在這個(gè)正六邊形中找到7個(gè)點(diǎn),以這7個(gè)點(diǎn)為中心分別繪制7個(gè)邊長(zhǎng)為L(zhǎng)/3的正六邊形并進(jìn)行顏色填充,替換掉原來(lái)邊長(zhǎng)為L(zhǎng)的正六邊形;重復(fù)以上操作直至達(dá)到要求的層數(shù),可以繪制出Hexaflake分形圖案,如下圖所示。

JavaScript實(shí)現(xiàn)像雪花一樣的Hexaflake分形

Hexaflake分形采用遞歸過(guò)程易于實(shí)現(xiàn),編寫(xiě)如下的HTML代碼。

<!DOCTYPE html><head><title>Hexaflake分形</title></head><body><canvas style='border:3px double #996633;'></canvas><script type='text/javascript'> var canvas = document.getElementById(’myCanvas’); var ctx = canvas.getContext(’2d’); var maxdepth =4; var sqrt3=Math.sqrt(3); function drawHexagon(x,y,L) { ctx.beginPath(); ctx.moveTo(x-sqrt3/2*L,y-L/2); ctx.lineTo(x-sqrt3/2*L,y+L/2); ctx.lineTo(x,y+L); ctx.lineTo(x+sqrt3/2*L,y+L/2); ctx.lineTo(x+sqrt3/2*L,y-L/2); ctx.lineTo(x,y-L); ctx.closePath(); ctx.fillStyle = '#00FFFF'; ctx.fill(); } function drawHexaflake(n,x,y,L) { if(n>0) { drawHexaflake(n-1,x,y-2*L/3,L/3); drawHexaflake(n-1,x,y,L/3); drawHexaflake(n-1,x,y+2*L/3,L/3); drawHexaflake(n-1,x-sqrt3/3*L,y+L/3,L/3); drawHexaflake(n-1,x-sqrt3/3*L,y-L/3,L/3); drawHexaflake(n-1,x+sqrt3/3*L,y+L/3,L/3); drawHexaflake(n-1,x+sqrt3/3*L,y-L/3,L/3); } else drawHexagon(x,y,L); } drawHexaflake(maxdepth,250,250,200);</script></body></html>

在瀏覽器中打開(kāi)包含這段HTML代碼的html文件,可以看到在瀏覽器窗口中繪制出的Hexaflake分形圖案,如下圖所示。

JavaScript實(shí)現(xiàn)像雪花一樣的Hexaflake分形

執(zhí)行語(yǔ)句:

ctx.fillStyle='black';ctx.fillRect(0,0,500,500);

將屏幕背景設(shè)置為黑色,將繪制的正六邊形用白色填充,則在瀏覽器窗口中繪制出的Hexaflake分形圖案像雪花兒一樣,如下圖所示。

JavaScript實(shí)現(xiàn)像雪花一樣的Hexaflake分形

將Hexaflake分形的生成過(guò)程進(jìn)行動(dòng)態(tài)展示,編寫(xiě)如下的HTML文件。

<!DOCTYPE html><head><title>Hexaflake分形</title></head><body><canvas style='border:3px double #996633;'></canvas><script type='text/javascript'> var canvas = document.getElementById(’myCanvas’); var ctx = canvas.getContext(’2d’); var depth =0; var sqrt3=Math.sqrt(3); function drawHexagon(x,y,L) { ctx.beginPath(); ctx.moveTo(x-sqrt3/2*L,y-L/2); ctx.lineTo(x-sqrt3/2*L,y+L/2); ctx.lineTo(x,y+L); ctx.lineTo(x+sqrt3/2*L,y+L/2); ctx.lineTo(x+sqrt3/2*L,y-L/2); ctx.lineTo(x,y-L); ctx.closePath(); ctx.fillStyle = '#FFFFFF'; ctx.fill(); } function drawHexaflake(n,x,y,L) { if(n>0) { drawHexaflake(n-1,x,y-2*L/3,L/3); drawHexaflake(n-1,x,y,L/3); drawHexaflake(n-1,x,y+2*L/3,L/3); drawHexaflake(n-1,x-sqrt3/3*L,y+L/3,L/3); drawHexaflake(n-1,x-sqrt3/3*L,y-L/3,L/3); drawHexaflake(n-1,x+sqrt3/3*L,y+L/3,L/3); drawHexaflake(n-1,x+sqrt3/3*L,y-L/3,L/3); } else drawHexagon(x,y,L); } function go() { ctx.fillStyle = '#000000'; ctx.fillRect(0,0,500,500); drawHexaflake(depth,250,250,200); depth++; if (depth>4) { depth=0; } } window.setInterval(’go()’,1500);</script></body></html>

在瀏覽器中打開(kāi)包含這段HTML代碼的html文件,在瀏覽器窗口中呈現(xiàn)出如下圖所示的Hexaflake分形動(dòng)態(tài)生成效果。

JavaScript實(shí)現(xiàn)像雪花一樣的Hexaflake分形

以上就是JavaScript實(shí)現(xiàn)像雪花一樣的Hexaflake分形的詳細(xì)內(nèi)容,更多關(guān)于JavaScript Hexaflake分形的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 国产亚洲高清不卡在线观看 | 成人国产免费 | 精品国产免费观看 | 国产性自拍 | 色精品一区二区三区 | 黄www片 | 黄色不卡视频 | 亚洲精品一区二区三区在线看 | 97成人在线 | 国产成人盗摄精品 | 午夜精品视频在线观看美女 | 久久精品久久精品久久 | 日本aaaa片毛片免费观看 | 成人在线第一页 | 一本久久综合 | 日日干日日操日日射 | 欧美国产精品亚洲精品第一区 | 91九色国产 | 视频一区在线 | 欧美一区三区 | 中文字幕波多野不卡一区 | 久久久久香蕉视频 | 在线看亚洲 | 色综合久久88色综合天天提莫 | a级午夜毛片免费一区二区 a级性生活视频 | 美女黄影院| 91久久亚洲精品国产一区二区 | 韩国一级毛片大全女教师 | 久久精品国产一区 | 香港经典a毛片免费观看爽爽影院 | 国产成人久久久精品一区二区三区 | 欧美毛片在线观看 | 国产三级理论 | 久久久一本精品99久久精品66 | 中国内地毛片免费高清 | 国产亚洲自在精品久久 | 亚洲自偷自偷图片在线高清 | 黄色国产免费观看 | 国产在线视频一区二区三区 | 狠狠色丁香婷婷久久综合不卡 | 搞黄网站在线观看 |