利用HTML5中的Canvas繪制一張笑臉的教程

今天,你將學(xué)習(xí)一項(xiàng)稱為Canvas(畫布)的web技術(shù),以及它和文檔對(duì)象模型(通常被稱為DOM)的關(guān)聯(lián)。這項(xiàng)技術(shù)非常強(qiáng)大,因?yàn)樗箇eb開發(fā)人員能夠通過使用JavaScript訪問和修改HTML元素。
現(xiàn)在你可能想知道為什么我們需要大刀闊斧地使用JavaScript。簡而言之,HTML和JavaScript是相互依存的,一些HTML組件,如canvas元素,并不能脫離JavaScript單獨(dú)使用。畢竟,如果我們不能在上面繪圖,那canvas能派什么用處呢?
為了更好地理解這個(gè)概念,我們一起通過一個(gè)示例項(xiàng)目來嘗試畫一個(gè)簡單的笑臉。讓我們開始吧。
開始
首先創(chuàng)建一個(gè)新目錄來保存你的項(xiàng)目文件,然后打開你最喜歡的文本編輯器或web開發(fā)工具。一旦你這樣做了,你應(yīng)該創(chuàng)建一個(gè)空的index.html和一個(gè)空的script.js,之后我們將繼續(xù)編輯。
接下來,我們來修改index.html文件,這不會(huì)涉及很多東西,因?yàn)槲覀冺?xiàng)目的大部分代碼將用JavaScript編寫。我們需要在HTML中做的是創(chuàng)建一個(gè)canvas元素和引用script.js,這相當(dāng)直截了當(dāng):
- <!DOCTYPE html><body>
- <canvas id='canvas' width='640' height='480'></canvas>
- <script type='text/javascript' src='script.js'></script>
- </body></html>
這么解釋,我使用一組標(biāo)記< html >和< body>,這樣,我們可以通過body為文檔添加更多的元素。抓住這個(gè)機(jī)會(huì),我完成了一個(gè)id屬性為canvas的640*480的canvas元素。
這個(gè)屬性只是簡單地為元素加上一個(gè)字符串,目的是為了唯一識(shí)別,稍后我們將利用這個(gè)屬性,在JavaScript文件中定位我們的canvas元素。接下來,我們?cè)偈褂?lt;script>標(biāo)記引用JavaScript文件,它指定JavaScript的語言類型和script.js文件的路徑。
操作DOM
如其名稱“文檔對(duì)象模型”,我們需要通過使用另一種語言,調(diào)用接口訪問HTML文檔,在這里,我們使用的語言是JavaScript。為此,我們需要在內(nèi)置文檔對(duì)象上的布置一個(gè)簡單引用。這個(gè)對(duì)象直接對(duì)應(yīng)于我們的< html >標(biāo)記,類似的,它是整個(gè)項(xiàng)目的基礎(chǔ),因?yàn)槲覀兛梢酝ㄟ^它來獲取元素,執(zhí)行變化。
- var canvas = document.getElementById('canvas');
還記得我們?nèi)绾问褂胕d =“canvas”來定義一個(gè)canvas元素嗎?現(xiàn)在我們使用document.getElementById方法,從HTML文檔獲取這個(gè)元素,我們簡單地傳遞匹配所需元素id的字符串。現(xiàn)在我們已經(jīng)獲取了這個(gè)元素,接下來就可以用其進(jìn)行繪畫工作了。
為了使用canvas進(jìn)行繪畫,我們必須操作它的上下文。令人驚訝的是,一個(gè)canvas不包含任何繪圖的方法或?qū)傩裕撬纳舷挛膶?duì)象有我們需要的所有方法。一個(gè)上下文定義如下所示:
- var context = canvas.getContext('2d');
每一個(gè)canvas有幾個(gè)不同的上下文,根據(jù)程序的目的,只需要一個(gè)二維的上下文就足夠了,它將獲得我們需要?jiǎng)?chuàng)建笑臉的所有繪圖方法。
在我們開始之前,我必須告知您,上下文存儲(chǔ)了兩種顏色屬性,一個(gè)用于畫筆(stroke),一個(gè)用于填充(fill)。對(duì)于我們的笑臉,需要設(shè)置填充為黃色,畫筆為黑色。
- context.fillStyle = 'yellow';
- context.strokeStyle = 'black';
設(shè)置完上下文所需的顏色后,我們必須為臉畫一個(gè)圓。不幸的是,上下文中沒有圓的預(yù)定義方法,因此我們需要使用所謂的路徑(path)。路徑只是一系列的相連的直線和曲線,路徑在繪圖完成后關(guān)閉。
- context.beginPath();
- context.arc(320, 240, 200, 0, 2 * Math.PI);
- context.fill();
- context.stroke();
- context.closePath();
這樣解釋,我們運(yùn)用上下文開始一個(gè)新的路徑。接下來,我們?cè)邳c(diǎn)(320、240)上創(chuàng)建一個(gè)半徑為200像素的圓弧。最后兩個(gè)參數(shù)指定構(gòu)建圓弧的初始和最終角度,所以我們傳遞0和2 *Math.PI,來創(chuàng)建一個(gè)完整的圓。最后,我們運(yùn)用上下文基于我們已經(jīng)設(shè)置的顏色進(jìn)行填充并畫出路徑。
盡管關(guān)閉路徑不是腳本的功能所必須的,但我們還是需要關(guān)閉路徑,這樣就可以開始繪制笑臉中新的眼睛和嘴。眼睛可以通過同樣的方式完成,每個(gè)眼睛需要較小的半徑和不同的位置。但首先我們必須記住設(shè)置填充顏色為白色。
- context.fillStyle = 'white';
- context.beginPath();
- context.arc(270, 175, 30, 0, 2 * Math.PI);
- context.fill();
- context.stroke();
- context.closePath();
- context.beginPath();
- context.arc(370, 175, 30, 0, 2 * Math.PI);
- context.fill();
- context.stroke();
- context.closePath();
以上是關(guān)于眼睛的所有代碼?,F(xiàn)在嘴巴很相似,但這次我們不會(huì)填滿圓弧,我們的角度將配置為一個(gè)半圓。要做到這一點(diǎn),我們需要設(shè)置起始角度為零和結(jié)束角度為-1 * Math.PI。請(qǐng)記住,不要忘記將畫筆的顏色設(shè)置為紅色。
- context.fillStyle = 'red';
- context.beginPath();
- context.arc(320, 240, 150, 0, -1 * Math.PI);
- context.fill()
- context.stroke();
- context.closePath();
祝賀
干的不錯(cuò)。你已經(jīng)完成了本教程,你做了一個(gè)很棒的笑臉,同時(shí)學(xué)習(xí)了更多關(guān)于Canvas、HTML、JavaScript,和文檔對(duì)象模型的知識(shí)。如果你有任何問題,請(qǐng)留言。
相關(guān)文章
HTML5通過調(diào)用canvas對(duì)象的getContext()方法來獲取繪圖環(huán)境
通過調(diào)用canvas對(duì)象的getContext()方法來獲取繪圖環(huán)境,其只需要一個(gè)參數(shù):繪圖環(huán)境的類型,下面通過實(shí)例為大家詳細(xì)介紹下2014-06-23html5之Canvas路徑繪圖、坐標(biāo)變換應(yīng)用實(shí)例
本文寫一個(gè)html5的時(shí)鐘應(yīng)用程序試手主要設(shè)置了坐標(biāo)變換的平移(translate)和旋轉(zhuǎn)變換(ratate),以及html5 Canvas的路徑繪圖,beginPath,closePath,rect,arc等多的也2012-12-26- 在html5中我覺得最重要的就是引入了Canvas,使得我們可以在web中繪制各種圖形,而Canvas為基于像素的繪圖。Canvas是一個(gè)相當(dāng)于畫板的html節(jié)點(diǎn),我們必須以js操作繪圖2012-12-26
HTML5 canvas標(biāo)簽實(shí)現(xiàn)刮刮卡效果
這篇文章主要介紹了HTML5 canvas標(biāo)簽實(shí)現(xiàn)刮刮卡效果,本文給出了運(yùn)行效果、HTML代碼和JS代碼,并給出了完整源碼下載,需要的朋友可以參考下2015-04-24- 這篇文章主要介紹了HTML5 Canvas的事件處理介紹,本文講解了Canvas的限制、給Canvas元素綁定事件、isPointInPath方法、循環(huán)重繪和事件冒泡等內(nèi)容,需要的朋友可以參考下2015-04-24
- 這篇文章主要介紹了HTML5 Canvas中繪制橢圓的4種方法,本文講解了參數(shù)方程法、均勻壓縮法、三次貝塞爾曲線法、光柵法等4種方法,需要的朋友可以參考下2015-04-24
一款基于HTML5+Canvas實(shí)現(xiàn)的圖片馬賽克模糊動(dòng)畫特效源碼
經(jīng)常可以在網(wǎng)上或者電視上看到被馬賽克模糊的圖片或者視頻,今天我們要利用HTML5 Canvas技術(shù)來實(shí)現(xiàn)圖片的馬賽克模糊效果2015-02-05HTML5基于Canvas實(shí)現(xiàn)的粒子人物頭像效果源碼
今天我們要再利用HTML5 Canvas實(shí)現(xiàn)一個(gè)粒子效果的人物頭像,你可以任意選擇一張頭像圖片,接下來該圖片會(huì)被打散成許多粒子2015-02-05HTML5基于Canvas實(shí)現(xiàn)的折線圖表和柱形圖表源碼
今天要分享的一款HTML5 Canvas圖表應(yīng)用提供了折線圖和柱形圖兩種,這款HTML5圖表在初始化數(shù)據(jù)的時(shí)候有一種漸現(xiàn)的動(dòng)畫特效,我們可以將這款圖表應(yīng)用在統(tǒng)計(jì)頁面上2015-01-20HTML5 Canvas繪制圓點(diǎn)虛線實(shí)例
這篇文章主要介紹了HTML5 Canvas繪制圓點(diǎn)虛線實(shí)例,HTML5并未提供畫虛線的方法,本文是根據(jù)Stack Overflow的方法修改而來,需要的朋友可以參考下2015-01-01