html5中文学习网

您的位置: 首页 > html5教程 > 入门教程 » 正文

HTML5 Canvas draw方法制作动画效果示例_html5教程技巧

[ ] 已经帮助:人解决问题
点评:首先要准备一张有连续帧的图片,然后利用HTML5 Canvas的draw方法在不同的时间间隔绘制不同的帧,这样看起来就像动画在播放,关键技术点及实例代码如下,感兴趣的朋友可以参考下哈,希望对大家有所帮助
 
 

HTML5 Canvas动画效果演示 jK4HTML5中文学习网 - HTML5先行者学习网
主要思想: jK4HTML5中文学习网 - HTML5先行者学习网
首先要准备一张有连续帧的图片,然后利用HTML5 Canvas的draw方法在不同的时间间隔绘制不同的帧,这样看起来就像动画在播放。 jK4HTML5中文学习网 - HTML5先行者学习网
关键技术点: jK4HTML5中文学习网 - HTML5先行者学习网
JavaScript 函数setTimeout()有两个参数,第一个是参数可以传递一个JavaScript方法, jK4HTML5中文学习网 - HTML5先行者学习网
另外一个参数代表间隔时间,单位为毫秒数。代码示例: jK4HTML5中文学习网 - HTML5先行者学习网
setTimeout( update, 1000/30); jK4HTML5中文学习网 - HTML5先行者学习网
Canvas的API-drawImage()方法,需要指定全部9个参数: jK4HTML5中文学习网 - HTML5先行者学习网
ctx.drawImage(myImage, offw, offh, width,height, x2, y2, width, height); jK4HTML5中文学习网 - HTML5先行者学习网
其中offw, offh是指源图像的起始坐标点,width, height表示源图像的宽与高,x2,y2表 jK4HTML5中文学习网 - HTML5先行者学习网
示源图像在目标Canvas上的起始坐标点。 jK4HTML5中文学习网 - HTML5先行者学习网
一个22帧的大雁飞行图片实现的效果: jK4HTML5中文学习网 - HTML5先行者学习网
 jK4HTML5中文学习网 - HTML5先行者学习网
源图像: jK4HTML5中文学习网 - HTML5先行者学习网
 jK4HTML5中文学习网 - HTML5先行者学习网
程序代码: jK4HTML5中文学习网 - HTML5先行者学习网
jK4HTML5中文学习网 - HTML5先行者学习网
 jK4HTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
