成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > 在html5的Canvas上繪制橢圓的幾種方法總結(jié)

在html5的Canvas上繪制橢圓的幾種方法總結(jié)

熱門標簽:電銷機器人視頻 地圖標注自己去過的地方 高德地圖標注錯誤怎么修改 江蘇高頻外呼系統(tǒng)線路 會聲會影怎樣做地圖標注效果 洛陽市伊川縣地圖標注中心官網(wǎng) 平頂山電子地圖標注怎么修改 搜狗星級酒店地圖標注 標準智能外呼系統(tǒng)
概述
HTML5中的Canvas并沒有直接提供繪制橢圓的方法,下面是對幾種繪制方法的總結(jié)。各種方法各有優(yōu)缺,視情況選用。各方法的參數(shù)相同:
context為Canvas的2D繪圖環(huán)境對象,
x為橢圓中心橫坐標,
y為橢圓中心縱坐標,
a為橢圓橫半軸長,
b為橢圓縱半軸長。
參數(shù)方程法
該方法利用橢圓的參數(shù)方程來繪制橢圓

復(fù)制代碼
代碼如下:

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

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

復(fù)制代碼
代碼如下:

//------------均勻壓縮法繪制橢圓--------------------
//其方法是用arc方法繪制圓,結(jié)合scale進行
//橫軸或縱軸方向縮放(均勻壓縮)
//這種方法繪制的橢圓的邊離長軸端越近越粗,長軸端點的線寬是正常值
//邊離短軸越近、橢圓越扁越細,甚至產(chǎn)生間斷,這是scale導(dǎo)致的結(jié)果
//這種缺點某些時候是優(yōu)點,比如在表現(xiàn)環(huán)的立體效果(行星光環(huán))時
//對于參數(shù)a或b為0的情況,這種方法不適用
function EvenCompEllipse(context, x, y, a, b)
{
context.save();
//選擇a、b中的較大者作為arc方法的半徑參數(shù)
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();
};

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

復(fù)制代碼
代碼如下:

