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

  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
H5代碼的基礎:密鑰元素及其目的H5代碼的基礎:密鑰元素及其目的Apr 23, 2025 am 12:09 AM

HTML5的關鍵元素包括、、、、、等,用於構建現代網頁。 1.定義頭部內容,2.用於導航鏈接,3.表示獨立文章內容,4.組織頁面內容,5.展示側邊欄內容,6.定義頁腳,這些元素增強了網頁的結構和功能性。

HTML5和H5:了解常見用法HTML5和H5:了解常見用法Apr 22, 2025 am 12:01 AM

HTML5和H5沒有區別,H5是HTML5的簡稱。 1.HTML5是HTML的第五個版本,增強了網頁的多媒體和交互功能。 2.H5常用於指代基於HTML5的移動網頁或應用,適用於各種移動設備。

HTML5:現代網絡的基礎(H5)HTML5:現代網絡的基礎(H5)Apr 21, 2025 am 12:05 AM

HTML5是超文本標記語言的最新版本,由W3C標準化。 HTML5引入了新的語義化標籤、多媒體支持和表單增強,提升了網頁結構、用戶體驗和SEO效果。 HTML5引入了新的語義化標籤,如、、、等,使網頁結構更清晰,SEO效果更好。 HTML5支持多媒體元素和,無需第三方插件,提升了用戶體驗和加載速度。 HTML5增強了表單功能,引入了新的輸入類型如、等,提高了用戶體驗和表單驗證效率。

H5代碼:編寫清潔有效的HTML5H5代碼:編寫清潔有效的HTML5Apr 20, 2025 am 12:06 AM

如何寫出乾淨高效的HTML5代碼?答案是通過語義化標籤、結構化代碼、性能優化和避免常見錯誤。 1.使用語義化標籤如、等,提升代碼可讀性和SEO效果。 2.保持代碼結構化和可讀性,使用適當縮進和註釋。 3.優化性能,通過減少不必要的標籤、使用CDN和壓縮代碼。 4.避免常見錯誤,如標籤未閉合,確保代碼有效性。

H5:如何增強網絡上的用戶體驗H5:如何增強網絡上的用戶體驗Apr 19, 2025 am 12:08 AM

H5通過多媒體支持、離線存儲和性能優化提升網頁用戶體驗。 1)多媒體支持:H5的和元素簡化開發,提升用戶體驗。 2)離線存儲:WebStorage和IndexedDB允許離線使用,提升體驗。 3)性能優化:WebWorkers和元素優化性能,減少帶寬消耗。

解構H5代碼:標籤,元素和屬性解構H5代碼:標籤,元素和屬性Apr 18, 2025 am 12:06 AM

HTML5代碼由標籤、元素和屬性組成:1.標籤定義內容類型,用尖括號包圍,如。 2.元素由開始標籤、內容和結束標籤組成,如內容。 3.屬性在開始標籤中定義鍵值對,增強功能,如。這些是構建網頁結構的基本單位。

了解H5代碼:HTML5的基本原理了解H5代碼:HTML5的基本原理Apr 17, 2025 am 12:08 AM

HTML5是構建現代網頁的關鍵技術,提供了許多新元素和功能。 1.HTML5引入了語義化元素如、、等,增強了網頁結構和SEO。 2.支持多媒體元素和,無需插件即可嵌入媒體。 3.表單增強了新輸入類型和驗證屬性,簡化了驗證過程。 4.提供了離線和本地存儲功能,提升了網頁性能和用戶體驗。

H5代碼:Web開發人員的最佳實踐H5代碼:Web開發人員的最佳實踐Apr 16, 2025 am 12:14 AM

H5代碼的最佳實踐包括:1.使用正確的DOCTYPE聲明和字符編碼;2.採用語義化標籤;3.減少HTTP請求;4.使用異步加載;5.優化圖像。這些實踐能提升網頁的效率、可維護性和用戶體驗。

See all articles

熱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

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

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版