搜尋
首頁web前端H5教程在html5的Canvas上繪製橢圓的幾種方法總結_html5教程技巧

概述
HTML5中的Canvas並沒有直接提供繪製橢圓的方法,以下是對幾種繪製方法的總結。各種方法各有優缺,視情況選用。各方法的參數相同:
context為Canvas的2D繪圖環境對象,
x為橢圓中心橫座標,
y為橢圓中心縱座標,
a為橢圓橫半軸長,
b為橢圓縱半軸長。
參數方程法
該方法利用橢圓的參數方程來繪製橢圓

複製代碼
程式碼如下:

//-----------用參數方程式繪製橢圓---------------- -----
//函數的參數x,y為橢圓中心;a,b分別為橢圓橫半軸、
//縱半軸長度,不可同時為0
//該方法的缺點是,當linWidth較寬,橢圓較扁時
//橢圓內部長軸端較為尖銳,不平滑,效率較低
function ParamEllipse(context, x, y, a, b)
{
//max是等於1除以長軸值a和b中的較大者
//i每次循環增加1/max,表示度數的增加
//這樣可以讓每次循環所繪製的路徑(弧線)接近1像素
var step = (a > b) ? 1 / a : 1 / b;
context.beginPath();
context.moveTo (x a, y); //從橢圓的左端點開始繪製
for (var i = 0; i {
//參數方程式為x = a * cos(i), y = b * sin(i),
//參數為i,表示度數(弧度)
context.lineTo(x a * Math.cos(i), y b * Math .sin(i));
}
context.closePath();
context.stroke();
};

均勻壓縮法


均勻壓縮法
這種方法利用了數學中的均勻壓縮原理將圓進行均勻壓縮為橢圓,理論上為能夠得到標準的橢圓.下面的代碼會出現線寬不一致的問題,解決辦法看5樓simonleung的評論。
複製程式碼


程式碼如下:


//------- -----均勻壓縮法繪製橢圓--------------------
//其方法是用arc方法繪製圓,結合scale進行
//橫軸或縱軸方向縮放(均勻壓縮)
//這種方法繪製的橢圓的邊離長軸端越近越粗,長軸端點的線寬是正常值
//邊離短軸越近、橢圓越扁越細,甚至產生間斷,這是scale導致的結果
//這種缺點某些時候是優點,例如在表現環的立體效果(行星光環)時
//對於參數a或b為0的情況,這種方法不適用
function EvenCompEllipse(context, x, y, a, b)
{
context.save();
//選擇a、b中的較大者作為arc方法的半徑參數
var r = (a > b) ? a : b;
var ratioX = a / r; //橫軸縮放比率
var ratioY = b / r; //縱軸縮放比率
context.scale(ratioX, ratioY); //進行縮放(均勻壓縮)
context.beginPath();
//從橢圓的左端點開始逆時針繪製
context.moveTo((x a) / ratioX, y / ratioY);
context.arc(x / ratioX, y / ratioY, r, 0, 2 * Math.PI );
context.closePath();
context.stroke();
context.restore(); };


三次貝塞爾曲線法一
三次貝塞爾曲線繪製橢圓在實際繪製時是一種近似,在理論上也是一種近似。 但因為其效率較高,在電腦向量圖形學中,常用於繪製橢圓,但是具體的理論我不是很清楚。 近似程度在於兩個控制點位置的選取。這種方法的控制點位置是我自己試驗得出,精確度還可以.
複製程式碼


程式碼如下:


//---------使用三次貝塞爾曲線模擬橢圓1---------------------
//此方法也會產生當lineWidth較寬,橢圓較扁時,
//長軸端較尖銳,不平滑的現象
function BezierEllipse1(context, x, y, a, b )
{
//關鍵​​是bezierCurveTo中兩個控制點的設定
//0.5和0.6是兩個關鍵係數(在本函數中為試驗而得)
var ox = 0.5 * a,
oy = 0.6 * b;
context.save();
context.translate(x, y);
context.beginPath();
//從橢圓縱縱軸下端開始逆時針方向繪製
context.moveTo(0, b);
context.bezierCurveTo(ox, b, a, oy, a, 0);
context.bezierCurveTo , ox, -b, 0, -b);
context.bezierCurveTo(-ox, -b, -a, -oy, -a, 0);
context.bezierCurveTo(-a, oy, - ox, b, 0, b);
context.closePath();
context.stroke(); context.restore(); };
三次貝塞爾曲線法二
這種方法是從StackOverFlow中一個帖子的回復中改變而來,精度較高,也是通常用來繪製橢圓的方法.

複製程式碼
程式碼如下:

//---------使用三次貝塞爾曲線模擬橢圓2---------------------
//此方法也會產生當lineWidth較寬,橢圓較扁時
//,長軸端較尖銳,不平滑的現象
//這種方法比前一個貝塞爾方法精確度高,但效率稍差
function BezierEllipse2(ctx, x, y, a, b)
{
var k = .5522848,
ox = a * k, // 水平控制點偏移量
oy = b * k; // 垂直控制點偏移量
ctx.beginPath();
//從橢圓的左端點開始順時針繪製四條三次貝塞爾曲線
ctx.moveTo(x - a, y);
ctx.bezierCurveTo (x - a, y - oy, x - ox, y - b, x, y - b);
ctx.bezierCurveTo(x ox, y - b, x a, y - oy, x a, y);
ctx.bezierCurveTo(x a, y oy, x ox, y b, x, y b);
ctx.bezierCurveTo(x - ox, y b, x - a, y oy, x - a, y);
ctx.closePath();
ctx.stroke();
};

光柵法
這種方法可以根據Canvas能夠操作像素的特點,利用圖形學中的基本演算法來繪製橢圓。 例如中點畫橢圓演算法等。
其中一個例子是園友「豆豆狗」的部落格文章「HTML5 Canvas 提高班(一) —— 光柵圖形學(1)中點畫圓演算法」。這種方法由於比較“原始”,靈活性大,效率高,精度高,但要實現一個有使用價值的繪製橢圓的函數,比較複雜。例如,要當線寬改變時,演算法就複雜一些。雖然是畫圓的演算法,但畫橢圓的演算法與之類似,可以參考下。
Demo
下面是除光柵法之外,幾個繪製橢圓函數的演示,演示程式碼如下:

複製程式碼
複製程式碼


程式碼如下:








注意,要成功運行程式碼,需要支援HTML5的Canvas的瀏覽器。 第一次寫博客,弄了一整天,真不容易啊!博客園的暗色皮膚模板對插入的代碼顯示效果不好。為了弄代碼格式,我可是煞費苦心啊!
陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡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

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

熱工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MantisBT

MantisBT

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

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),