forked from skjApp/HTML5-Examples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCanvasAnimationUsingAnimationTimingAPIWithFPSCounting.htm
115 lines (88 loc) · 2.79 KB
/
CanvasAnimationUsingAnimationTimingAPIWithFPSCounting.htm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
<!DOCTYPE HTML>
<html>
<head>
<title>Canvas Animation Using Animation Timing API</title>
</head>
<body>
<canvas id = 'canvas1' width = '500px' height = '500px'>
</canvas>
<input id = 'button1' type='button' value = 'Start Animation' onclick = startAnimation() />
<div id = 'div1'>0
</div>
<script type="text/javascript">
var canvas1 = document.getElementById('canvas1') ;
var ctx = canvas1.getContext('2d') ;
var requestAnimationFrame = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || window.msRequestAnimationFrame || window.oRequestAnimationFrame ;
var div1 = document.getElementById('div1') ;
var animationData =
{
'currentFrame' : 0 ,
'x' : 10,
'y' : 10,
'imageSrc' : 'https://github.com/skjApp/OpenGraphics/raw/master/BalloonBoy1(416x78).png' ,
"frames": [
{'xOffset': 0,'yOffset':0, 'width': 41,'height': 78}, // frame 0
{'xOffset': 41,'yOffset':0, 'width': 33,'height': 78}, // frame 1
{'xOffset': 74,'yOffset':0, 'width': 32,'height': 78}, // frame 2
{'xOffset':106,'yOffset':0, 'width': 34,'height': 78}, // frame 3
{'xOffset':140,'yOffset':0, 'width': 33,'height': 78}, // frame 4
{'xOffset':173,'yOffset':0, 'width': 35,'height': 78}, // frame 5
]
} ;
var img ;
function loadAnimation()
{
img = new Image() ;
img.src = animationData['imageSrc'] ;
}
loadAnimation() ;
var count = 0 ;
var time = 0 ;
var firstTime = 0 ;
function animate()
{
ctx.fillColor = 'black' ;
ctx.fillRect(0,0,500,500) ;
var x = animationData['x'] ;
var y = animationData['y'] ;
var currentFrame = animationData['currentFrame']
var frame = animationData['frames'][currentFrame] ;
var xOffset = frame['xOffset'] ;
var yOffset = frame['yOffset'] ;
var width = frame['width'] ;
var height = frame['height'] ;
if(img != undefined)
{
ctx.drawImage(img, xOffset, yOffset, width, height, x, y, width, height) ;
}
// Updating Current Frame
if(currentFrame < 5)
{
animationData['currentFrame'] = animationData['currentFrame'] + 1 ;
}
else
{
animationData['currentFrame'] = 0 ;
}
// Updation x
animationData['x'] = animationData['x'] + 1 ;
}
function startAnimation()
{
animationLoop() ;
}
function animationLoop()
{
time = Math.floor(Date.now()/1000) ;
if(firstTime == 0)
{
firstTime = time ;
}
animate() ;
requestAnimationFrame(animationLoop) ;
count++ ;
div1.innerHTML = 'Average Frames Per Second : ' + (count/(time - firstTime)) ;
}
</script>
</body>
</html>