茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    html5 Canvas畫圖教程(10)—把面拆成線條模擬出圓角矩形
    來源:易賢網 閱讀:1584 次 日期: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 &lt; 2 * r) r = w / 2;

    if (h &lt; 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ī)則圓角矩形的辦法吧,不過個人覺得挺難的。

    更多信息請查看網頁制作

    2026上岸·考公考編培訓報班

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