HTML5新增了一個(gè)元素canvas,用于繪圖使用,其實(shí)它的表現(xiàn)和div比較接近(其實(shí)他應(yīng)該屬于inline-block),而提供了許多接口,從而輕易的繪制矩形框、園三角形等
PS:關(guān)于HTML5新增元素
經(jīng)過最近兩天的學(xué)習(xí),和以前對HTML5的認(rèn)知,我認(rèn)為HTML5其實(shí)還是HTML4,兩者之間沒多大的區(qū)別,無非是增加了點(diǎn)新東西。
我認(rèn)為HTML5為我們帶來的真正意義是:我們可以用javascript做更多的事情了;我們可以用javascript實(shí)現(xiàn)更好的產(chǎn)品了。比如HTML5就解決了我們頭疼的跨域問題、實(shí)時(shí)通信API、與現(xiàn)在的canvas之所以HTML5叫HTML5,我認(rèn)為他是劃時(shí)代的,比如他讓我們用網(wǎng)頁開發(fā)游戲變成可能;比如他讓電腦桌面只剩IE不在是傳說(過于夸張)
可以看到,對于canvas來說,還是老老實(shí)實(shí)定義高寬的好,別去傻乎乎的用樣式了,當(dāng)然這個(gè)問題需要實(shí)際研究才能得出最終結(jié)論。
PS:其實(shí),使用該方法這么麻煩,完全可以將該函數(shù)封裝下下,使用便會(huì)簡單許多
1、使用getElementById方法獲取繪制對象2、取得上下文getContext('2d'),這都是固定的寫法3、指定填充的顏色fillStyle和繪制的顏色strokeStyle,即里面的顏色和邊框的顏色4、指定線寬linewidth5、填充/繪制 fillRect/strokeRect 參數(shù)為 x,y,width,height6、若是要使其中一塊透明,使用clearRect
arc方法參數(shù)很多,依次是:xy半徑開始弧度(我們一般喜歡角度,所以要轉(zhuǎn)換)結(jié)束弧度順時(shí)針或者逆時(shí)針true為順時(shí)針
其它都好說,主要這個(gè)開始角度和結(jié)束角度我們來研究下,因?yàn)殚_始我沒搞懂,但后來我發(fā)現(xiàn)他其實(shí)很簡單了。。。就是開始的角度和結(jié)束的角度嘛,和我們高中學(xué)的知識(shí)一樣的,只不過單位換算Math.PI/180為一度。。。。
反正還是沒說清楚,對了,記得我們高中畫圓的除了圓規(guī)和一個(gè)計(jì)量三角形角度的半圓直尺了嗎,我要說的角度就是那個(gè)。。。太坑爹了!
好像最右邊是0度,垂直是90度,水平是180度,既然如此,我們再來看看
正時(shí)針逆時(shí)針
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//獲取canvas對象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 400, 300); //填充畫布結(jié)束
context.beginPath();
context.arc(80, 80, 50, 0, 180 * Math.PI / 180, true);
context.closePath();
context.fillStyle = 'gray';
context.fill();
context.beginPath();
context.arc(180, 180, 50, 0, 180 * Math.PI / 180, false);
context.closePath();
context.fillStyle = 'gray';
context.fill();
}
</script>
</head>
<body>
<canvas id="canvas" width="400" height="300">
</canvas>
<button onclick="draw();">
繪制圓</button>
<input type="color" />
</body>
</html>

我們發(fā)現(xiàn)正時(shí)針與逆時(shí)針還是有所不同的,
context.arc(180, 180, 50, 90 * Math.PI / 180, 290 * Math.PI / 180, true);
原諒我這里居然思考了半個(gè)小時(shí),我甚至搜索了高中的資料。。。。


于是我好像明白了點(diǎn)什么。。。。。。
moveTo與lineTo
現(xiàn)上實(shí)驗(yàn)結(jié)果:
兩次moveto
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//獲取canvas對象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 300, 200); //填充畫布結(jié)束
context.beginPath();
context.fillStyle = 'gray';
context.strokeStyle = 'black';
context.moveTo(10, 10);
context.lineTo(150, 150);
context.moveTo(10, 10);
context.lineTo(10, 150);
context.closePath();
context.fill();
context.stroke();
}
</script>
</head>
<body>
<canvas id="canvas" width="300" height="200">
</canvas>
<button onclick="draw();">
繪制</button>
<input type="color" />
</body>
</html>
一次moveto
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//獲取canvas對象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 300, 200); //填充畫布結(jié)束
context.beginPath();
context.fillStyle = 'gray';
context.strokeStyle = 'black';
context.moveTo(10, 10);
context.lineTo(150, 150);
// context.moveTo(10, 10);
context.lineTo(10, 150);
context.closePath();
context.fill();
context.stroke();
}
</script>
</head>
<body>
<canvas id="canvas" width="300" height="200">
</canvas>
<button onclick="draw();">
繪制</button>
<input type="color" />
</body>
</html>
三次moveto
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//獲取canvas對象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 300, 200); //填充畫布結(jié)束
context.beginPath();
context.fillStyle = 'gray';
context.strokeStyle = 'black';
context.moveTo(10, 10);
context.lineTo(150, 150);
context.moveTo(10, 10);
context.lineTo(10, 150);
context.moveTo(10, 150);
context.lineTo(150, 150);
context.closePath();
context.fill();
context.stroke();
}
</script>
</head>
<body>
<canvas id="canvas" width="300" height="200">
</canvas>
<button onclick="draw();">
繪制</button>
<input type="color" />
</body>
</html>
以上代碼幾乎一樣,但是他產(chǎn)生的結(jié)果卻不同:

我認(rèn)為,使用moveto后相當(dāng)于新開一起點(diǎn),之前的一筆勾銷,若是只使用lineto的話,他會(huì)將幾個(gè)點(diǎn)連成線,若是可以組成圖形便會(huì)擁有中間色彩