HTML5 Canvas中使用用路径描画圆弧
程序员文章站
2023-12-04 10:29:28
这篇文章主要介绍了HTML5 Canvas中使用用路径描画圆弧,本文演示了如何在HTML5 Canvas中画一个完整的圆、半圆、圆弧,需要的朋友可以参考下... 15-01-01...
本文翻译自steve fulton & jeff fulton html5 canvas, chapter 2, “advanced path methods, arcs”
在canvas绘图中,“圆弧”既可以是一个整圆,也可以是圆周的一部分。
复制代码
代码如下:context.arc()
context.arc(x, y, radius, startangle, endangle, anticlockwise)
在上述方法描述中,x和y定义圆心,radius定义圆周的半径。startangle和endangle以极坐标值表示。anticlockwise(布尔值)定义圆弧的方向。
比如,如果我们想描画一个以点(100, 100)为圆心,半径为20的圆周,我们可以使用以下代码:
复制代码
代码如下:context.arc(100, 100, 20, (math.pi/180)*0, (math.pi/180)*360, false);
执行效果为:
值得注意的是,在上述代码中,我们需要将起始角度(0)和结束角度(360)通过乘以(math.pi/180)来转换成极坐标弧度。当起始角度为0而结束角度为360时,得到的是一个整圆。
除了整圆,我们也可以描画圆弧片段。下述代码描画了四分之一个圆周:
复制代码
代码如下:context.arc(100, 100, 20, (math.pi/180)*0, (math.pi/180)*90, false);
如果我们想描画除上述圆弧之外的另外四分之三个圆周,我们可以将anticlockwise设置为true:
复制代码
代码如下:context.arc(100, 100, 20, (math.pi/180)*0, (math.pi/180)*90, true);
译注1:在canvas的坐标系中,y轴的方向是向下的。
译注2:使用context.arcto()方法也可以描画圆弧。steve fulton & jeff fulton 的 html5 canvas 原著中对该方法的描述是完全错误的。正确的arcto()总结详见:曲线之arcto。
上一篇: 软文推广活动,如何才能让人印象深刻?