X-Git-Url: http://id.pley.net/sound.git/blobdiff_plain/c20b1f29d05b360d2314dc3189cee0a024b276ca..refs/remotes/origin/master:/sound.html diff --git a/sound.html b/sound.html index d050524..af92487 100644 --- a/sound.html +++ b/sound.html @@ -29,28 +29,75 @@ audio.autoplay = false; audio.src = 'Coin.wav'; audio.preload = 'auto'; + audio.addEventListener('canplaythrough', eventLogger); + audio.addEventListener('emptied', eventLogger); audio.addEventListener('ended', eventLogger); - audio.addEventListener('play', 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('waiting', eventLogger); audio.addEventListener('volumechange', eventLogger); - audio.addEventListener('emptied', eventLogger); - audio.addEventListener('loadstart', eventLogger); - audio.addEventListener('progress', 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; } -
+ +
+
+ - + --:-- + + --:-- + +