-
Notifications
You must be signed in to change notification settings - Fork 2
/
svgtogif.js
53 lines (52 loc) · 1.52 KB
/
svgtogif.js
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
var svg = svg2,
svgData = new XMLSerializer().serializeToString(svg),
img = document.createElement("img"),
interval = null,
first = true,
gif = new GIF({
workers: 4,
quality: 10,
width: parseInt(svg2.getAttribute('width')),
height: parseInt(svg2.getAttribute('height'))
}),
currentTime,
sampleRate = 20;
img.setAttribute("src", "data:image/svg+xml;base64," + btoa(svgData));
var max=0, maxElement=null;
$('#svg2 animateMotion, #svg2 animate, #svg animateTransform').each(function(){
var duration = parseFloat(this.getAttribute('dur'));
if(duration > max){
maxElement = this;
max = duration;
}
})
maxElement.onrepeat = function(){
if(first){
currentTime = new Date().getTime();
interval = setInterval(draw, sampleRate);
first = !first;
}
else if(interval){
clearInterval(interval);
interval = null;
draw();
gif.render();
}
}
gif.on('finished', function(blob) {
var newGif = new Image();
newGif.src = URL.createObjectURL(blob);
document.body.appendChild(newGif);
});
draw = function(){
var canvas = document.createElement('canvas'),
ctx = canvas.getContext("2d"),
newTime = new Date().getTime();
canvas.width = gif.options.width;
canvas.height = gif.options.height;
ctx.fillStyle = "#fff";
ctx.fillRect(0, 0, canvas.width, canvas.height);
ctx.drawImage(img, 0, 0);
gif.addFrame(ctx, {delay:newTime-currentTime});
currentTime = newTime;
}