canvasHTML,canvasHTML绘制弧形
如何在html5的canvas绘制地图
我这里认为大家都稍微了解甚至熟悉canvas的一些API,就不具体说,每一个参数代表什么意思了。
!DOCTYPE html
html
head
meta charset='utf-8'
title图片加载平移放大缩小示例/title
style
html,body{
margin:0px;
padding:0px;
}
canvas{
border: 1px solid #000;
}
/style
/head
body
canvas id="canvas" width="800" height="800"/canvas
script type="text/javascript" src="main.js"/script
/body
/html
var canvas,context;
function int(){
canvas=document.getElementById('canvas');
context=canvas.getContext('2d');
}
图片加载
创建一个图片对象之后,图片不能马上绘制到canvas上面,因为图片还没有加载完成。所以我们需要监听图片对象加载完事件,然后再去绘制。
var img,//图片对象
imgIsLoaded//图片是否加载完成;
function loadImg(){
img=new Image();
img.onload=function(){
imgIsLoaded=true;
//draw image
}
img.src="map.jpg";
}
图片绘制
绘制图像一个函数就可以搞定,但是需要记录这个图像的左上角坐标以及缩放比例。
var imgX,imgY,imgScale;
function drawImage(){
context.clearRect(0,0,canvas.width,canvas.height);
context.drawImage(img,0,0,img.width,img.height,imgX,imgY,img.width*imgScale,img.height*imgScale);
}
图片平移
html5事件最小细度在DOM上,所以我们无法对canvas上的图像做监听,只能对canvas监听。
首先监听鼠标mousedown事件,等事件发生之后,再监听鼠标mousemove事件和mouseup事件
mousemove事件发生之后,获得鼠标移动的位移,相应的图片的位置改变多少
mouseup事件发生之后,取消对mousemove以及mouseup事件监听
canvas.onmousedown=function(event){
var pos=windowToCanvas(canvas,event.clientX,event.clientY);
canvas.onmousemove=function(event){
canvas.style.cursor="move";
var pos1=windowToCanvas(canvas,event.clientX,event.clientY);
var x=pos1.x-pos.x;
var y=pos1.y-pos.y;
pos=pos1;
imgX+=x;
imgY+=y;
drawImage();
}
canvas.onmouseup=function(){
canvas.onmousemove=null;
canvas.onmouseup=null;
canvas.style.cursor="default";
}
}
function windowToCanvas(canvas,x,y){
var bbox = canvas.getBoundingClientRect();
return {
x:x - bbox.left - (bbox.width - canvas.width) / 2,
y:y - bbox.top - (bbox.height - canvas.height) / 2
};
}
图片缩放
其实缩放很简单,稍微复杂的是,如何让鼠标成为放大或者缩小的中心。如果数学几何不好,计算公式就可能看不明白了。
canvas.onmousewheel=canvas.onwheel=function(event){//chrome firefox浏览器兼容
var pos=windowToCanvas(canvas,event.clientX,event.clientY);
event.wheelDelta=event.wheelDelta?event.wheelDelta:(event.deltaY*(-40));
if(event.wheelDelta0){
imgScale*=2;
imgX=imgX*2-pos.x;
imgY=imgY*2-pos.y;
}else{
imgScale/=2;
imgX=imgX*0.5+pos.x*0.5;
imgY=imgY*0.5+pos.y*0.5;
}
drawImage();
}
这个时候,基本功能就实现了,加载一张图片和加载多张图片都差不多,维护每一张图片的位置和大小,下面来整理一下代码吧。
var canvas,context;
var img,//图片对象
imgIsLoaded,//图片是否加载完成;
imgX=0,
imgY=0,
imgScale=1;
(function int(){
canvas=document.getElementById('canvas');
context=canvas.getContext('2d');
loadImg();
})();
function loadImg(){
img=new Image();
img.onload=function(){
imgIsLoaded=true;
drawImage();
}
img.src="map.jpg";
}
function drawImage(){
context.clearRect(0,0,canvas.width,canvas.height);
context.drawImage(img,0,0,img.width,img.height,imgX,imgY,img.width*imgScale,img.height*imgScale);
}
canvas.onmousedown=function(event){
var pos=windowToCanvas(canvas,event.clientX,event.clientY);
canvas.onmousemove=function(event){
canvas.style.cursor="move";
var pos1=windowToCanvas(canvas,event.clientX,event.clientY);
var x=pos1.x-pos.x;
var y=pos1.y-pos.y;
pos=pos1;
imgX+=x;
imgY+=y;
drawImage();
}
canvas.onmouseup=function(){
canvas.onmousemove=null;
canvas.onmouseup=null;
canvas.style.cursor="default";
}
}
canvas.onmousewheel=canvas.onwheel=function(event){
var pos=windowToCanvas(canvas,event.clientX,event.clientY);
event.wheelDelta=event.wheelDelta?event.wheelDelta:(event.deltaY*(-40));
if(event.wheelDelta0){
imgScale*=2;
imgX=imgX*2-pos.x;
imgY=imgY*2-pos.y;
}else{
imgScale/=2;
imgX=imgX*0.5+pos.x*0.5;
imgY=imgY*0.5+pos.y*0.5;
}
drawImage();
}
function windowToCanvas(canvas,x,y){
var bbox = canvas.getBoundingClientRect();
return {
x:x - bbox.left - (bbox.width - canvas.width) / 2,
y:y - bbox.top - (bbox.height - canvas.height) / 2
};
如何使用HTML5 Canvas动态的绘制拓扑图
使用HTML5 Canvas动态的绘制拓扑图:
HTML5中引入新的元素canvas,其drawImage 方法允许在 canvas 中插入其他图像( img 和 canvas 元素) 。drawImage函数有三种函数原型:
语法:
drawImage(image, dx, dy)
drawImage(image, dx, dy, dw, dh)
drawImage(image, sx, sy, sw, sh, dx, dy, dw, dh)
*第一个参数image可以用HTMLImageElement,HTMLCanvasElement或者HTMLVideoElement作为参数。
*dx、dy是image在canvas中定位的坐标值;
*dw、dh是image在canvas中即将绘制区域(相对dx和dy坐标的偏移量)的宽度和高度值;
*sx、sy是image所要绘制的起始位置;
*sw、sh是image所要绘制区域(相对image的sx和sy坐标的偏移量)的宽度和高度值。
举例:
!DOCTYPE html
html
body
p要使用的图像:/p
img id="tulip" src="/i/eg_tulip.jpg" alt="The Tulip" /
p画布:/p
canvas id="myCanvas" width="500" height="300" style="border:1px solid #d3d3d3;background:#ffffff;"
Your browser does not support the HTML5 canvas tag.
/canvas
script
var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
var img=document.getElementById("tulip");
ctx.drawImage(img,10,10);
/script
/body
/html
怎样在html5中添加canvas标签
canvas 标签是 HTML 5 中的新标签。
定义和用法
canvas 标签定义图形,比如图表和其他图像。
canvas 标签只是图形容器,您必须使用脚本来绘制图形。
实例
通过 canvas 元素来显示一个红色的矩形:
!DOCTYPE?HTML
html
head
script?type="text/javascript"
var?canvas=document.getElementById('myCanvas');
var?ctx=canvas.getContext('24d');
ctx.fillStyle='#FF0000';
ctx.fillRect(0,0,80,100);
/script
/head
body
canvas?id="myCanvas"your?browser?does?not?support?the?canvas?tag?/canvas
/body
/html
如何用HTML5 的Canvas制作3D动画效果
HTML5的诞生给web前端界带来了不小轰动,像什么动画旋转、图片滑块、图片轮播等等这些3D特效,也引发了不少朋友想要学习HTML5的好奇心。最近我一直在做canvas动画效果,发现canvas这个东西做动画不是不可以。相对于flash,它太底层。如果有给力的编辑器或者给力的框架的话,它就能发挥出更大的威力。
于是决定自己写一个简单一点的动画框架,以便能更方便地构建出一些动画效果。
我将分几个章节来讲述我这个小动画框架的实现:
1.通用类的提取:动画对象与帧对象
2.灵与肉的结合:便于拆卸的运动方程
3.进度条的实现:canvas的图片预加载
4.demo测试:通过一个demo测试框架
这一节我们先来说说通用类的提取。
其实上一篇文章我已经用到了这种从flash借鉴来的思路:一个动画对象(类似flash中的元件),一个帧对象(类似flash中的帧)。动画就是在不断在当前帧上绘制每个动画对象来实现的。有了这两个对象,再加上一些运动方法,我们就可以构建出动画来。
首先我们先来看看动画对象Aniele:
/*
*Aniele动画对象
*所有动画对象的始祖
*/
varAniele=function(){
this.img=newImage();
//定义动画对象位置
this.loca={
x:300,
y:300
}
//定义动画对象的大小(可以实现缩放)
this.dw;
this.dh;
//动画对象的速度属性
this.speed={
x:0,
y:0
}
//设置对象的透明度
this.alpha=1;
//设置图像翻转,1为不翻转,-1为翻转
this.scale={
x:1,
y:1
}
//定动画对象的运动方法库
this.motionFncs=[];
}
Aniele.prototype={
//添加运动方法
addMotionFnc:function(name,fnc) {
this.motionFncs[name]=fnc;
},
//删除运动方法
deleMotionFnc:function(name){
this.motionFncs[name]=null;
},
//遍历运动方法库里的所有运动方法
countMotionFncs:function() {
for(vari=0; i
if(this.motionFncs[i]==null)
continue;
this.motionFncs[i].call(this);
}
},
//把自己绘制出来的方法,包括功能:水平翻转
draw:function(canvas,ctx){
//存储canvas状态ctx.save();
//实现透明度的改变
ctx.globalAlpha=this.alpha;
//实现水平竖直翻转,定义drawImage的两个位置参数dx,dy
vardx=this.loca.x;
vardy=this.loca.y;
if(this.scale.x!=1||this.scale.y!=1){
if(this.scale.x0){
console.log(this.img.width)
dx=canvas.width-this.loca.x-this.img.width;
ctx.translate(canvas.width,1);
ctx.scale(this.scale.x,1);
}
if(this.scale.y0){
dy=canvas.height-this.loca.y-this.img.height;
ctx.translate(1,canvas.height);
ctx.scale(1,this.scale.y);
}
}
if(this.dw==null)
this.dw=this.img.width;
if(this.dh==null)
this.dh=this.img.height;
//画出对象
ctx.drawImage(this.img,dx,dy,this.dw,this.dh);
//恢复canvas状态ctx.restore();
}
}
动画对象的主要属性:
this.img=newImage();我们引入一张图片,依附在动画对象上;
this.loca.x等等;图片的大小位置透明度等等,便于绘图时调用;
this.motionFncs=[];这个比较关键,我们给动画对象定义一个运动方法库,把动画对象的运动规则都放在这个运动方法库中统一管理(每个动画对象都有自己的运动方法库);
动画对象的主要方法:
addMotionFnc: 为动画对象的运动方法库中添加一个运动方法;
deleMotionFnc:为动画对象的运动方法库中删除一个运动方法;
countMotionFncs:为动画对象遍历运动方法库中的所有运动方法;
draw:把动画对象画在画布上,这里我们会把画布作为参数传到这个方法里面去,便于绘图;
在draw方法里,我封装了一些对图像的简单操作,这些操作在动画中会经常用到:透明,缩放和翻转。
有了这个,我们就好似获得了flash里的一个元件,我们可以通过修改它的属性来随意改变它。
那么帧对象呢?
帧对象肩负着渲染的任务,并且管理所有动画对象:
/*
*Render渲染对象
*管理所有动画对象和渲染
*参数:画布对象,画布上下文*/varRender=function(canvas,ctx) {
//引入画布
this.canvas=canvas;
this.ctx=ctx;
//创建一个缓冲画布
this.backBuffer=document.('canvas');
this.backBuffer.width=this.canvas.width;
this.backBuffer.height=this.canvas.height;
this.backBufferctx=this.backBuffer.getContext('2d');
//所有动画对象
this.aniEles=[];
}
Render.prototype={
//初始化画布int
int:function() {
clearInterval(this.sint);
this.ctx.clearRect(0,0,this.canvas.width,this.canvas.height);
this.backBufferctx.clearRect(0,0,this.backBuffer.width,this.backBuffer.height);
},
//设置开始渲染
begin:function() {
this.lastFrame=(newDate()).getTime();
this.sint=setInterval((function(progra){
returnfunction(){progra.render();}
})(this),SECOND);
},
//主渲染方法
render:function() {
//在画布和缓存画布上清除历史帧
this.ctx.clearRect(0,0,this.canvas.width,this.canvas.height);
this.backBufferctx.clearRect(0,0,this.backBuffer.width,this.backBuffer.height);
//保存当前的实时输出帧率this.ftp
this.nowFrame=(newDate()).getTime();
this.ftp=1000/(this.nowFrame-this.lastFrame);
this.lastFrame=this.nowFrame;
//调用每个动画对象的运动方法
for(vari=0; i
if(this.aniEles[i]==null)
continue;
this.aniEles[i].countMotionFncs();
//把对象绘制到后台缓冲画布上
this.aniEles[i].draw(this.backBuffer,this.backBufferctx);
}
//把后台对象绘制到前台
this.ctx.drawImage(this.backBuffer,0,0);
},
//增加动画对象
addAniEle:function(name,aniEle) {
this.aniEles[name]=aniEle;
},
//删除动画对象
deleAniEle:function(name) {
this.aniEles[name]=null;
}
}
帧对象的主要属性:
this.aniEles=[];用来存储当前画布上所有动画实例的数组;
大家用过canvas载入图片的应该知道,由于图片的异步载入,动画过程中图片会出现闪烁的现象,为了避免这种现象,我采用了双缓冲。
首先后台创建一个画布:
this.backBuffer=document.('canvas');
this.backBuffer.width=this.canvas.width;
this.backBuffer.height=this.canvas.height;
this.backBufferctx=this.backBuffer.getContext('2d');
我们所有绘制命令都执行在这个后台画布上,最后把后台画布画在前台画布上:
this.ctx.drawImage(this.backBuffer,0,0);
这种先把图绘在后台画布,再把后台画布复制到前台的方法就叫做双缓冲技术。
帧属性的主要方法:
int:用于初始化画布;
begin:开始动画渲染的方法;
render:主渲染的方法;
addAniEle:为当前帧添加动画对象;
deleAniEle:为当前帧删除动画;
我们利用帧对象的流程是:先为当前帧添加动画对象,然后让当前帧开始渲染。
html5可以在canvas上放div么
如果让div在canvas上面覆盖显示,可以将div设置成position:absolute;或fixed
然后通过left和top进行定位
如果要在canvas里套div标签,则只有不支持canvas标签的浏览器才会识别canvas标签内的内容,支持的就忽略了,这主要是用来写不支持提示信息的
如何将div 转化成 html 5 canvas
div
id="svgContainer"
svg
id="svg"/svg
/div
首先需要获取svg标签以及内容:
var
svgHtml
=
svgContainer.innerHTML();
将svg转成canvas需要用到google的一个插件canvg,可以上官网下载,也可以直接远程引用进来
接下来就是调用该插件的canvg(canvasId,svgHtml)方法来转成canvas,这个方法第一个参数就是canvas标签的id,第二个自然就是svg标签内容了,就这样,svg转成了canvas
然后就是将canvas转成图片了,这个更加简单了
var
imgSrc
=
document.getElementById(canvasId).toDataUrl("image/png");//这其实是将canvas转成了图片,并返回图片的所有内容数据,如下即可显示图片
1
img
src=imgSrc
/