亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

HTML5 canvas 元素詳細教程一

2024-08-26 00:15:21
字體:
來源:轉載
供稿:網友

HTML5 canvas 元素詳細教程一基本用法。

<canvas>是Html5中一個全新的元素,它可以被JavaScript語言用來繪制圖形。最先<canvas>是在蘋果公司的Mac OS X Dashboard上被引入,他被應用于Safari,而后基于Gecko1.8的瀏覽器,也支持這個新的元素,例如Firefox瀏覽器。如今,<canvas>元素已是HTML5標準規范的一部分。

<canvas>能做什么,我們都將通過本教程向大家講解,并且可以作為你應用<canvas>的起點。學習<canvas>元素并不困難,只需要具有HTML和JavaScript的基礎知識,還要Firefox瀏覽器,Safari最新版或者Opera9+,這樣才能看到所有的示例效果。

現在我們就從如何定義<canvas>元素開始吧。

<canvas id="tutorial" width="150" height="150"></canvas>

<canvas>元素只有兩個屬性Width和Height,這些屬性都是可選的,并且可以使用DOM或css來控制。如果不設置width和height,則使用默認的寬300像素,高150像素。雖然可以通過css來控制和調整<canvas>的大小,但是渲染圖像會進行縮放來適應布局,一旦發現渲染結果看上去變形,不必非要依賴css,你可以通過在<canvas>中顯示的指定width和height的值。就像標準的HTML標簽一樣,也可以定義id屬性,這樣可以使得腳本應用更加方便。<canvas>元素可以像普通圖片一樣指定其樣式(邊距,邊框,背景等等)。然而這些樣式并不會對canvas實際生成的圖像產生什么影響。

因為該元素相對較新,并不是所有的瀏覽器都支持該元素,所我們要為那些不能正常瀏覽的提供替用的顯示信息,它可以使用文本也可以使用圖片:

  1. <canvas id="stockGraph" width="150" height="150"> 
  2.   您的瀏覽器不支持<canvas>元素。 
  3. </canvas> 
  4. <canvas id="clock" width="150" height="150"> 
  5.   <img src="images.png" width="150" height="150" alt="替換圖片"/> 
  6. </canvas> 

在Apple Safari里,<canvas>的實現跟<img>很相似,它沒有結束標簽。然而,為了使<canvas> 能在web的世界里廣泛適用,需要給替用內容提供一個容身之所,因此,在Mozilla的實現里結束標簽(</canvas>)是必須的。如果沒有替用內容,<canvas id="foo" ...></canvas> 對Safari 和Mozilla 是完全兼容的——Safari 會簡單地忽略結束標簽。如果有替用內容,那么可以用一些CSS 技巧來為并且僅為Safari 隱藏替用內容,因為那些替用內容是需要在IE 里顯示但不需要在Safari 里顯示。

<canvas> 創建的固定尺寸的繪圖畫面開放了一個或多個渲染上下文,通過它們可以來控制要顯示的內容。我們專注于2D 渲染上,這也是目前唯一的選擇,可能在將來會添加基于OpenGL ES 的3D渲染。

  1. var canvas = document.getElementById('tutorial'); 
  2. var ctx = canvas.getContext('2d'); 

 

