在同一个canvas中绘制多个图形
来源:互联网 发布:婴儿游泳馆软件 编辑:程序博客网 时间:2024/05/16 03:41
实验背景:
在做一个 HTML 5 的一个游戏项目的时候,想在同一个 canvas 元素中绘制多个具有不同颜色的图画,但是由于当时对 HTML 5 canvas 元素不是很熟悉,结果总是所有图画都具有一样的颜色。去网上查找,也没有找到这个问题的答案,于是只能自己研究了。
实验说明:
该项目本是移动平台的跨平台项目,可以跑在WP7,WP8,Andriod,iOS,黑莓等平台,但由于 HTML 5 本身具有较好的跨平台性,所以在保证平台兼容性没有问题的
情况下,本次测试在PC上进行。
实验目的:
在同一个 canvas 元素中绘制多个不同颜色的图画
实验材料:
语言:HTML5,javascript
开发工具:VS 2012
测试工具:IE 10
实验过程:
首先创建一个 HTML 5 的基本页面,并添加一个 canvas 元素,id 为 myCanvas,然后添加 JS 代码,绘制四个小圆圈
代码如下:
- <!DOCYTPE html>
- <html>
- <head>
- <meta charset="utf-8" />
- <title>在同一个 canvas 元素中绘制不同颜色的图画</title>
- <script>
- function start()
- {
- var c = document.getElementById("myCanvas")
- var cxt = c.getContext("2d")
- cxt.fillStyle = "#FF00FF"
- cxt.arc(100, 100, 50, 0, Math.PI * 2, true)
- cxt.fill()
- cxt.fillStyle = "#FF0000"
- cxt.arc(200, 200, 50, 0, Math.PI * 2, true)
- cxt.fill()
- cxt.fillStyle = "#FFFF00"
- cxt.arc(300, 300, 50, 0, Math.PI * 2, true)
- cxt.fill()
- cxt.fillStyle = "#000000"
- cxt.arc(400, 400, 50, 0, Math.PI * 2, true)
- cxt.fill()
- }
- </script>
- </head>
- <body onload="start()">
- <canvas id="myCanvas" height="1000" width="1000">
- 你的浏览器不支持 HTML 5
- </canvas>
- </body>
- </html>
<!DOCYTPE html><html> <head> <meta charset="utf-8" /> <title>在同一个 canvas 元素中绘制不同颜色的图画</title> <script> function start() { var c = document.getElementById("myCanvas") var cxt = c.getContext("2d") cxt.fillStyle = "#FF00FF" cxt.arc(100, 100, 50, 0, Math.PI * 2, true) cxt.fill() cxt.fillStyle = "#FF0000" cxt.arc(200, 200, 50, 0, Math.PI * 2, true) cxt.fill() cxt.fillStyle = "#FFFF00" cxt.arc(300, 300, 50, 0, Math.PI * 2, true) cxt.fill() cxt.fillStyle = "#000000" cxt.arc(400, 400, 50, 0, Math.PI * 2, true) cxt.fill() } </script> </head> <body onload="start()"> <canvas id="myCanvas" height="1000" width="1000"> 你的浏览器不支持 HTML 5 </canvas> </body></html>
效果如图:
代码说明:
本想为四个圆填充不同颜色,但最终结果是四个圆全部是黑色,即第四个圆的颜色,难道 一个 canvas 中只能有一种
fillStyle 吗?如果只有一种颜色,岂不是太单一?于是我又进行了多次测试。
经过测试,最终找到了一个解决方案。
canvas 绘制可以通过 JS 代码来控制(其实应该说 HTML 5 只是提供了个容器,绘制只能在 JS 里完成),而 JS 提
供了两个函数,beginPath() 和 closePath() ,这两
个函数可以起到类似 <div> 的作用,用它来把每个圆圈包围,就可以绘制不同颜色的图形了。
代码如下:
- <!DOCYTPE html>
- <html>
- <head>
- <meta charset="utf-8" />
- <title>在同一个 canvas 元素中绘制不同颜色的图画</title>
- <script>
- function start()
- {
- var c = document.getElementById("myCanvas")
- var cxt = c.getContext("2d")
- cxt.beginPath() //注意此处
- cxt.fillStyle = "#FF00FF"
- cxt.arc(100, 100, 50, 0, Math.PI * 2, true)
- cxt.fill()
- cxt.closePath() //注意此处
- cxt.beginPath() //注意此处
- cxt.fillStyle = "#FF0000"
- cxt.arc(200, 200, 50, 0, Math.PI * 2, true)
- cxt.fill()
- cxt.closePath() //注意此处
- cxt.beginPath() //注意此处
- cxt.fillStyle = "#FFFF00"
- cxt.arc(300, 300, 50, 0, Math.PI * 2, true)
- cxt.fill()
- cxt.closePath() //注意此处
- cxt.beginPath() //注意此处
- cxt.fillStyle = "#000000"
- cxt.arc(400, 400, 50, 0, Math.PI * 2, true)
- cxt.fill()
- cxt.closePath() //注意此处
- }
- </script>
- </head>
- <body onload="start()">
- <canvas id="myCanvas" height="1000" width="1000">
- 你的浏览器不支持 HTML 5
- </canvas>
- </body>
- </html>
<!DOCYTPE html><html> <head> <meta charset="utf-8" /> <title>在同一个 canvas 元素中绘制不同颜色的图画</title> <script> function start() { var c = document.getElementById("myCanvas") var cxt = c.getContext("2d") cxt.beginPath() //注意此处 cxt.fillStyle = "#FF00FF" cxt.arc(100, 100, 50, 0, Math.PI * 2, true) cxt.fill() cxt.closePath() //注意此处 cxt.beginPath() //注意此处 cxt.fillStyle = "#FF0000" cxt.arc(200, 200, 50, 0, Math.PI * 2, true) cxt.fill() cxt.closePath() //注意此处 cxt.beginPath() //注意此处 cxt.fillStyle = "#FFFF00" cxt.arc(300, 300, 50, 0, Math.PI * 2, true) cxt.fill() cxt.closePath() //注意此处 cxt.beginPath() //注意此处 cxt.fillStyle = "#000000" cxt.arc(400, 400, 50, 0, Math.PI * 2, true) cxt.fill() cxt.closePath() //注意此处 } </script> </head> <body onload="start()"> <canvas id="myCanvas" height="1000" width="1000"> 你的浏览器不支持 HTML 5 </canvas> </body></html>
效果如图:
请读者们注意,两个函数有所属的对象,此事例中为 cxt 。
另外,在测试中,笔者还发现,当去掉所有的 closePath() 时,只保留 beginPath() ,一样可以达到目的,也就是
说,当遇到beginPath() 时,会自动重新开始下一个图形
的绘制(保留 closePath() ,去掉 beginPath() 时,效果相当于不添加这两个函数)。但是笔者个人认为,最好两个
函数都添加,这样会提高代码可读性,使代码更规
范。
实验结果:
成功在同一个 canvas 元素中绘制出不同颜色的多个图形,并且还对 beginPath() 和 closePath() 的用法有了意外收获。
实验总结:HMTL 5 的 canvas 是一大亮点,可以绘制出精美的图形(本文只是对某种用法的讨论,真正的 canvas
的功能要比此例强大的多),但对在实验中意外收获
的beginPath() 和closePath() 函数的用法,以及由此联想出的 canvas 绘制图形的机制,笔者还很不清楚,会在以后
找时间继续研究。
- 在同一个canvas中绘制多个图形
- [实验]在同一个 canvas 元素中绘制不同颜色的图形
- 在Canvas中利用Path绘制基本图形
- 在Canvas中利用Path绘制基本图形
- HTML5 Canvas绘制多个图形时,点击图形实现页面跳转
- HTML5中使用canvas绘制复杂图形
- 绘制多个图形
- 在canvas里绘制多个图像并且旋转图像
- Android软件开发:在Canvas中利用Path绘制基本图形
- Android Canvas 图形绘制
- canvas 绘制图形1
- canvas 绘制图形2
- Canvas绘制图形
- canvas绘制基本图形
- canvas绘制图形
- canvas绘制图形
- Canvas绘制基础图形
- Canvas图形绘制---ChessBoard
- 3.1 字符串移位包含问题
- FZU 2101 DP
- 在代码当中控制UI界面
- mysql数据库的备份、导入、导出命令,以及数据的导入、导出
- Boost多线程
- 在同一个canvas中绘制多个图形
- c++内存对象模型
- nutch命令详解
- title
- 彻底理解Cisco/Linux/Windows的IP路由
- boost.assert库 static_assert
- extern const的烦恼
- Reservoir Sampling - 蓄水池抽样
- VS2008集成QT4.7.2环境搭建