+
+ var audio;
+
+ function log(text) {
+ var log = document.getElementById('log');
+ if (!log) {
+ log = document.createElement('div');
+ log.id = 'log';
+ document.body.appendChild(log);
+ }
+
+ var line = document.createElement('div');
+ line.appendChild(document.createTextNode(text));
+ log.insertBefore(line, log.firstChild);
+ }
+
+ function eventLogger(event) {
+ log(event.type);
+ }
+
+ function onload() {
+ audio = new Audio();
+ audio.autoplay = false;
+ audio.src = 'Coin.wav';
+ audio.preload = 'auto';
+ audio.addEventListener('canplaythrough', eventLogger);
+ audio.addEventListener('emptied', eventLogger);
+ audio.addEventListener('ended', eventLogger);
+ audio.addEventListener('ended', updateTime);
+ audio.addEventListener('loadstart', eventLogger);
+ audio.addEventListener('pause', eventLogger);
+ audio.addEventListener('pause', updateTime);
+ audio.addEventListener('play', eventLogger);
+ audio.addEventListener('playing', eventLogger);
+ audio.addEventListener('progress', eventLogger);
+ audio.addEventListener('suspend', eventLogger);
+ audio.addEventListener('timeupdate', eventLogger);
+ audio.addEventListener('volumechange', eventLogger);
+ audio.addEventListener('waiting', eventLogger);
+ audio.addEventListener('timeupdate', updateTime);
+ audio.addEventListener('durationchange', eventLogger);
+ audio.addEventListener('durationchange', updateDuration);
+ audio.addEventListener('ratechange', eventLogger);
+ audio.addEventListener('ratechange', updateRate);
+ }
+
+ function formatTime(time) {
+ var seconds = (time % 60).toFixed(0);
+ var minutes = (time / 60).toFixed(0);
+ return ("0" + minutes).substr(-2, 2) + ':' + ("0" + seconds).substr(-2, 2);
+ }
+
+ function updateTime() {
+ var time = document.getElementById('time');
+ var currentTime = audio.currentTime;
+ time.innerText = formatTime(currentTime);
+
+ var timeline = document.getElementById('timeline');
+ timeline.value = currentTime;
+ }
+
+ function updateDuration() {
+ var duration = document.getElementById('duration');
+ duration.innerText = formatTime(audio.duration);
+
+ var timeline = document.getElementById('timeline');
+ timeline.max = audio.duration;
+ }
+
+ function updateRate() {
+ var rate = document.getElementById('rate');
+ rate.value = audio.playbackRate;
+ }
+