一、<canvas>标签
Html5 引入了一个新的<canvas> 标签,这个标签所代表的区域就好象一块画布,你的所有图形绘制最后都要在这块画布上呈现。有了这个标签,浏览器的图形表现力被极大的提升,Flash 和 SilverLight 有没有感到威胁呢?
<canvas>标签的用法非常简单,如下:
< canvas id ="tutorial" width ="150" height ="150" style ="background-color:red;" >
你的浏览器不支持 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 对象 ,即渲染上下文对象,你可以在 这里 找到关于它的更多内容,都是一些绘图方法。
三、浏览器支持
除了在那些不支持的浏览器上显示替用内容之外,我们还可以通过脚本的方式来检查浏览器是否支持 canvas ,方法很简单,判断 getContext 函数是否存在即可,代码如下:
var canvas = document.getElementById('tutorial');
if (canvas.getContext){
alert("支持 < canvas > 标签");
} else {
alert("不支持 < canvas > 标签");
}
四、一个小例子
下面将用 HTML5 的绘图功能演示一个上下移动的线条的例子, 具体的代码将在后续内容中给出。
< p >
你的浏览器不支持 < canvas > 标签,请使用 Chrome 浏览器 或者 FireFox 浏览器 </ p >
< script type ="text/javascript" > // <![CDATA[
var canvas = document.getElementById( ' move_line ' );
var ctx = canvas.getContext( " 2d " );
// 上下移动的直线
var width = 400 ;
var height = 200 ;
var y = 0
var dir = 1 ;
ctx.strokeStyle = " rgb(255,0,0) " ;
function draw(){
ctx.clearRect( 0 , 0 ,width,height)
ctx.beginPath();
ctx.moveTo( 0 ,y);
ctx.lineTo(width - 1 ,y);
ctx.stroke();
y = y + dir;
if ((y == 0 ) || (y == (height - 1 ))) dir = dir * ( - 1 );
}
// ]]></script>
< p >< input onclick = " interval=setInterval(draw,10); " type = " button " value = " 开始 " / > <input onclick="clearInterval(interval);" type="button" value="停止" / > < / p>
1.本站内容仅供参考,不作为任何法律依据。用户在使用本站内容时,应自行判断其真实性、准确性和完整性,并承担相应风险。
2.本站部分内容来源于互联网,仅用于交流学习研究知识,若侵犯了您的合法权益,请及时邮件或站内私信与本站联系,我们将尽快予以处理。
3.本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
4.根据《计算机软件保护条例》第十七条规定“为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。”您需知晓本站所有内容资源均来源于网络,仅供用户交流学习与研究使用,版权归属原版权方所有,版权争议与本站无关,用户本人下载后不能用作商业或非法用途,需在24个小时之内从您的电脑中彻底删除上述内容,否则后果均由用户承担责任;如果您访问和下载此文件,表示您同意只将此文件用于参考、学习而非其他用途,否则一切后果请您自行承担,如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
5.本站是非经营性个人站点,所有软件信息均来自网络,所有资源仅供学习参考研究目的,并不贩卖软件,不存在任何商业目的及用途
暂无评论内容