canvas 元素使用 JavaScript 在網頁上繪製圖像,本身是沒有繪圖能力。 canvas 是一個矩形區域,可以控制其每一像素。 canvas 擁有多種繪製路徑、矩形、圓形、字元以及添加圖像的方法。 下麵來做幾個示例: 1、填充畫布 <canvas id="myCanvas" width="
canvas 元素使用 JavaScript 在網頁上繪製圖像,本身是沒有繪圖能力。
canvas 是一個矩形區域,可以控制其每一像素。
canvas 擁有多種繪製路徑、矩形、圓形、字元以及添加圖像的方法。
下麵來做幾個示例:
1、填充畫布
<canvas id="myCanvas" width="200" height="100" style="border:1px solid red;"></canvas>
<script type="text/javascript">
var c=document.getElementById("myCanvas");
var cxt=c.getContext("2d");
cxt.fillStyle="#ccc";
cxt.fillRect(5,10,150,60); //x,y,x,y
</script>
執行如下:
2、獲取坐標
<script type="text/javascript">
function cnvs_getCoordinates(e){
x=e.clientX;
y=e.clientY;
document.getElementById("xycoordinates").innerHTML="Coordinates: (" + x + "," + y + ")"; }
function cnvs_clearCoordinates(){
document.getElementById("xycoordinates").innerHTML="";}
</script>
<div id="coordiv" style="float:left;width:199px;height:99px;border:1px solid #c3c3c3" onmousemove="cnvs_getCoordinates(event)" onmouseout="cnvs_clearCoordinates()"></div>
<div id="xycoordinates"></div>
執行如下:
3、繪製線條、圖形
1繪製正方形如下:
<canvas id="myCanvas" width="200" height="100" style="border:1px solid #c3c3c3;">
您的瀏覽器不支持 canvas 標簽.
</canvas>
<script type="text/javascript">
var c=document.getElementById("myCanvas");
var cxt=c.getContext("2d");
cxt.moveTo(10,10); //x,y 起點
cxt.lineTo(10,50); //x,y
cxt.lineTo(50,50); //x,y
cxt.lineTo(50,10); //x,y
cxt.lineTo(10,10); //x,y
cxt.stroke();
</script>
執行如下
2繪製圓形如下:
<canvas id="myCanvas" width="200" height="100" style="border:1px solid #c3c3c3;">
你的瀏覽器不支持canvas
</canvas>
<script type="text/javascript">
var c=document.getElementById("myCanvas");
var cxt=c.getContext("2d");
cxt.fillStyle="#ccc";
cxt.beginPath();
cxt.arc(20,20,10,0,Math.PI*2,true);
cxt.closePath();
cxt.fill();
</script>
執行如下:
4、繪製漸變
<canvas id="myCanvas" width="200" height="100" style="border:1px solid #c3c3c3;">
您的瀏覽器不支持 canvas 標簽.
</canvas>
<script type="text/javascript">
var c=document.getElementById("myCanvas");
var cxt=c.getContext("2d");
var grd=cxt.createLinearGradient(0,0,175,50);
grd.addColorStop(0,"#000000"); //黑
grd.addColorStop(1,"#FFFFFF"); //白
cxt.fillStyle=grd;
cxt.fillRect(5,10,175,50);//x,y,x,y
</script>
執行如下:
5、圖片
<canvas id="myCanvas" width="300" height="200" style="border:1px solid #c3c3c3;">
您的瀏覽器不支持 canvas 標簽.
</canvas>
<script type="text/javascript">
var c=document.getElementById("myCanvas");
var cxt=c.getContext("2d");
var img=new Image()
img.src="aa.png"
cxt.drawImage(img,10,20); //x,y
</script>
執行如下: