Skip to content

Instantly share code, notes, and snippets.

@acip
Created November 21, 2019 18:39
Show Gist options
  • Save acip/96902e7d1df2c84964087972b1f49e3c to your computer and use it in GitHub Desktop.
Save acip/96902e7d1df2c84964087972b1f49e3c to your computer and use it in GitHub Desktop.
setTimeout vs requestAnimationFrame
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<img id="stimImg" style="position:absolute; top:100px; left:100px; display:none" width="300" height="300" src=""/>
<div id="stimText" style="position:absolute; top:100px; left:100px; display:none" >word stim</div>
<script>
class StimRenderer {
constructor(stimId, presTime, isi) {
this.stim = document.getElementById(stimId);
this.presTime = presTime;
this.isi = isi;
}
show() {
this.setVisibility('block');
}
hide() {
this.setVisibility('none');
}
setVisibility(visibility) {
this.stim.style.display = visibility;
}
renderWithTimeout() {
let toggler = 'show';
const toggle = () => {
let timer;
this[toggler]();
if (toggler === 'show') {
toggler = 'hide';
timer = this.presTime;
} else {
toggler = 'show';
timer = this.isi;
}
setTimeout(toggle, timer);
};
toggle();
}
renderWithRequestAnimationFrame() {
let lastRender = 0;
let toggler = 'hide';
const toggle = (timestamp) => {
const stateInterval = toggler === 'show' ? this.presTime : this.isi;
const sinceLastRender = timestamp - lastRender;
if (sinceLastRender >= stateInterval) {
// need to change state
toggler = toggler === 'show' ? 'hide' : 'show';
this[toggler]();
lastRender = timestamp;
}
window.requestAnimationFrame(toggle);
};
window.requestAnimationFrame(toggle);
}
}
const urlParams = new URLSearchParams(window.location.search);
const presTime = parseInt(urlParams.get('presTime')) || 5000;
const isi = parseInt(urlParams.get('isi')) || 1000;
const stimId = parseInt(urlParams.get('text')) ? 'stimText' : 'stimImg';
const renderMode = parseInt(urlParams.get('timeout')) ? 'renderWithTimeout' : 'renderWithRequestAnimationFrame';
console.log({presTime, isi, stimId, renderMode});
const renderer = new StimRenderer(stimId, presTime, isi);
renderer[renderMode]();
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment