HTML5边玩边学(1)画布实现方法

一、<canvas>标签

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

新闻链接:Google声称Chrome7浏览器将提速60倍

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

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

复制代码

<canvas>标签和普通的 HTML 标签没有多大的区别,你可以设置它的宽度和高度,可以通过 CSS 设置它的背景色、边框样式等等。

你可以在 w3cschool 找到关于 <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 对象 ,即渲染上下文对象,你也可以在w3cschool找到关于它的更多内容,都是一些绘图方法。

三、浏览器支持 
除了在那些不支持的浏览器上显示替用内容之外,我们还可以通过脚本的方式来检查浏览器是否支持 canvas ,方法很简单,判断 getContext 函数是否存在即可,代码如下:

  1. var canvas = document.getElementById(‘tutorial‘);
  2. if (canvas.getContext){
  3. alert("支持 <canvas> 标签");
  4. } else {
  5. alert("不支持 <canvas> 标签");
  6. }

复制代码

四、一个小例子

下面将用 HTML5 的绘图功能演示一个上下移动的线条的例子, 具体的代码将在后续内容中给出

    1. <canvas style="你的浏览器不支持 <canvas>标签,请使用 Chrome 浏览器 或者 FireFox 浏览器</canvas>
    2. <script type="text/javascript">
    3. var canvas = document.getElementById(‘move_line‘);
    4. var ctx=canvas.getContext("2d");
    5. //上下移动的直线
    6. var width=400;
    7. var height=200;
    8. var y=0
    9. var dir=1;
    10. ctx.strokeStyle = "rgb(255,0,0)";
    11. function draw(){
    12. ctx.clearRect(0,0,width,height)
    13. ctx.beginPath();
    14. ctx.moveTo(0,y);
    15. ctx.lineTo(width-1,y);
    16. ctx.stroke();
    17. y=y+dir;
    18. if((y==0)||(y==(height-1))) dir=dir*(-1);
    19. }
    20. </script><p><input onclick="interval=setInterval(draw,10);" value="开始" type="button"> <input onclick="clearInterval(interval);" value="停止" type="button">

HTML5边玩边学(1)画布实现方法

时间: 2024-10-09 09:19:12

HTML5边玩边学(1)画布实现方法的相关文章

玩游戏学前端——看您的细节把握能力

引入 大约一年前曾经通过两篇文章给大家推荐了几个前端游戏<玩游戏学前端--猜颜色.选择器>.<玩游戏学前端--颜色您了解多少?>,刚刚又给大家分享了<玩游戏学前端--钢笔工具边玩边学>,通过玩游戏来学东西真的轻松愉快,我们接着给大家分享两个游戏,看看您的细节把握能力如何? 游戏 KERNTYPE 这个游戏检测您对字体细节的把握能力,主要考察文字间字母的位置,当您设置完之后,会反馈您的分数和结果.如下图所示. 蓝色字体标识正确的位置,白色的是您刚刚放置的位置,还可以使用单

玩游戏学前端——钢笔工具边玩边学

引入 大约一年前曾经通过两篇文章给大家推荐了几个前端游戏<玩游戏学前端--猜颜色.选择器>.<玩游戏学前端--颜色您了解多少?>,如果大家看到过定然会发现,通过玩游戏来学东西真的轻松愉快.今天我们继续给大家推荐一个游戏,让大家边学边玩钢笔工具. 钢笔工具是PS里面一个用途广泛而又略微难学的工具,有多少同学可以非常有把握的说掌握了钢笔工具,来来来不妨一试!! 游戏 整个游戏分为两个部分,一个部分是教学部分,另一个部分为游戏部分. 教学部分 教学部分为一些动画演示钢笔工具最基本的用法,

HTML5移动开发即学即用(双色) 王志刚 pdf扫描版?

HTML5已经广泛应用于各智能移动终端设备上,而且绝大部分技术已经被各种最新版本的测览器所支持:逐一剖析HTML5标准中包含的最新技术,详细介绍了HTML5新标准中提供的各种API,各种各样的应用实例,可以直接应用于自己的HTML5程序中. HTML5移动开发即学即用(双色)书中几乎涵盖了HTML5规范中涉及的所有技水(还在酝酿中的IndexedDatabase除外),是您能找到的真正的HTML5技术大全.包含作者精心编写的,运行于常用PC测览器以及智能手机上的应用实例,操作性与实用性俱佳,可以

html5中让页面缩放的4种方法

html5中让页面缩放的4种方法 2013-10-22 14:45:03 分类: Web开发 1.viewport这种方法,不是所有的浏览器都兼容 2.百分比这种方法,可以兼容大部分浏览器,但是修改幅度比较大.main .login .txt1{margin-top:8.59375%; position:relative;}3.css transform这种方法,可以兼容大部分浏览器,但是页面的位置是居中的.w320{transform: scale(1,1);-ms-transform: sc

跟我一起学写jQuery插件开发方法(转载)

jQuery如此流行,各式各样的jQuery插件也是满天飞.你有没有想过把自己的一些常用的JS功能也写成jQuery插件呢?如果你的答案是肯定的,那么来吧!和我一起学写jQuery插件吧! 很多公司的前端设计开发人员都是女孩子,而这些女孩子很多JavaScript技能都不是很好.而前端开发过程中,JavaScript技能又是必不可少的.所以,如果前端小MM正在为某个JavaScript效果发愁的时候,你潇洒的过去,然后对她说:“嗨,美女,用这个吧.这是我写的一个jQuery插件.”我想基本上你的

html5手机端播放音效不卡的方法

html5手机端播放音效不卡的方法线下载http://wxserver.knowway.cn/solosea/js/audioEngine.js 这个是性能不错 然后直接播放音效就可以了 audioEngine.playEffect('/solosea1/music/laidian.mp3', false); 如果切换不了 可以先stop 然后再play audioEngine.stopEffect('/hcfabuhui/music/2.mp3'); 如果延迟 是其他代码性能影响了 预加载也没

HTML5画布实现方法:

我们可以在HTML中使用属性width和height来定义Canvas.但是实现Canvas的相关功能主要还依赖于Javascript实现,即HTML5 Canvas API.我们使用javascript来访问和控制Canvas相关的区域,比如调用相关绘图的方法,用来动态的生成需要的动画或者图形. Html5 引入了一个新的 <canvas> 标签,这个标签所代表的区域就好象一块画布,所有图形绘制最后都要在这块画布上呈现. <canvas id="tutorial"

自学HTML5第四节(canvas画布详解)

canvas画布好像可是说是HTML5的精华了,一定要学好,嗯嗯,绚丽的东西就要从基础的开始.... 先看看啥玩意叫做canvas 什么是 Canvas? HTML5 的 canvas 元素使用 JavaScript 在网页上绘制图像. 画布是一个矩形区域,您可以控制其每一像素. canvas 拥有多种绘制路径.矩形.圆形.字符以及添加图像的方法. 创建一个canvas 向 HTML5 页面添加 canvas 元素. 规定元素的 id.宽度和高度: <canvas id="myCanvas

HTML5(二)音频视频画布

HTML5 Audio(音频) 定义和用法 <audio src="someaudio.wav" controls="controls"> 您的浏览器不支持 audio 标签. </audio> 提示:可以在开始标签和结束标签之间放置文本内容,这样老的浏览器就可以显示出不支持该标签的信息. 音频格式的MIME类型 Format MIME-type MP3 audio/mpeg Ogg audio/ogg Wav audio/wav 属性 属性