国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > WEB開發 > 正文

canvas繪制線條和圖案

2024-04-27 13:52:43
字體:
來源:轉載
供稿:網友

  沒有canvas之前,想要在網頁上面繪制線條或圖案,是非常麻煩且不兼容的。在《js畫直線》一文中轉載了網絡上常用的在IE和FF中繪制線條的方法,但如果想要這些方法通用,則是不可能的。但現在有了canvas標簽,一切就變得簡單了。

  現在,你只需要在頁面上添加canvas標簽,并通過Javascript調用它的相應方法,就可以輕松的在頁面上繪制線條和圖案。

  canvas繪制線條示例

   <b>canvas繪制線條示例</b><br/><canvas id="myCanvas"  style="border:1px solid #c3c3c3;">      Your browser does not support the canvas element.      </canvas>      <script type="text/javascript">          var myCanvas = document.getElementById("myCanvas");          if (!myCanvas.getContext)          {              alert("Your browser does not support the canvas element.");          }          else         {              var myContext = myCanvas.getContext("2d");              myContext.moveTo(200, 150);              myContext.lineTo(100, 100);              myContext.lineTo(200, 50);              myContext.strokeStyle = "#FF0000";              myContext.lineWidth = 4;              myContext.stroke();          }         </script> 

說明:

  1)顯示在頁面中放置了一個canvas標簽,設定id、width、height等屬性,并為這個標簽設定邊框。
  2)在Javascript中檢測瀏覽器是否支持
  3)當瀏覽器支持的時候開始調用getContext方法獲得繪圖的上下文(這地方很像vc中的GDI繪圖~~),目前只提供了2D上下文,將來還有可能支持OpenGL ES的3D上下文。
  4)moveTo方法是將當前位置移動到指定的坐標
  5)lineTo方法是向指定的左邊繪制直線
  6)strokeStyle 屬性是指定線條的顏色,在本例子中指定為紅色
  7)lineWidth 屬性設置線條的粗細,這里設置為4px
  8)stroke方法則是將直線顯示出來。貌似是之前只是規定了哪里有線條,并沒有顯示,當調用這個方法后,線條才可以顯示。

canvas繪制圖案

<b>canvas繪制圖案</b><BR><canvas id="myCanvas" width="300" height="200"  style="border:1px solid #c3c3c3;">      Your browser does not support the canvas element.      </canvas>      <script type="text/javascript">          var myCanvas = document.getElementById("myCanvas");          if (!myCanvas.getContext)          {              alert("Your browser does not support the canvas element.");          }          else         {              var myContext = myCanvas.getContext("2d");              myContext.fillStyle = "rgb(200,0,0)";              myContext.fillRect(10, 10, 55, 50);              myContext.fillStyle = "rgba(0, 0, 200, 0.5)";              myContext.fillRect(30, 30, 55, 50);              myContext.fillRect(100, 0, 150, 50);              myContext.strokeRect(100, 60, 150, 50);              myContext.clearRect(130, 10, 90, 30);          }      </script> 

說明:

  1)直接到fillStyle屬性,之前的代碼是相同的,不再贅言。
  2)fillStyle屬性設定了填充的顏色、透明度等,如果設置為"rgb(200,0,0)",則表示一個顏色,不透明;如果設置  為"rgba(0,0,200,0.5)",則表示顏色為rgb(0,0,200),透明度為50%,
  3)fillRect方法是繪制一個矩形,這個矩形區域沒有邊框,只有填充色。這個方法有四個參數,前兩個表示左上角的坐標位 置,第三個參數為長度,第四個參數為高度。
  4)strokeRect方法繪制一個帶邊框的矩形。該方法的四個參數的解釋同上。
  5)clearRect方法是清除一個矩形區域,被清除的區域將沒有任何線條。該方法的四個參數的解釋同上。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 荥经县| 梁平县| 镇巴县| 岚皋县| 德保县| 车致| 大兴区| 两当县| 马关县| 衡南县| 灌云县| 泾阳县| 山阴县| 新蔡县| 玉溪市| 托克托县| 玉林市| 阿坝| 卓尼县| 吉木萨尔县| 甘肃省| 蒲江县| 阜新| 汤原县| 宜春市| 云浮市| 宁远县| 乐业县| 巢湖市| 定日县| 京山县| 荥阳市| 长泰县| 林周县| 望江县| 滦南县| 皋兰县| 崇阳县| 富锦市| 克什克腾旗| 黄骅市|