-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbackground.js
65 lines (56 loc) · 1.65 KB
/
background.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
54
55
56
57
58
59
60
61
62
63
64
65
(function(){
var scales = [1,2];
var iconSize = 19;
var sheetWidth = 6;
var spriteImage = document.createElement('img');
spriteImage.addEventListener("load",initContexts);
spriteImage.src = '/images/sprites.svg';
var scaleCtxs = [];
function initContexts() {
scales.forEach(function(scale) {
var spriteCanvas = document.createElement('canvas');
spriteCanvas.width = spriteImage.width * scale;
spriteCanvas.height = spriteImage.height * scale;
console.log(spriteCanvas);
scaleCtxs[scale] = spriteCanvas.getContext('2d');
scaleCtxs[scale].drawImage(spriteImage, 0, 0,
spriteCanvas.width, spriteCanvas.height);
console.log(spriteCanvas);
console.log(scaleCtxs[scale]);
});
}
function getFrame(i) {
var x = i % sheetWidth;
var y = Math.floor(i / sheetWidth);
var dict = {};
scales.forEach(function(scale) {
var renderSize = iconSize * scale;
var left = x * renderSize;
var top = y * renderSize;
dict[renderSize] = scaleCtxs[scale].getImageData(
left, top, renderSize, renderSize);
});
return dict;
}
var spinterval = null;
function spinIcon() {
var frame = 0;
function advanceFrame() {
++frame;
var displayFrame = frame < 36 ? frame : 36 + (frame % 36);
chrome.browserAction.setIcon({imageData: getFrame(displayFrame)});
}
spinterval = setInterval(advanceFrame,20)
}
function stopIcon() {
clearInterval(spinterval); spinterval = null;
chrome.browserAction.setIcon({path: {
"19": "images/icon-19.png",
"38": "images/icon-38.png"
}});
}
function toggleSpinning() {
if (spinterval) stopIcon(); else spinIcon();
}
chrome.browserAction.onClicked.addListener(toggleSpinning);
})();