(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的值为渐变,然后绘制形状,如矩形,文本,或一条线。

 posted on 2020-08-18 21:44  wen22  阅读(214)  评论(0编辑  收藏  举报