HTML5 canvas易错点
一、画布的默认宽高
<canvas id="myCanvas" style="border:1px solid black;">
你的浏览器不支持html5
</canvas>
通过火狐浏览器访问,看到

通过截图工具发现,矩形的宽为300 高为150。但是我在w3school中看到的信息室说canvas默认宽高都为300

不过不是我要讨论的东西,可先忽略。
我们知道canvas只是html的一个新标签。因此,我们也可以用css来修改canvas画布的宽高大小。
但是,除非特殊情况,一定不要用css来定义Canvas的宽高。
两者的区别,在于:
Canvas自身的宽高就是画布本身的属性,而css给他的宽高则可以看作是缩放.
代码例子:

这是通过js来设置画布canvas的宽高,在保持文本设置不变的情况下,修改width以及height,会发现,文本处于不变的状态。

这是通过css来设置画布canvas的宽高,在保持文本设置不变的情况下,修改width以及height,会发现,文本会随着设置而变化,而且有了缩放的感觉。
二、canvas画布只能共享一支画笔
在前面已经提到,在有了画布的情况下,我们要对画布进行操作,则需要画笔来进行。
canvas获取画笔 var ctx = c.getContext("2d");
我刚开始的时候,认为反正getContext只是方法。所以多调用几次,就可以整出多几只笔出来。比如:
var ctx = c.getContext("2d");
var ctx1 = c.getContext("2d");
后来通过浏览器访问时,oh my god。不行啊。
代码例子:

运行结果图:

从这里,我们就可以知道,canvas只能共享一支画笔。如果你需要画出不同的颜色,办法就是把这只唯一的“笔”不停的蘸上新颜色哦。^_^
三、路径问题即beginPath方法使用
在进行线条或者图形绘制时,最好在开头开始beginPath
在学习canvas的线条或者矩形线条的使用时,我感到奇怪的是,有些案例,每画一条线条,在开始时都会使用beginPath作为开头,而有些案例,则没有。真够坑的。
看了手册的解释说是,开启一条新的路径。那么它有什么重要的?
代码例子:

访问结果图:

从结果图,可以看出
1、结果不是一红 一黄。
2、第一条线条被描绘了两次。
如何理解这个结果.
我的理解是,我用手在画板上,用一支红色的笔画出一线条。然后,用一支黄色的笔再画出另一线条。那么,为什么我不会对第一条再次绘制呢?这是因为我知道,这两条线条是不同的。因此,我不会。而计算机不知道,它无法区别这两条线条是不是同一的。而要如何进行区别呢?就要用到beginPath。否则的话,canvas中的绘制方法,都会以“上一次beginPath”之后的所有路径为基础进行绘制了。
启用beginPath也有个好处,就是提高性能。否则,就会对之前的线条进行重新绘制了。
HTML5 canvas易错点的更多相关文章
- HTML5 canvas入门
HTML5 Canvas入门 <canvas> 标签定义图形,比如图表和其他图像,您必须使用脚本来绘制图形.在画布上(Canvas)画一个红色矩形,渐变矩形,彩色矩形,和一些彩色的文字. ...
- 赠书:HTML5 Canvas 2d 编程必读的两本经典
赠书:HTML5 Canvas 2d 编程必读的两本经典 这两年多一直在和HTML5 Canvas 打交道,也带领团队开发了世界首款基于HTML5 Canvas 的演示文档工具---AxeSlide( ...
- 如何开发一个简单的HTML5 Canvas 小游戏
原文:How to make a simple HTML5 Canvas game 想要快速上手HTML5 Canvas小游戏开发?下面通过一个例子来进行手把手教学.(如果你怀疑我的资历, A Wiz ...
- html5 canvas简易版捕鱼达人游戏源码
插件描述:html5利用canvas写的一个js版本的捕鱼,有积分统计,鱼可以全方位移动,炮会跟着鼠标移动,第一次打开需要鼠标移出背景图,再移入的时候就可以控制炮的转动,因为是用的mouseover触 ...
- 使用html5 canvas绘制图片
注意:本文属于<html5 Canvas绘制图形入门详解>系列文章中的一部分.如果你是html5初学者,仅仅阅读本文,可能无法较深入的理解canvas,甚至无法顺畅地通读本文.请点击上述链 ...
- HTML5 Canvas 获取网页的像素值。
我之前在网上看过一个插件叫做出JScolor 颜色拾取器 说白了就是通过1*1PX的DOM设置颜色值通过JS来获取当前鼠标点击位置DOM的颜色值. 自从HTML5 画布出来之后.就有更好的方法来 ...
- HTML5 程序设计 - 使用HTML5 Canvas API
请你跟着本篇示例代码实现每个示例,30分钟后,你会高喊:“HTML5 Canvas?!在哥面前,那都不是事儿!” 呵呵.不要被滚动条吓到,很多都是代码和图片.我没有分开写,不过上面给大家提供了目录,方 ...
- html5 canvas常用api总结(一)
1.监听浏览器加载事件. window.addEventListener("load",eventWindowLoaded,false); load事件在html页面加载结束时发生 ...
- JavaScript易错知识点整理
前言 本文是我学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由浅入深的介绍和讲解,其中也涉及了一 ...
随机推荐
- timeout Timeout时间已到.在操作完成之前超时时间已过或服务器未响应
Timeout时间已到.在操作完成之前超时时间已过或服务器未响应 问题 在使用asp.net开发的应用程序查询数据的时候,遇到页面请求时间过长且返回"Timeout时间已到.在操作完成之间超 ...
- CSS权威指南学习笔记 —— 初步认识CSS
层叠样式表(Cascading Style Sheets,CSS)可以影响文档的表现.CSS是依附于文档的,如果不存在某种文档,CSS基本上是没有用的. 为什么会有CSS 在web早期(1990-19 ...
- 详解Activity的四种启动模式
在Android中每个界面都是一个Activity,切换界面操作其实是多个不同Activity之间的实例化操作.在Android中Activity的启动模式决定了Activity的启动运行方式. Ac ...
- node学习第一篇
创建一个http服务器 //app.js var http = require("http"); function start(req, res){ //res.writeHead ...
- vim命令杂记
vim 实用命令. . . 命令重复上一次修改动作 >G 增加当前行到文档末尾处的缩进 C 相当于c$,更改当前位置 至 行尾的单词 S 相当于^c , 更改一行 : 重复上次的f命令所查找的字 ...
- javascript二级联动
二级联动在一般的网页中随处可见,一般是地址,比如点击浙江省,随后出现的是杭州市,嘉兴市:点击北京省出现的是朝阳,海淀,而不是出现杭州,嘉兴. 要想实现这个步骤,就要用到javascript来实现.其中 ...
- Preorder, Inorder, and Postorder非递归总结
Preorder, Inorder, and Postorder Iteratively Summarization[1] 1.Pre Order Traverse public List<In ...
- Database.SetInitializer的几种参数
一:数据库不存在时重新创建数据库 Database.SetInitializer<testContext>(new CreateDatabaseIfNotExists<testCon ...
- Linux02--文件系统与磁盘管理
1.文件默认权限umask umask命令用于指定新建文件和目录时的默认权限. root的umask默认值是022,普通用户的umask值为002. 新建文件的默认权限=666 - ...
- Annotation 与 HttpClient(5)--Annotation HttpClient
Annotation HttpClient 本内容不保证正确性,如有问题请及时提出 经过前面四篇博客的铺垫,现在给出带有标记的HttpClient的实现. 1. 带标记的HttpClient的 ...