濮阳杆衣贸易有限公司

主頁 > 知識庫 > html5 Canvas畫圖教程(9)—canvas中畫出矩形和圓形

html5 Canvas畫圖教程(9)—canvas中畫出矩形和圓形

熱門標簽:江蘇高頻外呼系統(tǒng)線路 會聲會影怎樣做地圖標注效果 電銷機器人視頻 地圖標注自己去過的地方 標準智能外呼系統(tǒng) 搜狗星級酒店地圖標注 洛陽市伊川縣地圖標注中心官網(wǎng) 平頂山電子地圖標注怎么修改 高德地圖標注錯誤怎么修改
本文講一下在canvas中畫出矩形和圓形的辦法,他們屬于基礎(chǔ)圖形。當(dāng)然,基礎(chǔ)圖形本來不止他們,但在canvas中,只有畫矩形與圓形不需要用其他方法模擬。

canvas畫矩形
1,fillRect與strokeRect
fillRect可以直接填充出一個矩形,填充樣式是你當(dāng)前設(shè)置的樣式;同理strokeRect就是直接描邊一個矩形
他們的參數(shù)是一致的,依次是(起點x坐標,起點y,矩形的寬,矩形的高)。這里的起點,注意,是指矩形的左上角那個點。
我們通常用他們來做簡單的事,他們也只能做簡單的事。為什么?因為他們畫的圖形沒有“路徑”的說法,直接就出來了。
比如你先用fillRect填充了一個矩形,然后你想把這個矩形描邊,如果你使用stroke(),則不會有效果,因為此時雖然有個矩形,但并不存在路徑。
如果你迫切的想把這個矩形描邊,你可以在同樣的位置使用strokeRect()來描邊一個矩形——但他們其實是獨立的,只是位置重疊罷了。

復(fù)制代碼
代碼如下:

ctx.fillRect(200,100,50,40);
ctx.strokeRect(200,100,50,40);

如果我們想要一個又有填充又有描邊的矩形,那同時使用fillRect和strokeRect無疑顯得很累贅。所以這種情況我們通常使用以下方法。

2,rect
rect的參數(shù)與fillRect和strokeRect毫無差別,不同的是他畫出的只是路徑,至于描邊或是填充要你后續(xù)自己完成。

復(fù)制代碼
代碼如下:

ctx.rect(300,100,50,40);
ctx.stroke()
ctx.fill();

這樣做有什么好處呢?前面的文章我提到過,填充或描邊會消耗大量資源,所以我們經(jīng)常(比如循環(huán))需要一次性繪制幾百條路徑,再來描邊或填充。此時使用rect畫路徑,最后再填充,就避免了fillRect和strokeRec每次都要填充或描邊的問題。

3,lineTo
當(dāng)然你也可以像我的畫線條的教程那樣,用4個lineTo來畫出一個矩形。但這毫無必要,具體可查看那篇文章。

Canvas畫圓形
蒼天無眼,其實canvas并沒有一個真正的可以直接畫出圓形的函數(shù),他畫的其實是一個360度的圓弧,看起來就是個圓形了。
canvas畫圓弧的函數(shù)我們前面講過了,即arc.我們用他來畫一個圓形:

復(fù)制代碼
代碼如下:

ctx.arc(300+25,100+20,20,0,Math.PI*2);
ctx.stroke()
ctx.fill();

這個arc和rect一樣,畫出的也是路徑,填充或描邊需要后續(xù)完成。
但要注意的是,圓形的位置判斷和矩形是不一樣的。我們以矩形的左上角為起點確定他的位置,但圓形的位置我們通常用圓心來確定。
如果你想畫一組水平和垂直都居中的矩形與圓形,那你可要記得不要把矩形的起點當(dāng)成了畫圓形的起點——圓形的起點可是圓心哈!
 
算了,我還是給你一個現(xiàn)在的公式吧,對齊的圓與矩形,圓心的坐標=矩形的坐標+矩形的一半寬高。
也就是圓心x=矩形x+矩形寬/2,圓形y=矩形y+矩形高/2。這樣他們就是絕對對齊了的。
雖然arc沒有直接畫圓的方法那么好用——我設(shè)想的直接畫圓的方法只需要3個參數(shù),即圓心坐標即半徑——但arc不止可以畫圓,還可以畫半圓什么的,所以功能更強大,用著也將就了。
既然有圓,那么就應(yīng)該有橢圓,但canvas中連一個正規(guī)的畫圓的函數(shù)都沒有,更別提橢圓了。所以畫橢圓必須用其他方法模擬,這個比較復(fù)雜,我留到后面講吧。

標簽:廣東 常德 廣西 松原 果洛 阿克蘇 蚌埠 鄂爾多斯

巨人網(wǎng)絡(luò)通訊聲明:本文標題《html5 Canvas畫圖教程(9)—canvas中畫出矩形和圓形》,本文關(guān)鍵詞  html5,Canvas,畫圖,教程,canvas,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《html5 Canvas畫圖教程(9)—canvas中畫出矩形和圓形》相關(guān)的同類信息!
  • 本頁收集關(guān)于html5 Canvas畫圖教程(9)—canvas中畫出矩形和圓形的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    崇仁县| 土默特右旗| 雅安市| 鞍山市| 平利县| 北票市| 房山区| 顺平县| 松潘县| 琼海市| 平度市| 长泰县| 临泉县| 乐陵市| 屯门区| 龙口市| 雅江县| 繁昌县| 明溪县| 荥阳市| 桓台县| 额济纳旗| 海南省| 衡阳市| 古浪县| 任丘市| 绍兴县| 饶阳县| 定日县| 澄江县| 龙南县| 蓬莱市| 凤台县| 嘉义县| 枞阳县| 汕尾市| 密山市| 洛隆县| 株洲县| 佛教| 巴彦淖尔市|