国产探花免费观看_亚洲丰满少妇自慰呻吟_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ā)表
主站蜘蛛池模板: 甘南县| 保山市| 德惠市| 赤峰市| 丰原市| 屏东市| 噶尔县| 景德镇市| 宁远县| 于都县| 青铜峡市| 永靖县| 平谷区| 曲阜市| 西乌| 昌宁县| 南通市| 兰溪市| 沈阳市| 永清县| 太白县| 金门县| 哈尔滨市| 平舆县| 平罗县| 庐江县| 渭南市| 南汇区| 房产| 方城县| 邻水| 吉木乃县| 卫辉市| 英德市| 鄢陵县| 淮北市| 华容县| 门源| 安平县| 手游| 邵阳县|