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

      編輯Tag賺U幣

      推薦:在html5的Canvas上繪制橢圓的幾種方法總結(jié)
      HTML5中的Canvas并沒有直接提供繪制橢圓的方法,下面是對幾種繪制方法的總結(jié)。各種方法各有優(yōu)缺,視情況選用。各方法的參數(shù)相同,感興趣的朋友可以參考下

      前面的文章我已經(jīng)講了3種在canvas中畫曲線的方法:arc,arcTo以及quadraticCurveTo.他們都有一個共同點,就是他們畫的曲線都只能偏向一邊,今天講的bezierCurveTo與他們最大的不同點就是有兩個控制點,即可以畫出S形的曲線了。

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

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

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

      復(fù)制代碼 代碼如下:www.wf0088.com

      var x1=450, //控制點1的x坐標(biāo)
      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坐標(biāo)是相同的。
      現(xiàn)在再畫一個S形的曲線,證明bezierCurveTo是與眾不同的:

      復(fù)制代碼 代碼如下:www.wf0088.com

      var x1 = 150;
      ...


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

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

      分享:幾個解決兼容IE6\7\8不支持html5標(biāo)簽的幾個方法
      html5大行其道的時代已經(jīng)到來,如果還在糾結(jié)于,是否應(yīng)該掌握html5和css3技術(shù)時,請狠狠的抽自己幾個嘴巴,然后,苦學(xué)吧!下面我們來看幾個解決兼容IE6\7\8不支持html5標(biāo)簽的幾個方法

      來源:未知//所屬分類:HTML5教程/更新時間:2013-04-22
      相關(guān)HTML5教程