我們來講解下上面的代碼,<canvas> 初始化是空白的,要使用腳本畫圖首先需要渲染上下文(rendering context),它可以通過canvas元素對象的getContext方法來獲取,同時得到的還有一些畫圖需要調用的函數。getContext() 接受一個用于描述其類型的值作為參數。上面第一行通過getElementById 方法取得canvas 對象的DOM 節點。然后通過其getContext 方法取得其畫圖操作上下文。并且我們還可以使用腳本的方式判斷瀏覽器對<canvas>的支持,即判斷getContext是否存在。

  1. var canvas = document.getElementById('tutorial'); 
  2. if (canvas.getContext){ 
  3.   var ctx = canvas.getContext('2d'); 
  4.   // drawing code here 
  5. } else { 
  6.   // canvas-unsupported code here 

我們用下面最簡單的模板作為開始,你可以復制他們到本地備用。

  1. <html> 
  2.   <head> 
  3.     <title>Canvas tutorial</title> 
  4.     <script type="text/javascript"> 
  5.       function draw(){ 
  6.         var canvas = document.getElementById('tutorial'); 
  7.         if (canvas.getContext){ 
  8.           var ctx = canvas.getContext('2d'); 
  9.         } 
  10.       } 
  11.     </script> 
  12.     <style type="text/css"> 
  13.       canvas { border: 1px solid black; } 
  14.     </style> 
  15.   </head> 
  16.   <body onload="draw();"> 
  17.     <canvas id="tutorial" width="150" height="150"></canvas> 
  18.   </body> 
  19. </html> 

細心的你會發現一個名為draw 的函數,它會在頁面裝載完畢之后執行一次(通過設置body 標簽的onload 屬性),它當然也可以在setTimeout,setInterval,或者其他事件處理函數中被調用。

作為開始,來一個簡單的吧——繪制兩個交錯的矩形,其中一個是有alpha透明效果。我們會在后面的示例中詳細的讓你了解它是如何運作的。

  1. <html> 
  2. <head> 
  3. <script type="application/x-javascript"
  4. function draw() { 
  5. var canvas = document.getElementById("canvas"); 
  6. if (canvas.getContext) { 
  7. var ctx = canvas.getContext("2d"); 
  8. ctx.fillStyle = "rgb(200,0,0)"
  9. ctx.fillRect (10, 10, 55, 50); 
  10. ctx.fillStyle = "rgba(0, 0, 200, 0.5)"
  11. ctx.fillRect (30, 30, 55, 50); 
  12. </script> 
  13. </head> 
  14. <body onload="draw();"
  15. <canvas id="canvas" width="150" height="150"></canvas> 
  16. </body> 
  17. </html> 

您可以復制上面的代碼到HTML文件運行,效果圖:

/

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧日韩不卡在线视频| 91热福利电影| 精品在线小视频| 国产成人精品久久二区二区| 亚洲男人天堂网站| 欧美另类极品videosbestfree| 国产欧美精品va在线观看| 国产精品日韩欧美大师| 日韩中文字幕网| 最近2019年好看中文字幕视频| 91免费精品视频| 亚洲国产欧美一区二区三区久久| 狠狠躁夜夜躁人人爽超碰91| 日韩av免费在线观看| 国产精品国产三级国产aⅴ浪潮| 亚洲精品久久久久久久久久久久| 国产成人一区二区三区小说| 欧美激情影音先锋| 欧美成人精品在线| 91视频国产一区| 亚洲午夜久久久影院| 菠萝蜜影院一区二区免费| 久久亚洲精品小早川怜子66| 日韩av综合网| 91日韩在线播放| 日韩电影中文字幕av| 亚洲精品日韩欧美| 97国产真实伦对白精彩视频8| 欧美人成在线视频| 国产99久久精品一区二区 夜夜躁日日躁| 国产自摸综合网| 国产精品一久久香蕉国产线看观看| 亚洲精品国产精品国自产在线| 国产精品7m视频| 欧美精品制服第一页| 日韩精品中文字幕视频在线| 成人欧美一区二区三区在线| 欧美精品18videos性欧美| 国产精品羞羞答答| 国产999在线| 久久精品一偷一偷国产| 欧美日韩激情视频8区| 欧美xxxx18国产| 欧美成人三级视频网站| 亚洲午夜女主播在线直播| 亚洲第一天堂无码专区| 成年无码av片在线| 欧美国产精品va在线观看| 亚洲片在线资源| 亚洲jizzjizz日本少妇| 欧美在线一区二区视频| 国内精品久久久久久影视8| 国产欧美一区二区三区四区| 欧美大胆在线视频| 91精品视频大全| 日韩av网址在线| 欧美性猛交xxxx富婆弯腰| 久久综合免费视频影院| 伦伦影院午夜日韩欧美限制| 日本精品视频网站| 97精品久久久| 亚洲天堂男人天堂| 中文字幕亚洲情99在线| 国产精品视频免费观看www| 久久久久成人精品| 国内外成人免费激情在线视频| 成人免费网站在线| 欧美日韩在线观看视频小说| 久久手机精品视频| 不卡av日日日| 精品毛片三在线观看| 欧美黑人巨大精品一区二区| 成人亚洲激情网| 亚洲欧美综合精品久久成人| 成人h视频在线| 久久久久久亚洲精品| 国产成人一区二区三区小说| 国产精品久久久久久搜索| 91网在线免费观看| 欧美日韩国产在线| 国产精品免费一区二区三区都可以| 国产精品自拍视频| 久久人人爽人人| 国产成人鲁鲁免费视频a| 亚洲激情免费观看| 国产成人综合一区二区三区| 欧美性做爰毛片| 亚洲一区二区三区视频| 欧美黑人xxx| 欧美成人精品在线播放| 欧美整片在线观看| 亚洲日本欧美中文幕| 亚洲最大在线视频| 欧美成人免费一级人片100| 国产视频精品免费播放| 欧美成在线视频| 亚洲激情视频在线播放| 色多多国产成人永久免费网站| 性色av一区二区三区| 国产精品电影观看| 日本久久久久久久久| 精品国产一区二区三区久久久狼| 性亚洲最疯狂xxxx高清| 国产亚洲欧洲高清| 欧美福利小视频| 91精品国产自产91精品| 情事1991在线| 人人爽久久涩噜噜噜网站| 91免费福利视频| 51视频国产精品一区二区| 亚洲国产女人aaa毛片在线| 一本色道久久综合狠狠躁篇怎么玩| 欧美在线精品免播放器视频| 2019最新中文字幕| 98精品国产高清在线xxxx天堂| 91极品女神在线| 国产精品第3页| 国产精品美乳一区二区免费| 亚洲一区二区三区四区视频| 狠狠久久亚洲欧美专区| 国内外成人免费激情在线视频| 国产精品丝袜一区二区三区| 中文字幕日韩精品有码视频| 欧美在线观看一区二区三区| 一区二区三区高清国产| 国产精品久久婷婷六月丁香| 欧美激情亚洲激情| 精品久久久香蕉免费精品视频| 91精品视频网站| 欧美电影免费观看大全| 国产狼人综合免费视频| 精品久久久久久久久久久久久久| 成人国产亚洲精品a区天堂华泰| 91国产视频在线播放| 日本国产高清不卡| 国产黑人绿帽在线第一区| 91性高湖久久久久久久久_久久99| 日韩视频免费看| 日韩在线观看网站| 亚洲精品视频久久| 欧美丰满少妇xxxxx| 亚洲xxx大片| 亚洲欧美中文在线视频| 国产成人激情视频| 亚洲人精选亚洲人成在线| 国产亚洲精品久久久| 国产成人自拍视频在线观看| 久久亚洲国产精品| 97欧美精品一区二区三区| 亚洲第一免费播放区| 国产精品扒开腿做爽爽爽男男| 亚洲全黄一级网站| 久久精品男人天堂| 亚洲片国产一区一级在线观看| 色偷偷偷亚洲综合网另类| 欧美疯狂做受xxxx高潮| 亚洲精品久久久久久久久久久久久| 欧美成人在线影院| 亚洲第一男人天堂| 亚洲香蕉成人av网站在线观看| 亚洲欧美日韩精品久久奇米色影视| www.日韩系列| 亚洲第一男人天堂| 欧美精品videosex极品1|