(1)、什么是画布
HTML5<canvas>元素用于图形的绘制,通过脚本(通常是JavaScript)来完成。
<canvas>标签只是图形容器,必须使用脚本来绘制图形。你以通过多种方法使用canvas绘制路径,盒、圆、字符以及添加图像。
(2)、创建一个画布(Canvas)
一个画布在网页中是一个矩形框,通过<canvas>元素来绘制。注意:默认情况下<canvas>元素没有边框和内容。<canvas>简单实例如下:
<canvas id="myCanvas"width="200"height="100"></canvas>
注意:标签通常需要指定一个id属性(脚本中经常引用),width和height属性定义的画布的大小。提示:你可以在HTML页面中使用多个<canvas>元素。使用style属性来添加边框:
<canvas id="myCanvas"width="200"height="100"
style="border:1pxsolid#000000;">
</canvas>
(3)、使用JavaScript来绘制图像
canvas元素本身是没有绘图能力的。所有的绘制工作必须在JavaScript内部完
成:
Var c=document.getElementById("myCanvas");//获取画布元素
Va rctx=c.getContext("2d"); getContext("2d") 使用2d页面 对象是内建的HTML5对象,拥有多种绘制路径、矩形、圆形、字/符以及添加图像的方法
Fill 永远填充
ctx.fillStyle="#FF0000";设置fillStyle属性 设置样式 可以是CSS颜色,渐变,或图案。fillStyle默认设置是#000000(黑色)。
ctx.fillRect(0,0,150,75); 方法定义了矩形当前的填充方式
fillRect(x轴,y轴,宽,高) x y 轴坐标是左上角相对页面的位置
(4)、Canvas-路径(线条)
moveTo(x,y)定义线条开始
lineTo(x,y)定义线条结束坐标,
stroke 画线
strokeStyle属性定义线条的颜色 默认是黑色的,绘制线条我们必须使用到"ink"的方法,就像stroke()。
(6)、Canvas-圆
在canvas中绘制圆形,我们将使用以下方法:
arc(x,y,r,start,stop)
参数描述
x圆的中心的x坐标。
y圆的中心的y坐标。
r圆的半径。
start起始角,以弧度计。(弧的圆形的三点钟位置是0度)。
stop结束角,以弧度计。
方向 Ture(逆时针)或false(顺时针) 圆是顺时针还是逆时针 默认是false
例子:
varc=document.getElementById("myCanvas");
varctx=c.getContext("2d");
tai1.beginPath();
//边的宽度
ctx.lineWidth=5;
//边的颜色
ctx.strokeStyle="red";
//填充的颜色
ctx.fillStyle="yellow";
ctx.fill();
ctx.arc(95,50,40,0,2*Math.PI);
ctx.stroke();
(7)、Canvas-文本
font-定义字体,fillText(text,x,y)
-在canvas上绘制实心的文本,strokeText(text,x,y)-在canvas上绘制空心的文本。使用"Arial"字体在画布上绘制一个高30px的文字(实心):
例如:
varc=document.getElementById("myCanvas");
varctx=c.getContext("2d");
ctx.font="30pxArial";
//字体的颜色
ctx.fillStyle="red";
ctx.fillText("HelloWorld",10,50);
(8)、Canvas-渐变
渐变可以填充在矩形,圆形,线条,文本等等,各种形状可以自己定义不同的颜色。
置Canvas渐变:
createLinearGradient(x,y,x1,y1)-创建线条渐变,
createRadialGradient(x,y,r,x1,y1,r1)-创建一个径向/圆渐变,
x0 | 渐变的开始圆的 x 坐标 |
y0 | 渐变的开始圆的 y 坐标 |
r0 | 开始圆的半径 |
x1 | 渐变的结束圆的 x 坐标 |
y1 | 渐变的结束圆的 y 坐标 |
r1 | 结束圆的半径 |
当我们使用渐变对象addColorStop()方法指定颜色停止,参数使用坐标来描述,可以是0至1. 如:grad.addColorStop(0, "red");
grad.addColorStop(0.5, "blue");
grad.addColorStop(1, "green");
使用渐变,设置fillStyle(即 ctx.fillStyle=grad)或strokeStyle的值为渐变,然后绘制形状,如矩形,文本,或一条线。