一、<canvas>标签

  Html5 引入了一个新的<canvas> 标签,这个标签所代表的区域就好象一块画布,你的所有图形绘制最后都要在这块画布上呈现。有了这个标签,浏览器的图形表现力被极大的提升,Flash 和 SilverLight 有没有感到威胁呢?

  <canvas>标签的用法非常简单,如下:

<canvas id="tutorial"width="150" height="150" style="">
你的浏览器不支持 Canvas 标签
</canvas>

  <canvas>标签和普通的 HTML 标签没有多大的区别,你可以设置它的宽度和高度,可以通过 CSS 设置它的背景色、边框样式等等。你可以在这里找到关于<canvas> 标签的更多内容。

  标签中间的内容是替换内容,如果用户的浏览器不支持<canvas> 标签,这段内容就会被显示出来;如果用户的浏览器支持<canvas> 标签,则这段内容将被忽略。

  上面的 <canvas> 代码显示效果如下:

你的浏览器不支持 Canvas 标签

  如果你用的是IE浏览器,可能只能看到一个提示;如果你用的是谷歌浏览器或者火狐浏览器,你就可以看到一个红色的方块区域。

  二、渲染上下文 Rendering Context

  其实光有 <canvas> 标签我们并不能作任何事情,玩过 Windows 编程的同学都知道,在 Windows 里面绘图先要得到一个设备上下文 DC ,在 <canvas> 标签上绘图也需要先得到一个渲染上下文,我们的图形并不是直接画到屏幕上的,而是先画到上下文(Context)上,然后再刷新到屏幕上面的。

  题外话: 为什么要整出一个“上下文”这么复杂的概念呢?因为有了上下文对象,我们就可以让各种不同的图形设备在我们眼里面看起都是一个样,我们只需要专注于绘图,其他的工作就让操作系统和浏览器去操心吧,说白了就是把各式各样的具体变成统一的抽象,从而减轻我们的负担。

  获取上下文非常简单,只需要如下两行代码:

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

  首先获取 canvas 对象,然后调用 canvas 对象的 getContext 方法,这个方法目前只能传入参数 "2d",不久的将来他可能会支持参数 "3d",你一定明白那意味着什么,让我们期待吧。

  getContext 方法返回一个 CanvasRenderingContext2D 对象 ,即渲染上下文对象,你可以在 这里 找到关于它的更多内容,都是一些绘图方法。

最新文章

  1. linux的mount(挂载)命令
  2. php对象的高级特性
  3. 动态规划(树形DP):HDU 5834 Magic boy Bi Luo with his excited tree
  4. js实现楼层效果
  5. C# Socket的TCP通讯
  6. Visual Lisp获得网络时间的方法
  7. 『转载』从内存资源中加载C++程序集:CMemLoadDll
  8. JavaJDBC整理
  9. Java中对象和json互相转换的工具类
  10. 设计模式のFilterPattern(过滤器模式)----结构模式
  11. c3p0配置文件(c3p0.properties.xml)解读
  12. Linux 常用命令随笔(二)
  13. ubuntu16.04下安装opencv3.1.0
  14. wcf和webapi(转)
  15. oracle 查询按月份分组
  16. windows下搭建nginx+php+虚拟主机配置过程
  17. 第一天-python基础
  18. 20165218 2017-2018-1 《Java程序设计》第三周学习总结
  19. Android批量图片载入经典系列——Volley框架实现多布局的新闻列表
  20. Mysql TEXT类型长度

热门文章

  1. curl post
  2. OC基础--Property
  3. jsp学习之基于mvc学生管理系统的编写
  4. JSP内置对象---request对象(用户登录页面(返回值和数组:gerParameter,getParameterValues))
  5. Text Justification
  6. linux内核学习之六 进程创建过程学习
  7. ionic的start-y属性初始化页面
  8. [ngRepeat:dupes] Duplicates in a repeater are not allowed. Use &#39;track by&#39; expression to specify unique keys
  9. gdb调试报错记录
  10. 作业七:团队项目——Alpha版本冲刺阶段009