canvas arcTo()用法详解

今天,我们接着介绍CanvasRenderingContext2D对象的方法arcTo()的用法。

arcTo(x1, y1, x2, y2, radius)

arcTo()方法将利用当前端点、端点1(x1,y1)和端点2(x2,y2)这三个点所形成的夹角,然后绘制一段与夹角的两边相切并且半径为radius的圆上的弧线。弧线的起点就是当前端点所在边与圆的切点,弧线的终点就是端点2(x2,y2)所在边与圆的切点,并且绘制的弧线是两个切点之间长度最短的那个圆弧。此外,如果当前端点不是弧线起点,arcTo()方法还将添加一条当前端点到弧线起点的直线线段。

上述字面解释可能不易理解,我们最好结合实际的代码示例来帮助理解,请先参考下面的代码:

 
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>HTML5 Canvas arcTo()绘制弧线入门示例</title>
  6. </head>
  7. <body>
  8. <!-- 添加canvas标签,并加上红色边框以便于在页面上查看 -->
  9. <canvas id="myCanvas" width="400px" height="300px" style="border: 1px solid red;">
  10. 您的浏览器不支持canvas标签。
  11. </canvas>
  12. <script type="text/javascript">
  13. //获取Canvas对象(画布)
  14. var canvas = document.getElementById("myCanvas");
  15. //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误
  16. if(canvas.getContext){  
  17.     //获取对应的CanvasRenderingContext2D对象(画笔)
  18.     var ctx = canvas.getContext("2d");  
  19.    
  20.     //指定绘制路径的起始点
  21.     ctx.moveTo(50, 50);
  22.     //绘制一条到坐标(150,50)的水平直线
  23.     ctx.lineTo(150, 50);
  24.    
  25.     //坐标点(150,50)就是绘制弧线时的当前端点
  26.    
  27.     //端点1
  28.     var p1 = {
  29.         x : 200,
  30.         y : 50
  31.     };
  32.     //端点2
  33.     var p2 = {
  34.         x : 200,
  35.         y : 100        
  36.     };
  37.     //绘制与当前端点、端点1、端点2三个点所形成的夹角的两边相切并且半径为50px的圆的一段弧线
  38.     ctx.arcTo(p1.x, p1.y, p2.x, p2.y, 50);
  39.    
  40.     //设置线条颜色为蓝色
  41.     ctx.strokeStyle = "blue";
  42.     //按照上述绘制路径绘制弧线
  43.     ctx.stroke();
  44. }
  45. </script>
  46. </body>
  47. </html>

对应的显示效果如下图(图中的蓝色部分即为实际的绘制效果):运行代码

使用canvas arcTo()绘制的弧线使用canvas arcTo()绘制的弧线

如上图所示,由于在使用arcTo()绘制弧线时,「画笔」所在的端点为(150,50),所以坐标点(150,50)就是当前端点,接着我们在arcTo()方法的参数中指定了端点1(200,50)和端点2(200,100),因此arcTo()将绘制出与这三个端点所形成的夹角的两边相切、并且半径为50px的圆上的一段弧线。此外,夹角两边与圆相切的两个切点,将圆分成了两段圆弧,一段就是上图绘制出来的1/4圆弧,一段则是剩下的3/4圆弧,由于arcTo()将会沿着最短圆弧的方向绘制弧线,所以绘制出来的弧线就是较短的1/4圆弧。

在上面的示例中,由于我们设定的这三个端点比较特殊,当前端点和端点2实际上就是弧线所在圆与对应的夹角两边相切的切点。也就是说,当前端点就在弧线所在的圆上,并且是所绘制的圆弧的起点。现在,我们再来看看当前端点不是弧线起点的情况:

 
  1. <script type="text/javascript">
  2. //获取Canvas对象(画布)
  3. var canvas = document.getElementById("myCanvas");
  4. //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误
  5. if(canvas.getContext){  
  6.     //获取对应的CanvasRenderingContext2D对象(画笔)
  7.     var ctx = canvas.getContext("2d");  
  8.    
  9.     //指定绘制路径的起始点
  10.     ctx.moveTo(50, 50);
  11.     //注释掉lineTo(),不再先绘制直线  
  12.     //ctx.lineTo(150, 50);
  13.    
  14.     //此时,坐标点(50,50)就是绘制弧线时的当前端点
  15.    
  16.     //端点1
  17.     var p1 = {
  18.         x : 200,
  19.         y : 50
  20.     };
  21.     //端点2
  22.     var p2 = {
  23.         x : 200,
  24.         y : 100        
  25.     };
  26.     //绘制与当前端点、端点1、端点2三个点所形成的夹角的两边相切并且半径为50px的圆的一段弧线
  27.     ctx.arcTo(p1.x, p1.y, p2.x, p2.y, 50);
  28.    
  29.     //设置线条颜色为蓝色
  30.     ctx.strokeStyle = "blue";
  31.     //按照上述绘制路径绘制弧线
  32.     ctx.stroke();
  33. }
  34. </script>

对应的显示效果如下图:运行代码

当前端点不是圆弧起点时的图形效果当前端点不是圆弧起点时的图形效果

通过观察上面的显示效果你会发现,这和我们第1个代码示例的显示效果完全一致。在此处的示例代码中,我们并没有先绘制一条直线,但是,在绘制弧线时,这里的起始点(50,50)就是当前端点,所以arcTo()将会利用起始点(50,50)、端点1(200,50)、端点2(200,100)所形成的夹角,然后绘制一段与夹角两边相切的圆弧。由于起始点(50,50)和端点1(200,50)所在的直线与第1个例子中当前端点(150,50)和端点1(200,50)所在的直线实际上是同一条直线,所以绘制出来的圆弧依然相同。不同的是,此时的当前端点并不是圆弧的起点,arcTo()就会自动添加一条当前端点到圆弧起点的直线。于是,我们就看到了与第1个实例代码完全相同的图形效果。

来源地址:http://www.365mini.com/page/html5-canvas-arcto.htm

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值