html5 Canvas畫圖教程(10)—把面拆成線條模擬出圓角矩形
來源:易賢網 閱讀:1306 次 日期:2016-07-23 13:23:50
溫馨提示:易賢網小編為您整理了“html5 Canvas畫圖教程(10)—把面拆成線條模擬出圓角矩形”,方便廣大網友查閱!

一個正常的圓角矩形,我們先假設他四個角的圓角弧度一致——因為這樣比較好畫。我們動用把面拆成線條的能力,很容易就能發(fā)現圓角矩形其實是由4條鉤子般的曲線組成。

名單

提到鉤子,如果你看過我介紹arcTo的文章,那么可能你一下就明白了這種圖形就可以用arcTo畫出來。

我講arcTo的時候提過,arcTo有個特性就是,他的第2條切線延長也并不會對他畫出的線條造成影響(在上文的最后部分),這也為我們畫圓角矩形提供了方便,不用擔心變形。

下面放出我在國外網站上發(fā)現的canvas畫圓角矩形的方法,應該是效率最高的了。

代碼如下:

//圓角矩形

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;

}

此函數的參數,依次是x坐標,y坐標,寬度,高度,圓角半徑。特別要注意最后這個參數——圓角半徑。

此方法用了4次arcTo畫出了一個圓角矩形,他的每個角的弧度都是一樣的。此圓角矩形的坐標點也是和矩形一樣的左上角,但他的起筆點可不是這里,而是:

名單

你可以去掉其中的某條線,看看此方法的原理。

當然,提醒一下,不論畫什么圖形,都要記得閉合路徑——closePath,避免留下隱患。

這個方法最后有個return this,是為了讓你能使用鏈式語法,如:

ctx.roundRect(200,300,200,120,20).stroke();你不需要的話也可以去掉他。

如果你并不想擴充ContextRenderingContext2D原型,你也可以把這個方法另外做一個函數。

當時發(fā)現這個函數的時候,我連arcTo是什么都不知道,所以也沒有記住是在哪個網站上發(fā)現的,反正不是我原創(chuàng)的,在此感謝作者。

在前文中我一直強調這個方法畫出的圓角矩形每個角都是一致的,是因為css3中的border-radius可以很輕松的畫出每個角甚至每個角的鄰邊圓弧不一致的圓角矩形,待我找找canvas中畫不規(guī)則圓角矩形的辦法吧,不過個人覺得挺難的。

更多信息請查看網頁制作

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網