国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

html5 canvas里繪制橢圓并保持線條粗細(xì)均勻的技巧

2024-08-26 00:16:03
字體:
供稿:網(wǎng)友

點(diǎn)評(píng):Canvas里繪制橢圓是一個(gè)很常見的需求,但是目前大多數(shù)瀏覽器還沒有實(shí)現(xiàn)該方法,因此經(jīng)常會(huì)使用arc或者arcTo方法結(jié)合scale變形來繪制橢圓,感興趣的朋友可以了解下,希望可以幫助到你們

Canvas里繪制橢圓是一個(gè)很常見的需求,比較新的HTML Canvas 2D Context W3C草案里面新增了ellipse方法繪制橢圓,但是目前大多數(shù)瀏覽器還沒有實(shí)現(xiàn)該方法,所以需要用arc或者arcTo方法結(jié)合scale變形來繪制橢圓。

示例代碼:

復(fù)制代碼

代碼如下:


<canvas></canvas>
<script>
var ctx = documentquerySelector('canvas')getContext('2d');
ctxlineWidth = "10";
ctxscale(1,2);
ctxarc(150,150,100,0,MathPI*2,false);
ctxstroke();
</script>


有點(diǎn)不對(duì),因?yàn)榫€條粗細(xì)不均勻了,stroke也被scale影響了。

要修正這個(gè)問題,就要一點(diǎn)點(diǎn)小技巧了。

示例代碼:

復(fù)制代碼

代碼如下:


[code]
<canvas></canvas>
<script>
var ctx = documentquerySelector('canvas')getContext('2d');
ctxlineWidth = "10";
ctxsave();
ctxscale(1,2);
ctxarc(150,150,100,0,MathPI*2,false);
ctxrestore();
ctxstroke();
</script>


[/code]


現(xiàn)在均勻了,非常完美。

技巧就在先save保存畫布狀態(tài),然后縮放、調(diào)用路徑指令,再restore恢復(fù)畫布狀態(tài),再stroke繪制出來。

關(guān)鍵點(diǎn)是先save后縮放,先restore后stroke.


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 德庆县| 建德市| 伊宁市| 永兴县| 鄂州市| 定陶县| 安溪县| 横峰县| 黔西县| 庆元县| 驻马店市| 文山县| 尼勒克县| 隆德县| 永德县| 涡阳县| 武乡县| 博湖县| 洪雅县| 遂昌县| 丽江市| 怀来县| 阜南县| 嵩明县| 鄂托克前旗| 牟定县| 德化县| 静安区| 怀宁县| 商河县| 鄂伦春自治旗| 长武县| 成武县| 平武县| 迭部县| 大悟县| 浦北县| 八宿县| 阳朔县| 徐州市| 同江市|