]> 105106.c2e0p.group Git - sound.git/blobdiff - sound.html
Set default volume; add canplaythrough listener.
[sound.git] / sound.html
index 34889fa9696ccb6fd0bdfcaecc61a1ded261fd1b..67b4059a7a4443e54a2dba2bd110d694558aae5e 100644 (file)
@@ -4,15 +4,56 @@
        <title>sound test</title>
        <script src="sound.js"></script>
        <script>
-       var sound = new Sound();
-       sound.src = 'Coin.wav';
-       sound.play();
-       sound.addEventListener('ended', function() { document.body.appendChild(document.createTextNode('ended')); })
+
+       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('loadstart', eventLogger);
+               audio.addEventListener('pause', eventLogger);
+               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);
+       }
+
        </script>
 </head>
-<body>
+<body onload="onload()">
 
-<button onclick="sound.play()">play</button><button onclick="sound.pause()">pause</button>
+       <div>
+               <button onclick="audio.play()">play</button>
+               <button onclick="audio.pause()">pause</button>
+               <button onclick="audio.muted = !audio.muted">mute</button>
+               <input type="range" min="0" max="1" step="0.01" value="1" onchange="audio.volume = event.target.value" />
+               <button onclick="audio.loop = !audio.loop">loop</button>
+       </div>
 
 </body>
 </html>
\ No newline at end of file