mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
Add keepalive attribute to canvas to tag that controls wether it animates in background in emulated requestAnimationFrame() function, and use it in all example files.
This commit is contained in:
parent
a775e66632
commit
3feb45addc
31 changed files with 60 additions and 77 deletions
|
@ -52,5 +52,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -70,5 +70,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -300,5 +300,5 @@
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -47,5 +47,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body style='background-color:black'>
|
<body style='background-color:black'>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -78,5 +78,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
File diff suppressed because one or more lines are too long
|
@ -44,5 +44,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -71,5 +71,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -27,5 +27,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -82,5 +82,5 @@
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Click to add circles:</p>
|
<p>Click to add circles:</p>
|
||||||
<canvas id='canvas' resize stats></canvas>
|
<canvas id="canvas" resize stats keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -42,5 +42,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body style='background-color: black'>
|
<body style='background-color: black'>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -15,5 +15,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -43,5 +43,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -29,5 +29,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
File diff suppressed because one or more lines are too long
|
@ -23,5 +23,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -92,5 +92,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -81,5 +81,5 @@
|
||||||
Drag segment handles and points to manipulate them.
|
Drag segment handles and points to manipulate them.
|
||||||
Close the path to start a new one.
|
Close the path to start a new one.
|
||||||
</p>
|
</p>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -26,5 +26,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -31,5 +31,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -68,5 +68,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -78,5 +78,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -40,5 +40,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -113,5 +113,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -40,5 +40,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -78,5 +78,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -26,5 +26,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -44,5 +44,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -84,5 +84,5 @@
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id='canvas' resize></canvas>
|
<canvas id="canvas" resize keepalive="true"></canvas>
|
||||||
</body>
|
</body>
|
|
@ -99,52 +99,42 @@ DomEvent.requestAnimationFrame = new function() {
|
||||||
|
|
||||||
// So we need to fake it. Define helper functions first:
|
// So we need to fake it. Define helper functions first:
|
||||||
var callbacks = [],
|
var callbacks = [],
|
||||||
fastRate = 1000 / 60,
|
|
||||||
slowRate = 1000,
|
|
||||||
focused = true,
|
focused = true,
|
||||||
timer;
|
timer;
|
||||||
|
|
||||||
// Installs interval timer that checks all callbacks. This results in much
|
DomEvent.add(window, {
|
||||||
// faster animations than repeatedly installing timout timers.
|
focus: function() {
|
||||||
function setTimer(timeout) {
|
focused = true;
|
||||||
window.clearInterval(timer);
|
},
|
||||||
|
blur: function() {
|
||||||
|
focused = false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return function(callback, element) {
|
||||||
|
// See if we can handle natively first
|
||||||
|
if (request)
|
||||||
|
return request(callback, element);
|
||||||
|
// If not, do the callback handling ourself:
|
||||||
|
callbacks.push([callback, element]);
|
||||||
|
if (!timer) {
|
||||||
|
// Installs interval timer that checks all callbacks. This results
|
||||||
|
// in faster animations than repeatedly installing timout timers.
|
||||||
timer = window.setInterval(function() {
|
timer = window.setInterval(function() {
|
||||||
// Checks all installed callbacks for element visibility and execute
|
// Checks all installed callbacks for element visibility and
|
||||||
// if needed.
|
// execute if needed.
|
||||||
if (!focused)
|
|
||||||
return;
|
|
||||||
for (var i = callbacks.length - 1; i >= 0; i--) {
|
for (var i = callbacks.length - 1; i >= 0; i--) {
|
||||||
var entry = callbacks[i],
|
var entry = callbacks[i],
|
||||||
func = entry[0],
|
func = entry[0],
|
||||||
element = entry[1];
|
element = entry[1];
|
||||||
if (!element || DomElement.isVisible(element)) {
|
if (!element || element.getAttribute('keepalive') == 'true'
|
||||||
|
|| focused && DomElement.isVisible(element)) {
|
||||||
// Handle callback and remove it from callbacks list.
|
// Handle callback and remove it from callbacks list.
|
||||||
callbacks.splice(i, 1);
|
callbacks.splice(i, 1);
|
||||||
func(+new Date);
|
func(+new Date);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}, timeout);
|
}, 1000 / 60);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!paper.debug) {
|
|
||||||
DomEvent.add(window, {
|
|
||||||
focus: function() {
|
|
||||||
focused = true;
|
|
||||||
// Switch to falst checkCallback calls while window is focused.
|
|
||||||
timer && setTimer(fastRate);
|
|
||||||
},
|
|
||||||
blur: function() {
|
|
||||||
focused = false;
|
|
||||||
// Switch to slow checkCallback calls while window is blured.
|
|
||||||
timer && setTimer(slowRate);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return function(callback, element) {
|
|
||||||
if (request)
|
|
||||||
return request(callback, element);
|
|
||||||
callbacks.push([callback, element]);
|
|
||||||
!timer && setTimer(fastRate);
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
@ -108,12 +108,5 @@ if (window.tests) {
|
||||||
for (var i = 0; i < sources.length; i++) {
|
for (var i = 0; i < sources.length; i++) {
|
||||||
document.write('<script type="text/javascript" src="' + (window.root || '')
|
document.write('<script type="text/javascript" src="' + (window.root || '')
|
||||||
+ sources[i] + '"></script>');
|
+ sources[i] + '"></script>');
|
||||||
if (sources[i] === 'src/paper.js') {
|
|
||||||
// Activate paper.debug for code loaded through load.js, as we're in
|
|
||||||
// development mode.
|
|
||||||
document.write('<script type="text/javascript">'
|
|
||||||
+ 'paper.debug = false;'
|
|
||||||
+ '</script>');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue