什么是Canvas
<canvas>是 HTML5 新增的元素,可使用JavaScript脚本来绘制图形。
canvas是一个矩形区域,您可以控制其每一像素。
引入Canvas
```html
<canvas id="canvas" width="300" height="300"></canvas>
```

`<canvas>` 看起来和 `<img>` 元素很相像,唯一的不同就是它并没有 `src` 和 `alt` 属性。实际上,`<canvas>` 标签只有两个属性—— `width` 和 `height`,并且这些属性都是可选的。

width 和 height 属性
当没有设置宽度和高度的时候,`canvas` 会初始化宽度为300像素和高度为150像素。该元素可以使用CSS来定义大小,但在绘制时图像会伸缩以适应它的框架尺寸:如果CSS的尺寸与初始画布的比例不一致,它会出现扭曲。

*注意*: 如果你绘制出来的图像是扭曲的, 尝试在<canvas>的属性中明确规定宽和高,而不是使用CSS。

兼容性
某些较老的浏览器(尤其是IE9之前的IE浏览器)或者文本浏览器不支持HTML元素"canvas",在这些浏览器上会把`<canvas>`标签内部的内容显示出来,因此我们可以在这些不支持`<canvas>`的浏览器上提供一些替代内容,而支持`<canvas>`的浏览器将会忽略在容器中包含的内容,并且只是正常渲染canvas。
```html
<canvas id="myCanvas" width="150" height="150">
  如果您的浏览器不支持Canvas,那么您将看到本行文字
</canvas>
```
</canvas> 标签不可省
与 `<img>` 元素不同,`<canvas>` 元素需要结束标签(`</canvas>`).如果结束标签不存在,则文档的其余部分会被认为是替代内容,将不会显示出来。

获取绘图上下文(the rendering context)
canvas起初是空白的.如果想要对canvas进行一些操作,那么则需要获取canvas的绘图上下文对象。`<canvas>` 元素有一个做 `getContext()` 的方法,这个方法是用来获得渲染上下文和它的绘画功能。`getContext()`只有一个参数,上下文的格式.对于2D图像而言,这个格式参数是`"2d"`。

```javascript
var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');
```

如果在不支持`<canvas>`的浏览器中运行了上述代码,会抛出一个错误.所以在我们获取绘图上下文对象之前,应该先检查一下浏览器对该特性的支持情况。
```javascript
var canvas = document.getElementById('tutorial');
if (canvas.getContext){
  var ctx = canvas.getContext('2d');
  // drawing code here
} else {
  // canvas-unsupported code here
}
```

基本绘图操作
和Windows操作系统自带的画图程序一样,`Canvas`的两种基本绘图操作是填充和描边。填充,就是用指定的样式(颜色、渐变或图像)填充图形;描边,就是只在图形的边缘画线。填充和描边的样式分别取决于两个属性:`fillStyle`和`strokeStyle`。这两个属性的值可以是字符串、渐变对象或模式对象,而且它们的默认值都是`"#000000"`。如果为它们指定表示颜色的字符串值,可以使用 CSS 中指定颜色值的任何格式,包括颜色名、十六进制码、 rgb、rgba、hsl 或 hsla。

 绘制矩形
矩形是唯一一种可以直接在 2D 上下文中绘制的形状.与矩形有关的方法包括 `fillRect()`、 `strokeRect()` 和 `clearRect()`。这三个方法都能接收 4 个参数:矩形的 x 坐标、矩形的 y 坐标、矩形宽度和矩形高度。这些参数的单位都是像素。

填充矩形
`fillRect(x, y, width, height)`

绘制矩形描边
`strokeRect(x, y, width, height)`

清除矩形
该方法的功能类似于Windows系统中画图程序的橡皮擦,会将指定矩形矩形区域中的所有内容全部清除。

`clearRect(x, y, width, height)`

绘制路径
如果要绘制矩形以外的形状,则需要自定义绘制路径。2D 绘制上下文支持很多在画布上绘制路径的方法。要绘制路径,首先必须调用 beginPath()方法,表示要开始绘制新路径。然后,再通过调用下列方法来实际地绘制路径。

`arc(x, y, radius, startAngle, endAngle, counterclockwise)`

> 以`(x,y)`为圆心绘 制一条弧线,弧线半径为 `radius`,起始和结束角度(用弧度表示)分别为 `startAngle` 和 `endAngle`。最后一个参数表示 `startAngle` 和 `endAngle` 是否按逆时针方向计算,值为 `false` 表示按顺时针方向计算。

 `arcTo(x1, y1, x2, y2, radius)`
> 从上一点开始绘制一条弧线,到`(x2,y2)`为止,并且以 给定的半径 `radius` 穿过`(x1,y1)`。

`lineTo(x, y)`
> 从上一点开始绘制一条直线,到`(x,y)`为止。

 `moveTo(x, y)`
> 将绘图游标移动到`(x,y)`,不画线。

`rect(x, y, width, height)`
> 从点`(x,y)`开始绘制一个矩形,宽度和高度分别由 `width` 和 `height` 指定。这个方法绘制的是矩形路径,而不是 `strokeRect()` 和 `fillRect()` 所绘制的独立的形状。

创建了路径后,接下来有几种可能的选择。如果想绘制一条连接到路径起点的线条,可以调用 `closePath()`。如果路径已经完成,你想用 `fillStyle` 填充它,可以调用 `fill()` 方法。另外,还可 以调用 `stroke()` 方法对路径描边,描边使用的是 `strokeStyle`。最后还可以调用 `clip()`,这个方法可以在路径上创建一个剪切区域。

绘制一个简易时钟

```javascript
var canvas = document.getElementById("canvas");
//确定浏览器支持元素
if (canvas.getContext){
	var context = canvas.getContext("2d");

	//开始路径
	context.beginPath();

	//绘制外圆
	context.arc(100, 100, 99, 0, 2 * Math.PI, false);

	//绘制内圆
	context.moveTo(194, 100);
	context.arc(100, 100, 94, 0, 2 * Math.PI, false);

	//绘制分针
	context.moveTo(100, 100);
	context.lineTo(100, 15);

	//绘制时针
	context.moveTo(100, 100);
	context.lineTo(35, 100);

	//描边路径
	context.stroke();
}
```

绘制文本
绘制文本主要有两个方法:`fillText()` 和 `strokeText()`。这两个方法都可以接收 4 个参数:要绘制的文本字符串、`x` 坐标、`y` 坐标和可选的最大像素宽度。

而绘制出来文本的样式,由下面3个属性决定:

font`
> 表示文本样式、大小及字体,用 CSS 中指定字体的格式来指定,例如`"10px Arial"`。

textAlign`
> 表示文本对齐方式。可能的值有 `"start"`、`"end"`、`"left"`、`"right"` 和 `"center"`。建议使用 `"start"` 和 `"end"`,不要使用 `"left"` 和 `"right"`,因为前两者的意思更稳妥,能同时适合从左到右和从右到左显示(阅读)的语言。

