html5 Canvas畫圖教程(9)—canvas中畫出矩形和圓形_HTML5教程
推薦:HTML5之SVG 2D入門1—SVG(可縮放矢量圖形)概述可縮放矢量圖形(Scalable Vector Graphics,簡稱SVG)是一種使用XML來描述二維圖形的語言(SVG嚴(yán)格遵從XML語法),SVG 功能集包括嵌套轉(zhuǎn)換、剪切路徑、alpha 蒙板和模板對象,感興趣的朋友可以了解下,或許對你的html5 SVG 2D知識增長有所幫助
本文講一下在canvas中畫出矩形和圓形的辦法,他們屬于基礎(chǔ)圖形。當(dāng)然,基礎(chǔ)圖形本來不止他們,但在canvas中,只有畫矩形與圓形不需要用其他方法模擬。canvas畫矩形
1,fillRect與strokeRect
fillRect可以直接填充出一個(gè)矩形,填充樣式是你當(dāng)前設(shè)置的樣式;同理strokeRect就是直接描邊一個(gè)矩形
他們的參數(shù)是一致的,依次是(起點(diǎn)x坐標(biāo),起點(diǎn)y,矩形的寬,矩形的高)。這里的起點(diǎn),注意,是指矩形的左上角那個(gè)點(diǎn)。
我們通常用他們來做簡單的事,他們也只能做簡單的事。為什么?因?yàn)樗麄儺嫷膱D形沒有“路徑”的說法,直接就出來了。
比如你先用fillRect填充了一個(gè)矩形,然后你想把這個(gè)矩形描邊,如果你使用stroke(),則不會(huì)有效果,因?yàn)榇藭r(shí)雖然有個(gè)矩形,但并不存在路徑。
如果你迫切的想把這個(gè)矩形描邊,你可以在同樣的位置使用strokeRect()來描邊一個(gè)矩形——但他們其實(shí)是獨(dú)立的,只是位置重疊罷了。
復(fù)制代碼 代碼如下:www.wf0088.com
ctx.fillRect(200,100,50,40);
ctx.strokeRect(200,100,50,40);
如果我們想要一個(gè)又有填充又有描邊的矩形,那同時(shí)使用fillRect和strokeRect無疑顯得很累贅。所以這種情況我們通常使用以下方法。
2,rect
rect的參數(shù)與fillRect和strokeRect毫無差別,不同的是他畫出的只是路徑,至于描邊或是填充要你后續(xù)自己完成。
復(fù)制代碼 代碼如下:www.wf0088.com
ctx.rect(300,100,50,40);
ctx.stroke()
ctx.fill();
這樣做有什么好處呢?前面的文章我提到過,填充或描邊會(huì)消耗大量資源,所以我們經(jīng)常(比如循環(huán))需要一次性繪制幾百條路徑,再來描邊或填充。此時(shí)使用rect畫路徑,最后再填充,就避免了fillRect和strokeRec每次都要填充或描邊的問題。
3,lineTo
當(dāng)然你也可以像我的畫線條的教程那樣,用4個(gè)lineTo來畫出一個(gè)矩形。但這毫無必要,具體可查看那篇文章。
Canvas畫圓形
蒼天無眼,其實(shí)canvas并沒有一個(gè)真正的可以直接畫出圓形的函數(shù),他畫的其實(shí)是一個(gè)360度的圓弧,看起來就是個(gè)圓形了。
canvas畫圓弧的函數(shù)我們前面講過了,即arc.我們用他來畫一個(gè)圓形:
復(fù)制代碼 代碼如下:www.wf0088.com
ctx.arc(300+25,100+20,20,0,Math.PI*2);
ctx.stroke()
ctx.fill();
這個(gè)arc和rect一樣,畫出的也是路徑,填充或描邊需要后續(xù)完成。
但要注意的是,圓形的位置判斷和矩形是不一樣的。我們以矩形的左上角為起點(diǎn)確定他的位置,但圓形的位置我們通常用圓心來確定。
如果你想畫一組水平和垂直都居中的矩形與圓形,那你可要記得不要把矩形的起點(diǎn)當(dāng)成了畫圓形的起點(diǎn)——圓形的起點(diǎn)可是圓心哈!
算了,我還是給你一個(gè)現(xiàn)在的公式吧,對齊的圓與矩形,圓心的坐標(biāo)=矩形的坐標(biāo)+矩形的一半寬高。
也就是圓心x=矩形x+矩形寬/2,圓形y=矩形y+矩形高/2。這樣他們就是絕對對齊了的。
雖然arc沒有直接畫圓的方法那么好用——我設(shè)想的直接畫圓的方法只需要3個(gè)參數(shù),即圓心坐標(biāo)即半徑——但arc不止可以畫圓,還可以畫半圓什么的,所以功能更強(qiáng)大,用著也將就了。
既然有圓,那么就應(yīng)該有橢圓,但canvas中連一個(gè)正規(guī)的畫圓的函數(shù)都沒有,更別提橢圓了。所以畫橢圓必須用其他方法模擬,這個(gè)比較復(fù)雜,我留到后面講吧。
分享:HTML5之SVG 2D入門2—圖形繪制(基本形狀)介紹及使用SVG提供了很多的基本形狀,這些元素可以直接使用,這一點(diǎn)比canvas好多了,在這里就不多說了,感興趣的朋友可以了解下,或許本文對你的了解SVG的圖形繪制有所幫助
相關(guān)HTML5教程:
- 只要五步 就可以用HTML5/CSS3快速制作便簽貼特效(圖)
- 網(wǎng)易微博Web App用HTML5開發(fā)的過程介紹
- HTML5 對各個(gè)標(biāo)簽的定義與規(guī)定:body的介紹
- 關(guān)于HTML5的安全問題開發(fā)人員需要牢記的
- 關(guān)于HTML5的22個(gè)初級技巧(圖文教程)
- 開發(fā)人員所需要知道的HTML5性能分析面面觀
- HTML5 Web Database 數(shù)據(jù)庫的SQL語句的使用方法
- HTML5實(shí)踐-圖片設(shè)置成灰度圖
- HTML5安全介紹之內(nèi)容安全策略(CSP)簡介
- HTML5 Web存儲方式的localStorage和sessionStorage進(jìn)行數(shù)據(jù)本地存儲案例應(yīng)用
- Bootstrap 學(xué)習(xí)分享
- input元素的url類型和email類型簡介
HTML5教程Rss訂閱Div+Css教程搜索
HTML5教程推薦
- HTML5之SVG 2D入門12—SVG DOM及DOM操作介紹
- Javascript 高級手勢使用介紹
- HTML5 實(shí)現(xiàn)一個(gè)訪問本地文件的實(shí)例
- 在html5的Canvas上繪制橢圓的幾種方法總結(jié)
- html5 Canvas畫圖教程(9)—canvas中畫出矩形和圓形
- 關(guān)于HTML5的22個(gè)初級技巧(圖文教程)
- 檢測瀏覽器是否支持html5視頻的代碼
- 利用HTML5中Geolocation獲取地理位置調(diào)用Google Map API在Google Map上定位
- HTML5之SVG 2D入門6—視窗坐標(biāo)系與用戶坐標(biāo)系及變換概述
- 一張圖片能隱含千言萬語之隱藏你的程序代碼
- 相關(guān)鏈接:
- 教程說明:
HTML5教程-html5 Canvas畫圖教程(9)—canvas中畫出矩形和圓形。