濮阳杆衣贸易有限公司

主頁 > 知識庫 > html5 Canvas畫圖教程(8)—canvas里畫曲線之bezierCurveTo方法

html5 Canvas畫圖教程(8)—canvas里畫曲線之bezierCurveTo方法

熱門標簽:高德地圖標注錯誤怎么修改 洛陽市伊川縣地圖標注中心官網(wǎng) 電銷機器人視頻 標準智能外呼系統(tǒng) 會聲會影怎樣做地圖標注效果 江蘇高頻外呼系統(tǒng)線路 搜狗星級酒店地圖標注 平頂山電子地圖標注怎么修改 地圖標注自己去過的地方
前面的文章我已經(jīng)講了3種在canvas中畫曲線的方法:arc,arcTo以及quadraticCurveTo.他們都有一個共同點,就是他們畫的曲線都只能偏向一邊,今天講的bezierCurveTo與他們最大的不同點就是有兩個控制點,即可以畫出S形的曲線了。

bezierCurveTo,也就是所謂的貝賽爾曲線了,如果你學(xué)過某些畫圖工具,就能馬上理解。
bezierCurveTo的語法如下
ctx.bezierCurveTo(x1,y1,x2,y2,x,y);他的參數(shù)我照例解釋一下,其中的(x1,y1)即控制點1的坐標,(x2,y2)是控制點2的坐標,(x,y)是他的終點坐標。和quadraticCurveTo一樣,他的起點坐標也是由moveTo預(yù)先設(shè)置好的。

所以,bezierCurveTo畫出一條曲線需要4個點:起點,終點,控制點1,控制點2.為了后續(xù)講解,這里我假定控制點1對應(yīng)起點,控制點2對應(yīng)終點
這里又要提到canvas畫圖的老問題了,就是代碼畫圖全部靠猜,畫到哪里你要刷新下才能明了。

我還是延續(xù)前面的優(yōu)良傳統(tǒng),畫一些輔助線來幫助大家理解:

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

var x1=450, //控制點1的x坐標
y1 = 300, //控制點1的y
x2 = 450, //控制點2的x
y2 = 500,//控制點2的y
x = 300, //終點x
y = 500;//終點y
ctx.moveTo(300,300);//起點
ctx.beginPath();
ctx.lineWidth = 5;
ctx.strokeStyle = "rgba(0,0,0,1)"
ctx.moveTo(300,300);
ctx.bezierCurveTo(x1,y1,x2,y2,x,y);
ctx.stroke();
//開始畫輔助線
ctx.beginPath();
ctx.strokeStyle = "rgba(255,0,0,0.5)";
ctx.lineWidth = 1;
// 連接起點和控制點1
ctx.moveTo(300,300);
ctx.lineTo(x1,y1);
// 連接終點和控制點2
ctx.moveTo(x2,y2);
ctx.lineTo(x,y);
// 連接起點與終點(基線)
ctx.moveTo(300,300);
ctx.lineTo(x,y);
ctx.stroke();


這里先畫了一個類似quadraticCurveTo的曲線,只偏向一邊。這條線顯得比較“圓潤”,是因為控制點1與2的x坐標是相同的。
現(xiàn)在再畫一個S形的曲線,證明bezierCurveTo是與眾不同的:

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

var x1 = 150;
...


其實只要把控制點1的坐標變一下就行了。如果控制點1與控制點2的坐標分別處在基線的兩邊,則是畫出S形的曲線;如果都在基線的某一邊,則是類似于quadraticCurveTo的效果。
這個例子的情形比較簡單,基線條(起點至終點)是豎直的,但實際應(yīng)用中大部分時候我們的基線都是斜著的,那情況就復(fù)雜多了。不過大家自己試吧

每個畫圖的方法看起來功能都比較單一,但是,強大的方法是各個單一的方法組合出來的。后續(xù)的文章我試著講解一些常規(guī)圖形的畫法,如圓角矩形,橢圓,他們就需要以前這些單一的方法結(jié)合起來。

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

巨人網(wǎng)絡(luò)通訊聲明:本文標題《html5 Canvas畫圖教程(8)—canvas里畫曲線之bezierCurveTo方法》,本文關(guān)鍵詞  html5,Canvas,畫圖,教程,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畫圖教程(8)—canvas里畫曲線之bezierCurveTo方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于html5 Canvas畫圖教程(8)—canvas里畫曲線之bezierCurveTo方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    溆浦县| 永兴县| 方正县| 建德市| 拜泉县| 连云港市| 安溪县| 石屏县| 商洛市| 高邑县| 阜宁县| 东乌| 深圳市| 南阳市| 金平| 汝南县| 平遥县| 弥渡县| 平阳县| 永仁县| 应用必备| 平和县| 清流县| 祁阳县| 普定县| 搜索| 安龙县| 龙川县| 邳州市| 文成县| 石家庄市| 双江| 富民县| 凤台县| 绥中县| 星座| 曲靖市| 龙南县| 天峨县| 冕宁县| 罗甸县|