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

2016-02-19 11:21 7 1 收藏

图老师设计创意栏目是一个分享最好最实用的教程的社区,我们拥有最用心的各种教程,今天就给大家分享HTML5 绘制图像(上)之:关于canvas元素引领下一代web页面的问题的教程,热爱PS的朋友们快点看过来吧!

【 tulaoshi.com - Web开发 】

初识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指定的情况:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

可以看到,对于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

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

进入正题

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

① 创建路径

② 创建图形路径

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

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

代码如下:

我是一个圆
!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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

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

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的话,他会将几个点连成线,若是可以组成图形便会拥有中间色彩

来源:http://www.tulaoshi.com/n/20160219/1597175.html

延伸阅读
经期做美容的代价 25岁的小周至今都为自己所做的割眼皮美容手术后悔不迭。一个多月前,她在一家美容院做了割双眼皮手术。当时她刚好来了月经。手术很简单,做得也很成功。不料,她手术后第二天却出现了伤口肿胀、疼痛、渗血、睁不开双眼的现象,接着又出现发烧、部分伤口红肿、流脓。家人急忙将她送往医院,医生确诊是因为美容后伤口感染导致...
标签: 孕前准备 孕前
六类女性生孩子易畸形 怀孕早期有过高热的妇女,孩子即便不出现明显外观畸形,但脑组织发育有可能受到不良影响,表现为智力低下,学习和反应能力较差。这种智力低下是由于高热造成胎儿脑神经细胞死亡,使脑神经细胞数减少所致,这种智力低下是不能恢复的。当然,高热造成胎儿畸形还与孕妇对高热的敏感性和其他因素有关。 研究发现,有六类女...
标签: 怀孕
选择最佳生育年龄是许多夫妇所关心的问题。父母的婚育年龄对胎儿是否有影响?答案是肯定的。 育龄过早的母亲对子代的影响:女性在18岁左右开始进入性成熟期,性成熟期持续约30年,为生育期,处于此期的妇女成为育龄妇女。一般认为女性的最佳生育年龄为24-28岁,此时生育不仅符合人体的生理特点,而且有利于胎儿的健康发育。女性到了18岁,虽...
标签: Web开发
微软的下一代Web服务器IIS 7将会综合ASP.NET开发技术,并且在可选组件中加入很多核心技术。除此之外,软件的管理工具可以允许更多安全且基于Web的远程连接。 IIS 7将会随微软的下一代操作系统“Longhorn”于2006的晚些时候发布,随着微软向它的关键商业伙伴开放秘密预览IIS7的资格,升级的细节也将会而逐渐浮出水面。 Interscape Techn...
注意怀孕不可一缓再缓(图) 注意怀孕不可一缓再缓 生育是人的本能,然而,随着社会的发展,越来越多的人被剥夺了生育的权利。统计数据表明:以前不孕不育症占10-15%,而近几年已高达20%。原因是多方面的,除去疾病因素外,大多数人还缺乏一定的相关知识。你是不是非常想知道如何才能怀孕,怀孕过程中遇到问题又该如何应付。我们就几个读者咨询...

经验教程

636

收藏

41
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部