html5 Canvas畫圖教程(8)—canvas里畫曲線之bezierCurveTo方法
來源:易賢網 閱讀:1831 次 日期:2016-07-23 13:27:49
溫馨提示:易賢網小編為您整理了“html5 Canvas畫圖教程(8)—canvas里畫曲線之bezierCurveTo方法”,方便廣大網友查閱!

arc,arcTo以及quadraticCurveTo.他們都有一個共同點,就是他們畫的曲線都只能偏向一邊,今天講的bezierCurveTo與他們最大的不同點就是有兩個控制點,即可以畫出S形的曲線了,感興趣的朋友可以了解下

bezierCurveTo,也就是所謂的貝賽爾曲線了,如果你學過某些畫圖工具,就能馬上理解。

bezierCurveTo的語法如下:

ctx.bezierCurveTo(x1,y1,x2,y2,x,y);他的參數我照例解釋一下,其中的(x1,y1)即控制點1的坐標,(x2,y2)是控制點2的坐標,(x,y)是他的終點坐標。和quadraticCurveTo一樣,他的起點坐標也是由moveTo預先設置好的。

所以,bezierCurveTo畫出一條曲線需要4個點:起點,終點,控制點1,控制點2.為了后續(xù)講解,這里我假定控制點1對應起點,控制點2對應終點

這里又要提到canvas畫圖的老問題了,就是代碼畫圖全部靠猜,畫到哪里你要刷新下才能明了。

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

復制代碼代碼如下:

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坐標是相同的。

現在再畫一個S形的曲線,證明bezierCurveTo是與眾不同的:

復制代碼代碼如下:

var x1 = 150;

...

名單

其實只要把控制點1的坐標變一下就行了。如果控制點1與控制點2的坐標分別處在基線的兩邊,則是畫出S形的曲線;如果都在基線的某一邊,則是類似于quadraticCurveTo的效果。

這個例子的情形比較簡單,基線條(起點至終點)是豎直的,但實際應用中大部分時候我們的基線都是斜著的,那情況就復雜多了。不過大家自己試吧

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

更多信息請查看網頁制作

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網