亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

JavaScript多種圖形實現代碼實例

瀏覽:74日期:2023-10-23 10:55:18

1.小星星

設有如下的曲線參數方程:

N=5

x = r*sin(nθ)*cos(θ)

y = r*sin(nθ)*sin(θ) (0≤θ≤2π)

用循環依次取θ值為0~2π(每次增量為π/64),計算出X和Y,在canvas畫布中將坐標點(X,Y)用線連起來,可繪制出一個一個5瓣花卉圖案。

編寫如下的HTML代碼。

<!DOCTYPE html><head><title>小星星</title><script type='text/javascript'> function draw(id) { var canvas=document.getElementById(id); if (canvas==null) return false; var context=canvas.getContext(’2d’); context.fillStyle='#EEEEFF'; context.fillRect(0,0,400,300); context.strokeStyle='blue'; context.lineWidth=2; context.beginPath(); var r=120; // 下面可進行修改的語句 (3) var n=5; // 下面可進行修改的語句 (3) for (theta=0;theta<=2*Math.PI;theta+=Math.PI/64) { b=r*Math.sin(n*theta); // 下面可進行修改的語句 (3) x=200+b*Math.cos(theta); y=150+b*Math.sin(theta); if (theta==0) context.moveTo(x,y); else context.lineTo(x,y); } context.stroke(); }</script></head><body onload='draw(’myCanvas’);'><canvas height='300'></canvas></body></html>

將上述HTML代碼保存到一個html文本文件中,再在瀏覽器中打開包含這段HTML代碼的html文件,可以看到在瀏覽器窗口中繪制出如圖1所示的5瓣花卉圖案。

JavaScript多種圖形實現代碼實例

圖1 5瓣花卉圖案1

我們將上面程序中標識的語句1“var r=120;”修改為“var r=50;”,適當減小初始半徑,使得繪制的圖案不會超出畫布的范圍,在將標識的語句3“b=r*Math.sin(n*theta);”修改為“b=r*(1+Math.sin(n*theta)/2);”,則在畫布中繪制出如圖2所示的5瓣花卉圖案。

JavaScript多種圖形實現代碼實例

圖2 5瓣花卉圖案2

這個圖案比圖1中的圖案的感覺是中間向外擴展了,使得中心部位出現空白。再次修改語句3為“b=r*(2+Math.sin(n*theta)/2);”,以增大中間部分的空白,則在畫布中繪制出如圖3所示的圖案,像小星星嗎?

JavaScript多種圖形實現代碼實例

圖3 小星星圖案

上面程序中的n值也可修改,例如在上面繪制小星星圖案的程序中,將標識語句2

“var n=5;”修改為“var n=6;”,則在畫布中繪制出如圖4所示的圖案。像六角雪花圖案嗎?

JavaScript多種圖形實現代碼實例

圖4 六角雪花圖案

我們這樣想一想,若將n的值修改為一個實數(有小數部分)會這樣呢?例如,將

“var n=5;”修改為“n=5.05;”,則在畫布中繪制出如圖5所示的圖案。

JavaScript多種圖形實現代碼實例

圖5 未封閉的小星星圖案線

2.環帶

由圖5知,θ值取0~2π時,正好繪制一圈,由于n取非整數時,曲線不封閉,因此,若取θ值為0~10π,繪制5圈,可得到一個環帶圖案。為讀者引用和下面講述方便,給出完整HTML文件內容如下。

<!DOCTYPE html><head><title>環帶</title><script type='text/javascript'> function draw(id) { var canvas=document.getElementById(id); if (canvas==null) return false; var context=canvas.getContext(’2d’); context.fillStyle='#EEEEFF'; context.fillRect(0,0,400,300); context.strokeStyle='red'; context.lineWidth=2; context.beginPath(); var n=5.05; k=10; for (theta=0;theta<=k*Math.PI;theta+=Math.PI/120) { var r=110*(1+Math.cos(n*theta)/5); var x =200+ r*Math.cos(theta); var y =150+ r*Math.sin(theta); if (theta==0) context.moveTo(x,y); else context.lineTo(x,y); } context.stroke(); }</script></head><body onload='draw(’myCanvas’);'><canvas height='300'></canvas></body></html>

在瀏覽器中打開包含這段HTML代碼的html文件,可以看到在畫布中繪制的五角環帶,如圖6所示。

JavaScript多種圖形實現代碼實例

圖6 五角環帶

將上面程序中的n值由“n=5.05”修改為“n=9.05”,則在畫布中繪制出如圖7所示的環帶。

JavaScript多種圖形實現代碼實例

圖7 九角環帶

若將上面程序中的n值修改為9.2,且將k值修改為12,則在畫布中繪制出如圖8所示的圓環帶。

JavaScript多種圖形實現代碼實例

圖8 n值為9.2時的圓環

若將上面程序中的n值修改為5.5,且將k值修改為12,則在畫布中繪制出如圖9所示的圓環。

JavaScript多種圖形實現代碼實例

圖9 n值為5.5時的圓環

在繪制圖9的程序中,再將語句“var r=110*(1+Math.cos(n*theta)/5);”修改為

“var r=90*(1+Math.cos(n*theta)/2);”則在畫布中繪制出如圖10所示的圖案。

JavaScript多種圖形實現代碼實例

圖10 n值為5.5時的另一環狀圖案

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 污视频免费网站 | 国产高清不卡一区二区三区 | 成人黄色网址 | 国产国语在线播放视频 | 1024.1024亚洲 国产 图片 1024cao社区榴地址一地址二 | 日本中文字幕不卡在线一区二区 | 国产日韩精品视频一区二区三区 | 色综久久天天综合绕视看 | 劲爆激情欧美毛片 | 亚洲一区二区约美女探花 | 国产综合视频在线观看一区 | 亚洲乱码中文字幕综合 | 国产精品视频网站你懂得 | 涩涩国产精品福利在线观看 | 色爱综合区 | 国产a久久精品一区二区三区 | 成人午夜影视全部免费看 | aaaaaa毛片免费看 | 福利视频91 | 中国wwwxxx| 国产主播大尺度精品福利 | 久久久男女野外野战 | 一本一道久久综合狠狠老 | 白白操在线视频 | 福利午夜在线 | 欧美三级真做在线观看 | 成人免费观看视频久爱网 | 免费永久在线观看黄网 | 国产精品亚洲精品影院 | 五月婷婷色综合 | 涩五月婷婷 | 久久免费视频播放 | 爽爽爽爽爽爽a成人免费视频 | 国产精品日本不卡一区二区 | 国产成人综合亚洲 | 精品国内一区二区三区免费视频 | 久久久久网站 | 国产一区二区三区不卡观 | aaa黑人一级毛片 | 嫩草视频在线观看www视频 | 成人黄网18免费观看的网站 |