//---------使用三次貝塞爾曲線模擬橢圓1---------------------
//此方法也會產(chǎn)生當lineWidth較寬,橢圓較扁時,
//長軸端較尖銳,不平滑的現(xiàn)象
function BezierEllipse1(context, x, y, a, b)
{
//關(guān)鍵是bezierCurveTo中兩個控制點的設(shè)置
//0.5和0.6是兩個關(guān)鍵系數(shù)(在本函數(shù)中為試驗而得)
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(a, -oy, 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中一個帖子的回復(fù)中改變而來,精度較高,也是通常用來繪制橢圓的方法.

復(fù)制代碼
代碼如下:

//---------使用三次貝塞爾曲線模擬橢圓2---------------------
//此方法也會產(chǎn)生當lineWidth較寬,橢圓較扁時
//,長軸端較尖銳,不平滑的現(xiàn)象
//這種方法比前一個貝塞爾方法精確度高,但效率稍差
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();
};

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

復(fù)制代碼
代碼如下:

<div id="CanvasWrap" style=" background:#fff; width: 600px; height: 600px; border: 1px solid black;"></div>
<script type="text/javascript">// <![CDATA[
var canvas,
context;
var div = document.getElementById("CanvasWrap");
div.innerHTML = "";
canvas = document.createElement("canvas");
canvas.style.width = "600px"
canvas.style.height = "600px"
canvas.width = 600;
canvas.height = 600;
context = canvas.getContext("2d");
div.appendChild(canvas);
function execDraw()
{
//解決Chrome下的線寬小于等于1的問題
context.lineWidth = 1.1;
context.strokeStyle="black"
ParamEllipse(context, 130, 80, 50, 50); //圓
ParamEllipse(context, 130, 80, 100, 20);//橢圓
EvenCompEllipse(context, 130, 200, 50, 50); //圓
EvenCompEllipse(context, 130, 200, 100, 20);//橢圓
BezierEllipse1(context, 470, 80, 50, 50); //圓
BezierEllipse1(context, 470, 80, 100, 20); //橢圓
BezierEllipse2(context, 470, 200, 50, 50); //圓
BezierEllipse2(context, 470, 200, 100, 20); //橢圓
//檢測相似性(重合的程度)
ParamEllipse(context, 300, 450, 250, 50);
context.strokeStyle = "yellow";
BezierEllipse1(context, 300, 450, 250, 50);
context.strokeStyle = "blue";
BezierEllipse2(context, 300, 450, 250, 50);
};
function clearCavnas()
{
context.clearRect(0, 0, 600, 600);
};
// ]]></script>
<p>

<button onclick="execDraw();" type="button">執(zhí)行</button>
<button onclick="clearCanvas();" type="button">清理</button>
</p>

注意,要成功運行代碼,需要支持HTML5的Canvas的瀏覽器。
第一次寫博客,弄了一整天,真不容易??!博客園的暗色皮膚模板對插入的代碼顯示效果不好。為了弄代碼格式,我可是煞費苦心?。?

標簽:松原 廣東 蚌埠 廣西 常德 阿克蘇 鄂爾多斯 果洛

巨人網(wǎng)絡(luò)通訊聲明:本文標題《在html5的Canvas上繪制橢圓的幾種方法總結(jié)》,本文關(guān)鍵詞  在,html5,的,Canvas,上,繪制,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《在html5的Canvas上繪制橢圓的幾種方法總結(jié)》相關(guān)的同類信息!
  • 本頁收集關(guān)于在html5的Canvas上繪制橢圓的幾種方法總結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    久久久久久久久久久亚洲| 国产精品久久久久久久小唯西川| 国产一二区视频| 欧美亚洲成人网| 日韩欧美国产三级电影视频| 亚洲在线欧美| 国产日韩在线播放| 欧日韩一区二区三区| 国产九一精品| 伊人成人免费视频| 中文字幕一区二区久久人妻| 欧美亚洲国产成人| 不卡的看片网站| 韩国国内大量揄拍精品视频| 波多野结衣在线免费观看| 奇米777国产一区国产二区| 丁香婷婷激情网| 欧美精品一卡| 精品一卡二卡三卡四卡日本乱码| 国产高清成人久久| 高清免费日韩| 日韩精品系列| 国产成人久久久| 福利视频在线| 国产亚洲高清在线观看| 俄罗斯男人又粗又大| 99re亚洲国产精品| 九色91视频| 亚洲九九在线| 久久精品女人天堂| 精品国产美女在线| 久久婷婷国产综合精品青草| 欧美精选一区二区三区| 亚洲香蕉成人av网站在线观看| 黄网站免费在线观看| 小嫩嫩精品导航| 亚洲一卡二卡三卡四卡| 日本一本二本在线观看| 亚洲精品小视频在线观看| 中国黄色a级片| 国产精品18久久久| 国产视频一区二区三区在线观看| 性高潮久久久久久久久| 中文字幕在线一| 欧美日韩在线不卡一区| 亚洲精品视频三区| 久久久蜜桃精品| 国产强被迫伦姧在线观看无码| 亚洲人metart人体| 中文在线资源新版官网| 国产美女作爱全过程免费视频| 精品无码一区二区三区| 黄色免费av网站| 欧美乱人伦中文字幕在线| 日本18视频网站| 成人激情电影在线| 久久黄色影院| 婷婷5月激情5月| 精品午夜福利在线观看| 九一免费在线观看| 国产日韩欧美一区二区三区乱码| 99国产精品久久久久久久成人| 国产女同性恋一区二区| 污污的视频在线免费观看| 8×8x拔擦拔擦在线视频网站| 亚洲精品女av网站| 中文字幕乱码无码人妻系列蜜桃| 久久精品国产亚洲7777| 石原莉奈在线亚洲二区| 久久超级碰碰| 啪啪免费视频一区| 超碰成人在线播放| 国产精品日韩一区二区免费视频| 三级精品在线观看| 菠萝蜜视频在线观看一区| 国产亚洲美女精品久久久| 蜜桃免费在线视频| 国产三级做爰高清在线| 国产欧美一区二区三区国产幕精品| 欧美极品jizzhd欧美| av影片在线看| 福利在线导航136| 欧美1区视频| 中文字幕视频观看| 五月婷婷深深爱| 久久国产精品免费视频| 女明星视频黄又免费| 少妇激情av一区二区三区| 欧美精品18+| 一区二区激情| 精品国产三级a∨在线| 天堂日韩电影| 国产一区二区视频在线| 黄频视频在线观看| 手机看片久久久| 擼擼色在线看观看免费| jizzjizzjizz亚洲女| 国产精品视频精品视频| 免费的黄色片| 麻豆免费看一区二区三区| 日韩欧美中文视频| 亚洲国产精品无码观看久久| 亚洲sss视频在线视频| 欧美日韩国产激情| 午夜精品久久久久久久| 免费白白视频| 成人欧美一区二区三区在线湿哒哒| 久久国产一二区| 国产高清免费在线观看| 国产精品精品| 国产偷国产偷精品高清尤物| 丝袜国产免费观看| 午夜爱爱毛片xxxx视频免费看| 国产裸体免费无遮挡| 日本欧美日韩| 五月天网站亚洲| 一区二区在线视频播放| 九九久久精品这里久久网| 成年人黄色大片在线| 女人黄色免费在线观看| 精品亚洲国产成av人片传媒| 69精品无码成人久久久久久| 亚洲精品日产精品乱码不卡| japanese色系久久精品| 欧美成a人片在线观看久| 91精选福利| 在线观看污视频| 久久97久久97精品免视看| 97中文字幕| 91免费在线| caoporn国产精品免费公开| 老鸭窝一区二区| 久久久久这里只有精品| 中文字幕在线视频不卡| 国产精品扒开腿做| 午夜性色福利影院| 欧美日韩生活片| 深夜福利在线观看直播| 日本午夜精品一区二区| 国产精华7777777| 欧美午夜不卡影院在线观看完整版免费| 最新中文字幕一区| 最新国产乱人伦偷精品免费网站| 中文字幕网站在线观看| 性中国xxx极品hd| 免费在线国产视频| 欧美成人官网二区| 国产精品久久久久一区二区国产| av天堂永久资源网| 777奇米成人网| 国产男小鲜肉同志免费| 欧美一区二区视频在线播放| 久久精品在线免费观看| 91人人网站| 国产精品国产三级国产专区53| 波多野结衣一区二区| 日韩av不卡播放| 自拍偷拍亚洲在线| 九九免费精品视频在线观看| 午夜激情在线观看视频| 免费男女羞羞的视频网站中文字幕妖精视频| 亚洲做受高潮| 丰满亚洲少妇av| 91精品秘密在线观看| 久久久精品国产99久久精品芒果| 亚洲二区免费| 欧美大片免费| 日韩黄色成人| 国产精品69久久久久水密桃| 久久久久久久激情| 天天色天天上天天操| 亚洲色图都市激情| 中文字幕一区二区人妻痴汉电车| 91香蕉视频网址| 亚洲韩国一区二区三区| 99reav在线| 欧美捆绑视频| 亚洲国产婷婷香蕉久久久久久99| 国产一区二区自拍| 人妻激情偷乱频一区二区三区| a天堂资源在线观看| 在线视频国内自拍亚洲视频| 欧美吻胸吃奶大尺度电影| 五月婷婷激情综合| 成人在线小视频| 成人18视频免费69| 视频一区在线视频| 一区二区成人在线观看| 99久久久久久久久| 欧美视频亚洲色图| 亚洲丝袜在线视频| 成人h精品动漫一区二区三区| 成人激情诱惑| 亚洲欧美另类小说视频| 91网站在线播放| 一级黄色大片免费观看| 日本在线观看视频| 一区二区三区免费视频播放器| 国产在线精品二区| 日本黄色三级大片| 国产乱人伦精品一区二区| 欧美黑粗硬大| 日本888xxxx| 国产真实乱对白精彩久久| 91免费在线| 精品女人久久久| 色女孩综合影院| 精品av一区二区| 亚洲一区二区美女| 成人美女在线视频| 樱花草www在线| 日韩亚洲精品在线观看| 国产情侣在线播放| 精品无人国产偷自产在线| 亚洲天堂avav| 精品伦理一区二区三区| 欧美videossex极品| 污污网站在线免费观看| 精品三级在线观看| jizzjizz韩国| 国产精品19乱码一区二区三区| 国产欧美一区二区三区在线观看视频| 欧美日韩一区二区三区在线电影| 国产亚洲欧美在线精品| 国模gogo一区二区大胆私拍| 精品在线播放| 成人观看视频| 精品久久ai| 美女日批免费视频| 91小仙女jk白丝袜呻吟| www.激情五月| 成人影视在线播放| 日韩欧美国产wwwww| 91网址在线观看| 岛国精品一区二区三区| 中文字幕2018| 久久人人爽人人爽人人片av不| 日本激情视频网站| 欧美天堂一区二区三区| 高清hd写真福利在线播放| 北条麻妃在线观看视频| 欧美午夜在线一二页| 丝袜美腿中文字幕| 黄页视频在线播放| 国产69精品久久久久9999| 一区二区三区精品在线观看| 欧美爱爱小视频| 国产人伦精品一区二区| 综合激情婷婷| 九一成人免费视频| 国产乱人伦精品一区二区三区| 疯狂做受xxxx欧美肥白少妇| 成人av网站大全| 欧美视频免费在线| 欧美日韩一区二区三区四区五区| 5566中文字幕| 最新av网站在线观看| 国产精品不卡一区二区三区在线观看| 日韩人在线观看| aaa一区二区| 中文字幕免费高清视频| 日韩精品久久理论片| 国产xxx视频| 久久综合偷偷噜噜噜色| 狠狠爱在线视频一区| 日本久久久久| 亚洲欧洲成人| 亚洲美女屁股眼交| 麻豆免费在线视频| 国产特级毛片| 亚洲综合大片69999| av电影在线观看网站| 日韩视频亚洲视频| 国产在线观看福利| 国内精品卡一卡二卡三| 成人免费在线网| www.就去干.com| 国产精品av一区二区| 久久久久天天天天| 自拍亚洲色图| 九色porny自拍视频在线观看| 一区二区视频免费在线观看| 一区在线不卡| 国产一级生活片| 91av在线看| 国产露脸91国语对白| 亚洲ai欧洲av| 伊人成综合网| 亚洲少妇视频| 激情综合网天天干| 理论片日本一区| 六月丁香婷婷激情| 99久久影视| 日韩免费电影在线观看| 国产成人精品日本亚洲专区61| 亚洲自拍小视频免费观看| 久久久精品国产**网站| 久久亚洲导航| 手机av免费在线观看| 国产亚洲人成a一在线v站| 欧美先锋资源| 亚洲国产精品va在线观看黑人| 国产成人精品免费在线| 欧美黄色一区二区| 91看片在线| 国产suv精品一区二区三区| 黄色小视频在线看| 国产精品毛片无遮挡高清| 亚洲摸下面视频| 天堂av免费在线观看| 99re在线国产| 中文字幕乱在线伦视频中文字幕乱码在线| 国产福利91精品一区二区| 国产欧美一区二区三区久久| 一级特黄aaaaaa大片| 成人video亚洲精品| 国产精品夜夜夜爽阿娇| 天堂影院一区二区| 99国内精品| 国产精品视频yy9299一区| 久久国产精品久久久久久久久久| 成人精品影院| 国产igao激情在线入口| 一个人在线视频免费观看www| 国内外激情在线| 国产美女高潮一区二区三区| 91国在线视频| 日韩不卡av在线|