博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
html5 Canvas绘制图形入门详解
阅读量:6943 次
发布时间:2019-06-27

本文共 2150 字,大约阅读时间需要 7 分钟。

html5,这个应该就不需要多作介绍了,只要是开发人员应该都不会陌生。html5是「新兴」的网页技术标准,目前,除IE8及其以下版本的IE浏览器之外,几乎所有主流浏览器(FireFox、Chrome、Opera、Safari、IE9+)都已经开始支持html5了。除此之外,在移动浏览器市场上,众多的移动浏览器也纷纷展开关于「html5的支持能力以及性能表现」的军备竞赛。html作为革命性的网页技术标准,再加上众多浏览器厂商或组织的鼎力支持,可以想见,html5将会成为未来网页技术的领头羊。

html5,说其是「新兴」的,其实也不算新了。毕竟,html5早在2008年其第一份正式草案就已经对外公布。从2008年算起,到现在也算是有些年头了。不过,到目前为止,对于大多数开发人员而言,仍然是「雷声大,雨点小」——听说html5的多,实际使用html5的却很少。

众所周知,html5中增加了许多新特性。在html5的众多特性中,Canvas应该算是最引人注目的新特性之一。我们使用html5的Canvas对象可以直接在浏览器的网页上绘制图形。这意味着浏览器可以脱离Flash等第三方插件,直接在网页上显示图形或动画。

现在,我们就来为html5初学者介绍如何使用html5 Canvas绘制基本的图形。

首先,我们需要准备如下html基础代码:

1  2  3  4 
5 HTML5 Canvas入门示例 6 7 8 9 10

上述代码是一个html5页面的基本代码模板。其中,第一行代码<!DOCTYPE html>是一个文档类型标签指令,这也是html5页面的标准文档类型指令,用于告诉浏览器「这是一个html5页面,请按照html5的网页标准来解析显示该页面」。第4行代码<meta charset="UTF-8">用于告诉浏览器「这个html5页面的字符编码为UTF-8」,这也是html5网页设置字符编码的标准写法。这与以往的html字符编码指令有所不同。

1 
2

现在,我们就在包含上述代码的html文件中进行Canvas绘制图形的实例讲解。首先,我们在上述html代码的body部分添加如下canvas标签。

1  2  3  4 
5 HTML5 Canvas入门示例 6 7 8 9
10
11 您的浏览器不支持canvas标签。12
13 14 15

此时,我们使用支持html5的浏览器打开该页面,将会看到如下内容:

             canvas标签显示效果

在html5中,canvas标签本身并没有任何行为,仅仅只是在页面上占用指定大小的页面空白空间。canvas标签就相当于一块空白的画布,还需要我们自己使用JavaScript提供的canvas API编写相应的代码从而在这块画布上绘制出我们想要的图形。

备注:canvas标签体内的文字内容将会在不支持html5的浏览器中显示。如上述html代码所示,如果你的浏览器不支持html5的canvas标签,那么将会在canvas标签处显示文字「您的浏览器不支持canvas标签」。

作为「画家」的我们,首先需要熟悉我们手中的画笔,也就是JavaScript中的Canvas对象及其相关内容。

在html5中,一个canvas标签就对应一个Canvas对象,我们在JavaScript可以使用document.getElementById()等常规函数来获取该对象。值得注意的是,在JavaScript中,我们并不是直接操作Canvas对象,而是通过Canvas对象来获取对应的图形绘制上下文对象CanvasRenderingContext2D,然后我们再利用CanvasRenderingContext2D对象自带的许多绘制图形的函数来绘图。

这就好像是每一张画布都对应一支画笔,要想在画布上绘画,我们就先要拿到对应的画笔,然后使用这支画笔在画布上绘图。CanvasRenderingContext2D对象就相当于这支画笔。现在,我们就先来尝试在JavaScript中拿到这支画笔。

1  2  3  4 
5 HTML5 Canvas绘制线条入门示例 6 7 8 9
10
11 您的浏览器不支持canvas标签。12
13 14 24 25

如上述代码所示,我们可以使用Canvas对象的getContext()方法来获取CanvasRenderingContext2D对象。比较细心的读者应该注意到了:getContext()方法需要传入一个字符串——2d,获取到的CanvasRenderingContext2D对象的名称中也带有2D。这是因为,目前html5只支持2D绘图,但是在未来的html5中也可能支持3D或其他形式的绘图。届时,我们可能就需要使用getContext("3d")来获取CanvasRenderingContext3D对象并绘制3D图形了

 

转载于:https://www.cnblogs.com/joyco773/p/6087216.html

你可能感兴趣的文章
【VMCloud云平台】SCSM(十)服务请求到资源落地
查看>>
Maven组件通过命令上传本地和私有仓库
查看>>
TrendMicro:针对以色列美国等国的基于Xtreme RAT的APT***
查看>>
Java编程时间格式与数据库中时间格式转化
查看>>
部署Silverlight项目到Windows Azure云平台实例
查看>>
DPM2012系列之一:安装Data Protection Manager 2012
查看>>
PhpGACL手册(一)
查看>>
DB2中如何快速定位锁等待语句
查看>>
centos/ubuntu挂载vmdk、 vdi为块设备的方法(非vdfuse)
查看>>
Exchange server 2003迁移到2010后,手动更新地址列表,提示OAB Versions无效
查看>>
xmanager连接RedHat出错:/usr/X11R6/bin/xterm: No such file or directory
查看>>
我是做SEO的
查看>>
PIG安装配置及案例应用
查看>>
Powershell管理系列(一)Active Direcrtory管理:用户管理
查看>>
使用PsList查看Windows上Oracle的线程等信息
查看>>
2012 定制化产品探讨(周金根).pdf
查看>>
使用智能DNS与多线路由解决教育网服务器费用难题
查看>>
SQL Server 2012 AlwaysOn高可用配置之五:配置仲裁
查看>>
Powershell管理系列(三十九)PowerShell查询和解锁AD账号
查看>>
【实战虚拟化】安全设计之一基本架构
查看>>