首頁 web前端 H5教程 在HTML5的CANVAS上绘制椭圆的几种方法

在HTML5的CANVAS上绘制椭圆的几种方法

May 17, 2016 am 09:08 AM
html5

  HTML5中的Canvas并没有直接提供绘制椭圆的方法,下面是对几种绘制方法的总结。各种方法各有优缺,视情况选用。各方法的参数相同:


  •   context为Canvas的2D绘图环境对象,
  •   x为椭圆中心横坐标,
  •   y为椭圆中心纵坐标,
  •   a为椭圆横半轴长,
  •   b为椭圆纵半轴长。



  参数方程法


  该方法利用椭圆的参数方程来绘制椭圆
  1. //-----------用参数方程绘制椭圆---------------------
  2. //函数的参数x,y为椭圆中心;a,b分别为椭圆横半轴、
  3. //纵半轴长度,不可同时为0
  4. //该方法的缺点是,当linWidth较宽,椭圆较扁时
  5. //椭圆内部长轴端较为尖锐,不平滑,效率较低
  6. function ParamEllipse(context, x, y, a, b)
  7. {
  8.    //max是等于1除以长轴值a和b中的较大者
  9.    //i每次循环增加1/max,表示度数的增加
  10.    //这样可以使得每次循环所绘制的路径(弧线)接近1像素
  11.    var step = (a > b) ? 1 / a : 1 / b;
  12.    context.beginPath();
  13.    context.moveTo(x + a, y); //从椭圆的左端点开始绘制
  14.    for (var i = 0; i
  15.    {
  16.       //参数方程为x = a * cos(i), y = b * sin(i),
  17.       //参数为i,表示度数(弧度)
  18.       context.lineTo(x + a * Math.cos(i), y + b * Math.sin(i));
  19.    }
  20.    context.closePath();
  21.    context.stroke();
  22. };
复制代码

  均匀压缩法


  这种方法利用了数学中的均匀压缩原理将圆进行均匀压缩为椭圆,理论上为能够得到标准的椭圆.
  1. //------------均匀压缩法绘制椭圆--------------------
  2. //其方法是用arc方法绘制圆,结合scale进行
  3. //横轴或纵轴方向缩放(均匀压缩)
  4. //这种方法绘制的椭圆的边离长轴端越近越粗,长轴端点的线宽是正常值
  5. //边离短轴越近、椭圆越扁越细,甚至产生间断,这是scale导致的结果
  6. //这种缺点某些时候是优点,比如在表现环的立体效果(行星光环)时
  7. //对于参数a或b为0的情况,这种方法不适用
  8. function EvenCompEllipse(context, x, y, a, b)
  9. {
  10.    context.save();
  11.    //选择a、b中的较大者作为arc方法的半径参数
  12.    var r = (a > b) ? a : b;
  13.    var ratioX = a / r; //横轴缩放比率
  14.    var ratioY = b / r; //纵轴缩放比率
  15.    context.scale(ratioX, ratioY); //进行缩放(均匀压缩)
  16.    context.beginPath();
  17.    //从椭圆的左端点开始逆时针绘制
  18.    context.moveTo((x + a) / ratioX, y / ratioY);
  19.    context.arc(x / ratioX, y / ratioY, r, 0, 2 * Math.PI);
  20.    context.closePath();
  21.    context.stroke();
  22.    context.restore();
  23. };
复制代码


      下面的代码会出现线宽不一致的问题,解决办法:


     均匀压缩法中把
  context.stroke();  context.restore();
  改為
  context.restore();  context.stroke();
  就可以

        三次贝塞尔曲线法一


  三次贝塞尔曲线绘制椭圆在实际绘制时是一种近似,在理论上也是一种近似。 但因为其效率较高,在计算机矢量图形学中,常用于绘制椭圆,但是具体的理论我不是很清楚。 近似程度在于两个控制点位置的选取。这种方法的控制点位置是我自己试验得出,精度还可以.
  1. //---------使用三次贝塞尔曲线模拟椭圆1---------------------
  2. //此方法也会产生当lineWidth较宽,椭圆较扁时,
  3. //长轴端较尖锐,不平滑的现象
  4. function BezierEllipse1(context, x, y, a, b)
  5. {
  6.    //关键是bezierCurveTo中两个控制点的设置
  7.    //0.5和0.6是两个关键系数(在本函数中为试验而得)
  8.    var ox = 0.5 * a,
  9.        oy = 0.6 * b;

  10.    context.save();
  11.    context.translate(x, y);
  12.    context.beginPath();
  13.    //从椭圆纵轴下端开始逆时针方向绘制
  14.    context.moveTo(0, b);
  15.    context.bezierCurveTo(ox, b, a, oy, a, 0);
  16.    context.bezierCurveTo(a, -oy, ox, -b, 0, -b);
  17.    context.bezierCurveTo(-ox, -b, -a, -oy, -a, 0);
  18.    context.bezierCurveTo(-a, oy, -ox, b, 0, b);
  19.    context.closePath();
  20.    context.stroke();
  21.    context.restore();

  22. };
复制代码

  三次贝塞尔曲线法二


  这种方法是从StackOverFlow中一个帖子的回复中改变而来,精度较高,也是通常用来绘制椭圆的方法.
  1. //---------使用三次贝塞尔曲线模拟椭圆2---------------------
  2. //此方法也会产生当lineWidth较宽,椭圆较扁时
  3. //,长轴端较尖锐,不平滑的现象
  4. //这种方法比前一个贝塞尔方法精确度高,但效率稍差
  5. function BezierEllipse2(ctx, x, y, a, b)
  6. {
  7.    var k = .5522848,
  8.    ox = a * k, // 水平控制点偏移量
  9.    oy = b * k; // 垂直控制点偏移量

  10.    ctx.beginPath();
  11.    //从椭圆的左端点开始顺时针绘制四条三次贝塞尔曲线
  12.    ctx.moveTo(x - a, y);
  13.    ctx.bezierCurveTo(x - a, y - oy, x - ox, y - b, x, y - b);
  14.    ctx.bezierCurveTo(x + ox, y - b, x + a, y - oy, x + a, y);
  15.    ctx.bezierCurveTo(x + a, y + oy, x + ox, y + b, x, y + b);
  16.    ctx.bezierCurveTo(x - ox, y + b, x - a, y + oy, x - a, y);
  17.    ctx.closePath();
  18.    ctx.stroke();
  19. };
复制代码


  光栅法


  这种方法可以根据Canvas能够操作像素的特点,利用图形学中的基本算法来绘制椭圆。 例如中点画椭圆算法等。


  其中一个例子是园友“豆豆狗”的一篇博文“HTML5 Canvas 提高班(一) —— 光栅图形学(1)中点画圆算法”。这种方法由于比较“原始”,灵活性大,效率高,精度高,但要想实现一个有使用价值的绘制椭圆的函数,比较复杂。比如,要当线宽改变时,算法就复杂一些。

      原文出自:Cloudy Waterman

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

HTML 中的表格邊框 HTML 中的表格邊框 Sep 04, 2024 pm 04:49 PM

HTML 表格邊框指南。在這裡,我們以 HTML 中的表格邊框為例,討論定義表格邊框的多種方法。

HTML 中的巢狀表 HTML 中的巢狀表 Sep 04, 2024 pm 04:49 PM

這是 HTML 中巢狀表的指南。這裡我們討論如何在表中建立表格以及對應的範例。

HTML 左邊距 HTML 左邊距 Sep 04, 2024 pm 04:48 PM

HTML 左邊距指南。在這裡,我們討論 HTML margin-left 的簡要概述及其範例及其程式碼實作。

HTML 表格佈局 HTML 表格佈局 Sep 04, 2024 pm 04:54 PM

HTML 表格佈局指南。在這裡,我們詳細討論 HTML 表格佈局的值以及範例和輸出。

HTML 輸入佔位符 HTML 輸入佔位符 Sep 04, 2024 pm 04:54 PM

HTML 輸入佔位符指南。在這裡,我們討論 HTML 輸入佔位符的範例以及程式碼和輸出。

HTML 有序列表 HTML 有序列表 Sep 04, 2024 pm 04:43 PM

HTML 有序列表指南。在這裡我們也分別討論了 HTML 有序列表和類型的介紹以及它們的範例

在 HTML 中移動文字 在 HTML 中移動文字 Sep 04, 2024 pm 04:45 PM

HTML 中的文字移動指南。在這裡我們討論一下marquee標籤如何使用語法和實作範例。

HTML onclick 按鈕 HTML onclick 按鈕 Sep 04, 2024 pm 04:49 PM

HTML onclick 按鈕指南。這裡我們分別討論它們的介紹、工作原理、範例以及各個事件中的onclick事件。

See all articles