textBaseline`
> 表示文本的基线。可能的值有 `"top"`、`"hanging"`、`"middle"`、`"alphabetic"`、 `"ideographic"` 和 `"bottom"`。

```javascript
context.font = 'bold 14px Arial';
context.textAlign = 'center';
context.textBaseline = 'middle';
context.fillText('hello, world', 100, 100);
```

初探Javascript之Canvas的更多相关文章

  1. 使用 JavaScript 和 canvas 做精确的像素碰撞检测

    原文地址:Pixel accurate collision detection with Javascript and Canvas 译者:nzbin 我正在开发一个需要再次使用碰撞检测的游戏.我通常 ...

  2. javascript的canvas绘图的基本用法

    <canvas>是HTML里面非常强大的元素,利用它结合js可以实现很多动画效果,大大增强交互性.下面,我想用图文并茂的方式阐述一下canvas的绘图机制的基础内容,话不多说,先上代码: ...

  3. 使用javascript和canvas画月半弯

    使用javascript和canvas画月半弯,月半弯好浪漫!浏览器须支持html5 查看效果:http://keleyi.com/a/bjad/8xqdm0r2.htm 以下是代码: <!do ...

  4. 初探JavaScript(四)——作用域链和声明提前

    前言:最近恰逢毕业季,千千万万的学生党开始步入社会,告别象牙塔似的学校生活.往往在人生的各个拐点的时候,情感丰富,感触颇深,各种对过去的美好的总结,对未来的展望.与此同时,也让诸多的老“园”工看完这些 ...

  5. 初探JavaScript(三)——JS带我"碰壁"带我飞

    已经写了两篇关于小白的JavaScript之行,不可否认,每一种语言都有其精华与糟粕之处,来不及细细体味其精华奥妙,也没法对其评头论足,只能先了解,后深入.到目前为止已经看完<JavaScrip ...

  6. 初探JavaScript(二)——JS如何动态操控HTML

    除去五一三天,我已经和<JavaScript Dom编程艺术>磨合了六天,第一印象很好.慢慢的,我发现这是一块排骨,除了肉还有骨头.遇到不解的地方就会多看几遍,实在不懂的先跳过,毕竟,初次 ...

  7. 初探JavaScript(一)——也谈元素节点、属性节点、文本节点

    Javascript大行其道的时候,怎么能少了我来凑凑热闹^_^ 基本上自己对于js的知识储备很少,先前有用过JQuery实现一些简单功能,要论起JS的前世今生,来龙去脉,我就一小白.抱起一本< ...

  8. JavaScript之canvas

    num.push(x,y); 动画草图(举个栗子,我们把数字“2”给画出来): <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transit ...

  9. 每天一个JavaScript实例-canvas绘图

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

随机推荐

  1. 数据库MySQL、redis主从切换shell脚本

    具体源码可找我领取

  2. c++ --> 变量、常量与运算符

    变量.常量与运算符   一.什么是变量?    在计算机的内存中, 内存被划分为一个一个的内存单元, 每个内存单元有自己的编号, 而变量就是对某一段连续内存单元使用一些更容易记忆.更容易区分的字符组合 ...

  3. Algorithm --> 最长公共子序列(LCS)

      一.什么是最长公共子序列     什么是最长公共子序列呢?举个简单的例子吧,一个数列S,若分别是两个或多个已知序列的子序列,且是所有符合条件序列中最长的,则S称为已知序列的最长公共子序列. 举例如 ...

  4. 浅谈 JSON.stringify 方法

    一.前言 最近项目中,遇到需要将对象转换成字符串进行传递,上次写过一篇文章关于json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值.当时主要是用在有时候处理字符串和 ...

  5. Flashing Back a Failed Primary Database into a Physical Standby Database(闪回FAILOVER失败的物理备库)

    文档操作依据来自官方网址:https://docs.oracle.com/cd/E11882_01/server.112/e41134/scenarios.htm#SBYDB4888 闪回FAILOV ...

  6. linux设置代理修改接口数据

    其实很简单,希望看到的人可以一次搞定,所以我把所有步骤写一块儿了. 1.首先在自己能上网的机器上安装fiddler,程序自己百度搜就可以,百度软件中心的程序就行. 2.安装fiddler后,管理员权限 ...

  7. 敏捷冲刺每日报告三(Java-Team)

    第三天报告(10.27  周五) 团队:Java-Team 成员: 章辉宇(284) 吴政楠(286) 陈阳(PM:288) 韩华颂(142) 胡志权(143) github地址:https://gi ...

  8. python的测试

    测试 知识点 单元测试概念 使用 unittest 模块 测试用例的编写 异常测试 测试覆盖率概念 使用 coverage 模块 实验步骤 1. 应该测试什么? 如果可能的话,代码库中的所有代码都要测 ...

  9. Linux 目录与文件管理

    1. 目录与路径1.1 相对路径与绝对路径1.2 目录的相关操作: cd, pwd, mkdir, rmdir1.3 关于执行文件路径的变量: $PATH2. 档案与目录管理2.1 档案与目录的检视: ...

  10. Mybatis的mapper代理开发dao方法

    看完了之前的mybatis原始的dao开发方法是不是觉得有点笨重,甚至说没有发挥mybatis 作为一个框架的优势.总结了一下,原始的dao方法有以下几点不足之处 dao接口实现方法中存在大量的模板方 ...