HTML5 绘制图像(上)之:关于canvas元素引领下一代web页面的问题


Posted in HTML / CSS onApril 24, 2013

初识canvas元素

HTML5新增了一个元素canvas,用于绘图使用,其实它的表现和div比较接近(其实他应该属于inline-block),而提供了许多接口,从而轻易的绘制矩形框、园三角形等

PS:关于HTML5新增元素
经过最近两天的学习,和以前对HTML5的认知,我认为HTML5其实还是HTML4,两者之间没多大的区别,无非是增加了点新东西。
我认为HTML5为我们带来的真正意义是:我们可以用javascript做更多的事情了;我们可以用javascript实现更好的产品了。比如HTML5就解决了我们头疼的跨域问题、实时通信API、与现在的canvas之所以HTML5叫HTML5,我认为他是划时代的,比如他让我们用网页开发游戏变成可能;比如他让电脑桌面只剩IE不在是传说(过于夸张)
绘制矩形框

直入正题,我们来绘制一个矩形框看看,这里提供一个颜色选择器用于方便的选择颜色,PS:现在不用jquery编程感觉真麻烦。。。

 问题:定义样式与定义height与width

 一来就遇到了问题,我这里先来截个图:

复制代码
代码如下:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//获取canvas对象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 300, 200); //填充画布结束

context.strokeStyle = 'red';
context.fillStyle = 'gray';
context.lineWidth = 1;
context.fillRect(10, 10, 100, 100);
context.strokeRect(10, 10, 100, 100);

context.clearRect(20, 20, 20, 20);
}
</script>
</head>
<body>
<canvas id="canvas" width=300 height="200" style="border: 1px solid black; width: 300px; height: 200px;">
</canvas>

<button onclick="draw();">
绘制矩形</button>
<input type="color" />
</body>
</html>


各位情况canvas元素,图一位设置width与height的情况,图二十用style指定的情况:

HTML5 绘制图像(上)之:关于canvas元素引领下一代web页面的问题

可以看到,对于canvas来说,还是老老实实定义高宽的好,别去傻乎乎的用样式了,当然这个问题需要实际研究才能得出最终结论。

好了,现在我们再来看看绘制矩形这个方法:

PS:其实,使用该方法这么麻烦,完全可以将该函数封装下下,使用便会简单许多
1、使用getElementById方法获取绘制对象2、取得上下文getContext('2d'),这都是固定的写法3、指定填充的颜色fillStyle和绘制的颜色strokeStyle,即里面的颜色和边框的颜色4、指定线宽linewidth5、填充/绘制 fillRect/strokeRect 参数为 x,y,width,height6、若是要使其中一块透明,使用clearRect

至此,绘制矩形框便暂时告一段落。

绘制圆形

现在我们来绘制圆形,这个说起绘制圆形,其实我原来用js好像写过一个,这里也贴出来看看:

复制代码
代码如下:

我是纯js画的圆
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<style type="text/css">
div
{
position: absolute;
width: 1px;
height: 1px;
line-height: 1px;
}
</style>
<script src="http://www.cnblogs.com/jquery-1.7.1.js" type="text/javascript"></script>
<script type="text/javascript">
//x2 + y2 = r2;
$(document).ready(function () {
//先画x,y
var box = $('#box');
var NUM = 200;
var R = NUM / 2;
var RR = R * R;
for (var i = 0; i <= NUM; i = i + 6) {
//var divX = $('<div style="left:' + i + 'px;top:' + R + 'px;">*</div>')
// var divY = $('<div style="top:' + i + 'px;left:' + R + 'px;">*</div>')

var ti = i;
//sqrt(x)
if (ti > R) {
ti = ti - R;
var ty = Math.sqrt((RR - ti * ti));
var y = $('<div style="left:' + (R - ty) + 'px;top:' + i + 'px;">*</div>')
var y1 = $('<div style="left:' + (R + ty) + 'px;top:' + i + 'px;">*</div>')
box.append(y);
box.append(y1);
} else if (ti < R) {
ti = R - ti;
var ty = Math.sqrt((RR - ti * ti));
var y = $('<div style="left:' + (R - ty) + 'px;top:' + i + 'px;">*</div>')
var y1 = $('<div style="left:' + (R + ty) + 'px;top:' + i + 'px;">*</div>')
box.append(y);
box.append(y1);
}
//box.append(divX);
//box.append(divY);
}

for (var i = 0; i <= NUM; i = i + 6) {
//var divX = $('<div style="left:' + i + 'px;top:' + R + 'px;">*</div>')
// var divY = $('<div style="top:' + i + 'px;left:' + R + 'px;">*</div>')
var ti = i;
//sqrt(x)
if (ti > R) {
ti = ti - R;
var ty = Math.sqrt((RR - ti * ti));
var y = $('<div style="top:' + (R - ty) + 'px;left:' + i + 'px;">*</div>')
var y1 = $('<div style="top:' + (R + ty) + 'px;left:' + i + 'px;">*</div>')
box.append(y);
box.append(y1);
} else if (ti < R) {
ti = R - ti;
var ty = Math.sqrt((RR - ti * ti));
var y = $('<div style="top:' + (R - ty) + 'px;left:' + i + 'px;">*</div>')
var y1 = $('<div style="top:' + (R + ty) + 'px;left:' + i + 'px;">*</div>')
box.append(y);
box.append(y1);
}
}
});