jK4HTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html> jK4HTML5中文学习网 - HTML5先行者学习网
<html> jK4HTML5中文学习网 - HTML5先行者学习网
<head> jK4HTML5中文学习网 - HTML5先行者学习网
<meta http-equiv="X-UA-Compatible" content="chrome=IE8"> jK4HTML5中文学习网 - HTML5先行者学习网
<meta http-equiv="Content-type" content="text/html;charset=UTF-8"> jK4HTML5中文学习网 - HTML5先行者学习网
<title>Canvas Mouse Event Demo</title> jK4HTML5中文学习网 - HTML5先行者学习网
<link href="default.css" rel="stylesheet" /> jK4HTML5中文学习网 - HTML5先行者学习网
<script> jK4HTML5中文学习网 - HTML5先行者学习网
var ctx = null; // global variable 2d context jK4HTML5中文学习网 - HTML5先行者学习网
var started = false; jK4HTML5中文学习网 - HTML5先行者学习网
var mText_canvas = null; jK4HTML5中文学习网 - HTML5先行者学习网
var x = 0, y =0; jK4HTML5中文学习网 - HTML5先行者学习网
var frame = 0; // 22 5*5 + 2 jK4HTML5中文学习网 - HTML5先行者学习网
var imageReady = false; jK4HTML5中文学习网 - HTML5先行者学习网
var myImage = null; jK4HTML5中文学习网 - HTML5先行者学习网
var px = 300; jK4HTML5中文学习网 - HTML5先行者学习网
var py = 300; jK4HTML5中文学习网 - HTML5先行者学习网
var x2 = 300; jK4HTML5中文学习网 - HTML5先行者学习网
var y2 = 0; jK4HTML5中文学习网 - HTML5先行者学习网
window.onload = function() { jK4HTML5中文学习网 - HTML5先行者学习网
var canvas = document.getElementById("animation_canvas"); jK4HTML5中文学习网 - HTML5先行者学习网
console.log(canvas.parentNode.clientWidth); jK4HTML5中文学习网 - HTML5先行者学习网
canvas.width = canvas.parentNode.clientWidth; jK4HTML5中文学习网 - HTML5先行者学习网
canvas.height = canvas.parentNode.clientHeight; jK4HTML5中文学习网 - HTML5先行者学习网
if (!canvas.getContext) { jK4HTML5中文学习网 - HTML5先行者学习网
console.log("Canvas not supported. Please install a HTML5 compatible browser."); jK4HTML5中文学习网 - HTML5先行者学习网
return; jK4HTML5中文学习网 - HTML5先行者学习网
} jK4HTML5中文学习网 - HTML5先行者学习网
// get 2D context of canvas and draw rectangel jK4HTML5中文学习网 - HTML5先行者学习网
ctx = canvas.getContext("2d"); jK4HTML5中文学习网 - HTML5先行者学习网
ctx.fillStyle="black"; jK4HTML5中文学习网 - HTML5先行者学习网
ctx.fillRect(0, 0, canvas.width, canvas.height); jK4HTML5中文学习网 - HTML5先行者学习网
myImage = document.createElement('img'); jK4HTML5中文学习网 - HTML5先行者学习网
myImage.src = "../robin.png"; jK4HTML5中文学习网 - HTML5先行者学习网
myImage.onload = loaded(); jK4HTML5中文学习网 - HTML5先行者学习网
} jK4HTML5中文学习网 - HTML5先行者学习网
function loaded() { jK4HTML5中文学习网 - HTML5先行者学习网
imageReady = true; jK4HTML5中文学习网 - HTML5先行者学习网
setTimeout( update, 1000/30); jK4HTML5中文学习网 - HTML5先行者学习网
} jK4HTML5中文学习网 - HTML5先行者学习网
function redraw() { jK4HTML5中文学习网 - HTML5先行者学习网
ctx.clearRect(0, 0, 460, 460) jK4HTML5中文学习网 - HTML5先行者学习网
ctx.fillStyle="black"; jK4HTML5中文学习网 - HTML5先行者学习网
ctx.fillRect(0, 0, 460, 460); jK4HTML5中文学习网 - HTML5先行者学习网
// find the index of frames in image jK4HTML5中文学习网 - HTML5先行者学习网
var height = myImage.naturalHeight/5; jK4HTML5中文学习网 - HTML5先行者学习网
var width = myImage.naturalWidth/5; jK4HTML5中文学习网 - HTML5先行者学习网
var row = Math.floor(frame / 5); jK4HTML5中文学习网 - HTML5先行者学习网
var col = frame - row * 5; jK4HTML5中文学习网 - HTML5先行者学习网
var offw = col * width; jK4HTML5中文学习网 - HTML5先行者学习网
var offh = row * height; jK4HTML5中文学习网 - HTML5先行者学习网
// first robin jK4HTML5中文学习网 - HTML5先行者学习网
px = px - 5; jK4HTML5中文学习网 - HTML5先行者学习网
py = py - 5; jK4HTML5中文学习网 - HTML5先行者学习网
if(px < -50) { jK4HTML5中文学习网 - HTML5先行者学习网
px = 300; jK4HTML5中文学习网 - HTML5先行者学习网
} jK4HTML5中文学习网 - HTML5先行者学习网
if(py < -50) { jK4HTML5中文学习网 - HTML5先行者学习网
py = 300; jK4HTML5中文学习网 - HTML5先行者学习网
} jK4HTML5中文学习网 - HTML5先行者学习网
//var rate = (frame+1) /22; jK4HTML5中文学习网 - HTML5先行者学习网
//var rw = Math.floor(rate * width); jK4HTML5中文学习网 - HTML5先行者学习网
//var rh = Math.floor(rate * height); jK4HTML5中文学习网 - HTML5先行者学习网
ctx.drawImage(myImage, offw, offh, width, height, px, py, width, height); jK4HTML5中文学习网 - HTML5先行者学习网
// second robin jK4HTML5中文学习网 - HTML5先行者学习网
x2 = x2 - 5; jK4HTML5中文学习网 - HTML5先行者学习网
y2 = y2 + 5; jK4HTML5中文学习网 - HTML5先行者学习网
if(x2 < -50) { jK4HTML5中文学习网 - HTML5先行者学习网
x2 = 300; jK4HTML5中文学习网 - HTML5先行者学习网
y2 = 0; jK4HTML5中文学习网 - HTML5先行者学习网
} jK4HTML5中文学习网 - HTML5先行者学习网
ctx.drawImage(myImage, offw, offh, width, height, x2, y2, width, height); jK4HTML5中文学习网 - HTML5先行者学习网
} jK4HTML5中文学习网 - HTML5先行者学习网
function update() { jK4HTML5中文学习网 - HTML5先行者学习网
redraw(); jK4HTML5中文学习网 - HTML5先行者学习网
frame++; jK4HTML5中文学习网 - HTML5先行者学习网
if (frame >= 22) frame = 0; jK4HTML5中文学习网 - HTML5先行者学习网
setTimeout( update, 1000/30); jK4HTML5中文学习网 - HTML5先行者学习网
} jK4HTML5中文学习网 - HTML5先行者学习网
</script> jK4HTML5中文学习网 - HTML5先行者学习网
</head> jK4HTML5中文学习网 - HTML5先行者学习网
<body> jK4HTML5中文学习网 - HTML5先行者学习网
<h1>HTML Canvas Animations Demo - By Gloomy Fish</h1> jK4HTML5中文学习网 - HTML5先行者学习网
<pre>Play Animations</pre> jK4HTML5中文学习网 - HTML5先行者学习网
<div id="my_painter"> jK4HTML5中文学习网 - HTML5先行者学习网
<canvas id="animation_canvas"></canvas> jK4HTML5中文学习网 - HTML5先行者学习网
</div> jK4HTML5中文学习网 - HTML5先行者学习网
</body> jK4HTML5中文学习网 - HTML5先行者学习网
</html> jK4HTML5中文学习网 - HTML5先行者学习网
 

jK4HTML5中文学习网 - HTML5先行者学习网
发现上传透明PNG格式有点问题,所以我上传不透明的图片。可以用其它图片替换,替换以后请修改最大帧数从22到你的实际帧数即可运行。jK4HTML5中文学习网 - HTML5先行者学习网
 jK4HTML5中文学习网 - HTML5先行者学习网

 
 
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助