html5 Canvas畫圖教程(10)—把面拆成線條模擬出圓角矩形
發(fā)布時間:2013-01-09 14:54:56 作者:佚名
我要評論

上一篇文章我講了畫矩形和圓形的方法,他們都有原生的canvas繪圖函數(shù)可完成。而本文講的圓角矩形則只有通過其他方法模擬出來,我們動用把面拆成線條的能力,很容易就能發(fā)現(xiàn)圓角矩形其實是由4條鉤子般的曲線組成,感興趣的朋友可以了解下
上一篇文章我講了畫矩形和圓形的方法,他們都有原生的canvas繪圖函數(shù)可完成。而本文講的圓角矩形則只有通過其他方法模擬出來。
一個正常的圓角矩形,我們先假設(shè)他四個角的圓角弧度一致——因為這樣比較好畫。我們動用把面拆成線條的能力,很容易就能發(fā)現(xiàn)圓角矩形其實是由4條鉤子般的曲線組成。
提到鉤子,如果你看過我介紹arcTo的文章,那么可能你一下就明白了這種圖形就可以用arcTo畫出來。
我講arcTo的時候提過,arcTo有個特性就是,他的第2條切線延長也并不會對他畫出的線條造成影響(在上文的最后部分),這也為我們畫圓角矩形提供了方便,不用擔心變形。
下面放出我在國外網(wǎng)站上發(fā)現(xiàn)的canvas畫圓角矩形的方法,應(yīng)該是效率最高的了。
//圓角矩形
CanvasRenderingContext2D.prototype.roundRect = function (x, y, w, h, r) {
if (w < 2 * r) r = w / 2;
if (h < 2 * r) r = h / 2;
this.beginPath();
this.moveTo(x+r, y);
this.arcTo(x+w, y, x+w, y+h, r);
this.arcTo(x+w, y+h, x, y+h, r);
this.arcTo(x, y+h, x, y, r);
this.arcTo(x, y, x+w, y, r);
// this.arcTo(x+r, y);
this.closePath();
return this;
}
此函數(shù)的參數(shù),依次是x坐標,y坐標,寬度,高度,圓角半徑。特別要注意最后這個參數(shù)——圓角半徑。
此方法用了4次arcTo畫出了一個圓角矩形,他的每個角的弧度都是一樣的。此圓角矩形的坐標點也是和矩形一樣的左上角,但他的起筆點可不是這里,而是:
你可以去掉其中的某條線,看看此方法的原理。
當然,提醒一下,不論畫什么圖形,都要記得閉合路徑——closePath,避免留下隱患。
這個方法最后有個return this,是為了讓你能使用鏈式語法,如:
ctx.roundRect(200,300,200,120,20).stroke();你不需要的話也可以去掉他。
如果你并不想擴充ContextRenderingContext2D原型,你也可以把這個方法另外做一個函數(shù)。
當時發(fā)現(xiàn)這個函數(shù)的時候,我連arcTo是什么都不知道,所以也沒有記住是在哪個網(wǎng)站上發(fā)現(xiàn)的,反正不是我原創(chuàng)的,在此感謝作者。
在前文中我一直強調(diào)這個方法畫出的圓角矩形每個角都是一致的,是因為css3中的border-radius可以很輕松的畫出每個角甚至每個角的鄰邊圓弧不一致的圓角矩形,待我找找canvas中畫不規(guī)則圓角矩形的辦法吧,不過個人覺得挺難的。
一個正常的圓角矩形,我們先假設(shè)他四個角的圓角弧度一致——因為這樣比較好畫。我們動用把面拆成線條的能力,很容易就能發(fā)現(xiàn)圓角矩形其實是由4條鉤子般的曲線組成。
提到鉤子,如果你看過我介紹arcTo的文章,那么可能你一下就明白了這種圖形就可以用arcTo畫出來。
我講arcTo的時候提過,arcTo有個特性就是,他的第2條切線延長也并不會對他畫出的線條造成影響(在上文的最后部分),這也為我們畫圓角矩形提供了方便,不用擔心變形。
下面放出我在國外網(wǎng)站上發(fā)現(xiàn)的canvas畫圓角矩形的方法,應(yīng)該是效率最高的了。
復制代碼
代碼如下://圓角矩形
CanvasRenderingContext2D.prototype.roundRect = function (x, y, w, h, r) {
if (w < 2 * r) r = w / 2;
if (h < 2 * r) r = h / 2;
this.beginPath();
this.moveTo(x+r, y);
this.arcTo(x+w, y, x+w, y+h, r);
this.arcTo(x+w, y+h, x, y+h, r);
this.arcTo(x, y+h, x, y, r);
this.arcTo(x, y, x+w, y, r);
// this.arcTo(x+r, y);
this.closePath();
return this;
}
此函數(shù)的參數(shù),依次是x坐標,y坐標,寬度,高度,圓角半徑。特別要注意最后這個參數(shù)——圓角半徑。
此方法用了4次arcTo畫出了一個圓角矩形,他的每個角的弧度都是一樣的。此圓角矩形的坐標點也是和矩形一樣的左上角,但他的起筆點可不是這里,而是:
你可以去掉其中的某條線,看看此方法的原理。
當然,提醒一下,不論畫什么圖形,都要記得閉合路徑——closePath,避免留下隱患。
這個方法最后有個return this,是為了讓你能使用鏈式語法,如:
ctx.roundRect(200,300,200,120,20).stroke();你不需要的話也可以去掉他。
如果你并不想擴充ContextRenderingContext2D原型,你也可以把這個方法另外做一個函數(shù)。
當時發(fā)現(xiàn)這個函數(shù)的時候,我連arcTo是什么都不知道,所以也沒有記住是在哪個網(wǎng)站上發(fā)現(xiàn)的,反正不是我原創(chuàng)的,在此感謝作者。
在前文中我一直強調(diào)這個方法畫出的圓角矩形每個角都是一致的,是因為css3中的border-radius可以很輕松的畫出每個角甚至每個角的鄰邊圓弧不一致的圓角矩形,待我找找canvas中畫不規(guī)則圓角矩形的辦法吧,不過個人覺得挺難的。
相關(guān)文章
HTML5中通過li-canvas輕松實現(xiàn)單圖、多圖、圓角圖繪制,單行文字、多行
這篇文章主要介紹了HTML5中通過li-canvas輕松實現(xiàn)單圖、多圖、圓角圖繪制,單行文字、多行文字等,需要的朋友可以參考下2018-11-30- 這篇文章主要介紹了詳解html2canvas截圖不能截取圓角圖片的解決方案的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-01-30
使用HTML5 Canvas繪制圓角矩形及相關(guān)的一些應(yīng)用舉例
這篇文章主要介紹了使用HTML5 Canvas繪制圓角矩形及相關(guān)的一些應(yīng)用舉例,作者舉了2048小游戲和微信對話框兩個實用的例子來作為操作Canvas API的實用練習推薦,需要的朋友可以2016-03-22- HTML5 Canvas繪制對象中提供的原生功能沒有實現(xiàn)繪制圓角矩形與虛線的功能,通過JavaScript的Object.prototype可以實現(xiàn)對對象CanvasRenderingContext2D添加這兩個函數(shù)功能,2013-08-02
- 這篇文章主要介紹了canvas繪制圓角頭像的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學2019-01-17