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:
Jürg Lehni 2011-05-14 13:04:02 +03:00
parent a775e66632
commit 3feb45addc
31 changed files with 60 additions and 77 deletions

View file

@ -52,5 +52,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -70,5 +70,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -300,5 +300,5 @@
</style> </style>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -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>

View file

@ -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

View file

@ -44,5 +44,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -71,5 +71,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -27,5 +27,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -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>

View file

@ -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>

View file

@ -15,5 +15,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -43,5 +43,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -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

View file

@ -23,5 +23,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -92,5 +92,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -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>

View file

@ -26,5 +26,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -31,5 +31,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -68,5 +68,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -78,5 +78,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -40,5 +40,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -113,5 +113,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -40,5 +40,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -78,5 +78,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -26,5 +26,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -44,5 +44,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -84,5 +84,5 @@
</script> </script>
</head> </head>
<body> <body>
<canvas id='canvas' resize></canvas> <canvas id="canvas" resize keepalive="true"></canvas>
</body> </body>

View file

@ -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);
}; };
}; };

View file

@ -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>');
}
} }