</script>
</head>
<body>
<div id="box" style="width: 504px; height: 504px; position: relative; top: 20px;
left: 300px; border: 0px solid black;">
</div>
</body>
</html>


HTML5 绘制图像(上)之:关于canvas元素引领下一代web页面的问题

话说,他还是比较圆的说。。。

进入正题

说起画圆、正弦图等肯定会经过一定计算的,所以稍稍复杂点:

① 创建路径

② 创建图形路径

③ 路径创建完成后关闭路径

④ 设定绘制样式调用方法绘制之

复制代码
代码如下:

我是一个圆
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//获取canvas对象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 300, 200); //填充画布结束
for (var i = 0; i < 5; i++) {
context.beginPath();
context.arc(i * 25, i * 25, i * 10, 0, Math.PI * 2, true);
context.closePath();
context.strokeStyle = 'red';
context.fill();
}
}
</script>
</head>
<body>
<canvas id="canvas" width="300" height="200" >
</canvas>

<button onclick="draw();">
绘制圆</button>
<input type="color" />
</body>
</html>


HTML5 绘制图像(上)之:关于canvas元素引领下一代web页面的问题

我们来看看绘制圆过程中其它地方都没有问题,但是创建圆路径这块值得考虑:

arc方法参数很多,依次是:xy半径开始弧度(我们一般喜欢角度,所以要转换)结束弧度顺时针或者逆时针true为顺时针
其它都好说,主要这个开始角度和结束角度我们来研究下,因为开始我没搞懂,但后来我发现他其实很简单了。。。就是开始的角度和结束的角度嘛,和我们高中学的知识一样的,只不过单位换算Math.PI/180为一度。。。。
反正还是没说清楚,对了,记得我们高中画圆的除了圆规和一个计量三角形角度的半圆直尺了吗,我要说的角度就是那个。。。太坑爹了!
好像最右边是0度,垂直是90度,水平是180度,既然如此,我们再来看看

复制代码代码如下:


 正时针逆时针 
 <!DOCTYPE html>
 <html xmlns="http://www.w3.org/1999/xhtml">
 <head>
     <title></title>
     <script type="text/javascript">
         function draw() {
             //获取canvas对象
             var canvas = document.getElementById('canvas');
             if (canvas == null) {
                 return false;
             }
             var context = canvas.getContext('2d');
             context.fillStyle = '#99d9ea';
             context.fillRect(0, 0, 400, 300); //填充画布结束             context.beginPath();
             context.arc(80, 80, 50, 0, 180 * Math.PI / 180, true);
             context.closePath();
             context.fillStyle = 'gray';
             context.fill();
             context.beginPath();
             context.arc(180, 180, 50, 0, 180 * Math.PI / 180, false);
             context.closePath();
             context.fillStyle = 'gray';
             context.fill();

         }
     </script>
 </head>
 <body>
     <canvas id="canvas" width="400" height="300">
     </canvas>
     <button onclick="draw();">
         绘制圆</button>
     <input type="color" />
 </body>
 </html>




我们发现正时针与逆时针还是有所不同的,

 context.arc(180, 180, 50, 90 * Math.PI / 180, 290 * Math.PI / 180, true);

原谅我这里居然思考了半个小时,我甚至搜索了高中的资料。。。。

于是我好像明白了点什么。。。。。。
moveTo与lineTo
现上实验结果:


复制代码代码如下:


 两次moveto 
 <!DOCTYPE html>
 <html xmlns="http://www.w3.org/1999/xhtml">
 <head>
     <title></title>
     <script type="text/javascript">
         function draw() {
             //获取canvas对象
             var canvas = document.getElementById('canvas');
             if (canvas == null) {
                 return false;
             }
             var context = canvas.getContext('2d');
             context.fillStyle = '#99d9ea';
             context.fillRect(0, 0, 300, 200); //填充画布结束             context.beginPath();
             context.fillStyle = 'gray';
             context.strokeStyle = 'black';
             context.moveTo(10, 10);
             context.lineTo(150, 150);
             context.moveTo(10, 10);
             context.lineTo(10, 150);
             context.closePath();
             context.fill();
             context.stroke();
         }
     </script>
 </head>
 <body>
     <canvas id="canvas" width="300" height="200">
     </canvas>
     <button onclick="draw();">
         绘制</button>
     <input type="color" />
 </body>
 </html>




复制代码代码如下:


一次moveto 
 <!DOCTYPE html>
 <html xmlns="http://www.w3.org/1999/xhtml">
 <head>
     <title></title>
     <script type="text/javascript">
         function draw() {
             //获取canvas对象
             var canvas = document.getElementById('canvas');
             if (canvas == null) {
                 return false;
             }
             var context = canvas.getContext('2d');
             context.fillStyle = '#99d9ea';
             context.fillRect(0, 0, 300, 200); //填充画布结束             context.beginPath();
             context.fillStyle = 'gray';
             context.strokeStyle = 'black';
             context.moveTo(10, 10);
             context.lineTo(150, 150);
 //            context.moveTo(10, 10);
             context.lineTo(10, 150);
             context.closePath();
             context.fill();
             context.stroke();
         }
     </script>
 </head>
 <body>
     <canvas id="canvas" width="300" height="200">
     </canvas>
     <button onclick="draw();">
         绘制</button>
     <input type="color" />
 </body>
 </html>




复制代码代码如下:


三次moveto 
 <!DOCTYPE html>
 <html xmlns="http://www.w3.org/1999/xhtml">
 <head>
     <title></title>
     <script type="text/javascript">
         function draw() {
             //获取canvas对象
             var canvas = document.getElementById('canvas');
             if (canvas == null) {
                 return false;
             }
             var context = canvas.getContext('2d');
             context.fillStyle = '#99d9ea';
             context.fillRect(0, 0, 300, 200); //填充画布结束             context.beginPath();
             context.fillStyle = 'gray';
             context.strokeStyle = 'black';
             context.moveTo(10, 10);
             context.lineTo(150, 150);
             context.moveTo(10, 10);
             context.lineTo(10, 150);
             context.moveTo(10, 150);
             context.lineTo(150, 150);
             context.closePath();
             context.fill();
             context.stroke();
         }
     </script>
 </head>
 <body>
     <canvas id="canvas" width="300" height="200">
     </canvas>
     <button onclick="draw();">
         绘制</button>
     <input type="color" />
 </body>
 </html>



以上代码几乎一样,但是他产生的结果却不同:


我认为,使用moveto后相当于新开一起点,之前的一笔勾销,若是只使用lineto的话,他会将几个点连成线,若是可以组成图形便会拥有中间色彩
HTML / CSS 相关文章推荐
CSS3盒子模型详解
Apr 24 HTML / CSS
CSS3 真的会替代 SCSS 吗
Mar 09 HTML / CSS
HTML5新控件之日期和时间选择输入的实现代码
Sep 13 HTML / CSS
html5 跨文档消息传输示例探讨
Apr 01 HTML / CSS
HTML5 form标签之解放表单验证、增加文件上传、集成拖放的使用方法
Apr 24 HTML / CSS
html5贪吃蛇游戏使用63行代码完美实现
Jun 25 HTML / CSS
html5 css3实例教程 一款html5和css3实现的小机器人走路动画
Oct 20 HTML / CSS
HTML5中的进度条progress元素简介及兼容性处理
Jun 02 HTML / CSS
HTML5 canvas基本绘图之绘制曲线
Jun 27 HTML / CSS
详解使用postMessage解决iframe跨域通信问题
Nov 01 HTML / CSS
纯html+css实现奥运五环的示例代码
Aug 02 HTML / CSS
详解flex:1什么意思
Jul 23 HTML / CSS
HTML5 form标签之解放表单验证、增加文件上传、集成拖放的使用方法
Apr 24 #HTML / CSS
HTML5 Web Workers之网站也能多线程的实现
Apr 24 #HTML / CSS
HTML5组件Canvas实现图像灰度化(步骤+实例效果)
Apr 22 #HTML / CSS
基于IE10/HTML5 开发
Apr 22 #HTML / CSS
IE10 Error.stack 让脚本调试更加方便快捷
Apr 22 #HTML / CSS
Javascript 高级手势使用介绍
Apr 21 #HTML / CSS
基于Modernizr 让网站进行优雅降级的分析
Apr 21 #HTML / CSS
You might like
PHP超级全局变量数组小结
2012/10/04 PHP
php实现cc攻击防御和防止快速刷新页面示例
2014/02/13 PHP
PHP实现linux命令tail -f
2016/02/22 PHP
Thinkphp5 如何隐藏入口文件index.php(URL重写)
2019/10/16 PHP
根据分辨率不同,调用不同的css文件
2006/08/25 Javascript
奉献给JavaScript初学者的编写开发的七个细节
2011/01/11 Javascript
电子商务网站上的常用的js放大镜效果
2011/12/08 Javascript
js中eval详解
2012/03/30 Javascript
Jquery判断$(&quot;#id&quot;)获取的对象是否存在的方法
2013/09/25 Javascript
JS实现样式清新的横排下拉菜单效果
2015/10/09 Javascript
jQuery实现选项卡切换效果简单演示
2015/12/09 Javascript
学习JavaScript设计模式之代理模式
2016/01/12 Javascript
jQuery获得字体颜色16位码的方法
2016/02/20 Javascript
浅析jquery unbind()方法移除元素绑定的事件
2016/05/24 Javascript
JS全局变量和局部变量最新解析
2016/06/24 Javascript
js自定义瀑布流布局插件
2017/05/16 Javascript
JavaScript中立即执行函数实例详解
2017/11/04 Javascript
vue中使用element ui的弹窗与echarts之间的问题详解
2019/10/25 Javascript
numpy 计算两个数组重复程度的方法
2018/11/07 Python
Python实现批量修改图片格式和大小的方法【opencv库与PIL库】
2018/12/03 Python
Python中利用LSTM模型进行时间序列预测分析的实现
2019/07/26 Python
python GUI库图形界面开发之PyQt5开发环境配置与基础使用
2020/02/25 Python
解决Python中报错TypeError: must be str, not bytes问题
2020/04/07 Python
解决Python在导入文件时的FileNotFoundError问题
2020/04/10 Python
总结python 三种常见的内存泄漏场景
2020/11/20 Python
Javascript 高级手势使用介绍
2013/04/21 HTML / CSS
const char*, char const*, char*const的区别是什么
2014/07/09 面试题
访谈节目策划方案
2014/05/15 职场文书
技术岗位竞聘演讲稿
2014/05/16 职场文书
新店开张活动方案
2014/08/24 职场文书
计算机科学与技术专业求职信
2014/09/03 职场文书
企业贷款委托书格式
2014/09/12 职场文书
王金山在党的群众路线教育实践活动总结大会上的讲话稿
2014/10/25 职场文书
初中生考试作弊检讨书
2014/12/14 职场文书
golang操作redis的客户端包有多个比如redigo、go-redis
2022/04/14 Golang
Python自动化实战之接口请求的实现
2022/05/30 Python