media.getDuration

Retorna la duración de un fichero de audio.

media.getDuration();

Descripción

La función media.getDuration es una función síncrona que retorna la duración del fichero de audio (si se conociera, y en segundos). Si la duración fuera desconocida, retornara -1.

Plataformas Soportadas

  • Android
  • iOS

Ejemplo Sencillo

    // Un reproductor de audio
    //
    var my_media = new Media(src, onSuccess, onError);

    // Obtiene la duración
    var counter = 0;
    var timerDur = setInterval(function() {
        counter = counter + 100;
        if (counter > 2000) {
            clearInterval(timerDur);
        }
        var dur = my_media.getDuration();
        if (dur > 0) {
            clearInterval(timerDur);
            document.getElementById('audio_duration').innerHTML = (dur) + " seg";
        }
   }, 100);

Ejemplo Completo

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
                          "http://www.w3.org/TR/html4/strict.dtd">
    <html>
      <head>
        <title>Ejemplo de Media</title>
    
        <script type="text/javascript" charset="utf-8" src="phonegap.js"></script>
        <script type="text/javascript" charset="utf-8">
    
        // Espere a que PhoneGap se inicie
        //
        document.addEventListener("deviceready", onDeviceReady, false);
    
        // PhoneGap esta listo
        //
        function onDeviceReady() {
            playAudio("http://audio.ibeat.org/content/p1rj1s/p1rj1s_-_rockGuitar.mp3");
        }
    
        // Un reproductor de audio
        //
        var my_media = null;
        var mediaTimer = null;
    
        // Reproduce el audio
        //
        function playAudio(src) {
            // Crea un objeto `Media` desde el argumento
            my_media = new Media(src, onSuccess, onError);
    
            // Reproduce el audio
            my_media.play();
    
            // Actualiza la posición cada segundo
            if (mediaTimer == null) {
                mediaTimer = setInterval(function() {
                    // Obtiene la posición actual
                    my_media.getCurrentPosition(
                        // Función 'callback' satisfactoria
                        function(position) {
                            if (position > -1) {
                                setAudioPosition((position) + " seg.");
                            }
                        },
                        // Función 'callback' de error
                        function(e) {
                            console.log("Error obteniendo posición" + e);
                            setAudioPosition("Error: " + e);
                        }
                    );
                }, 1000);
            }
        }
    
        // Pausa la reproducción
        // 
        function pauseAudio() {
            if (my_media) {
                my_media.pause();
            }
        }
    
        // Detiene la reproducción
        // 
        function stopAudio() {
            if (my_media) {
                my_media.stop();
            }
            clearInterval(mediaTimer);
            mediaTimer = null;
        }
    
        // Función 'callback' onSuccess
        //
        function onSuccess() {
            console.log("playAudio():Audio correcto");
        }
    
        // Función 'callback' onError
        //
        function onError(error) {
            alert('código: '  + error.code    + '\n' + 
                  'mensaje: ' + error.message + '\n');
        }
    
        // Muestra la posición
        // 
        function setAudioPosition(position) {
            document.getElementById('audio_position').innerHTML = position;
        }
    
        </script>
      </head>
      <body>
        <a href="#" class="btn large" onclick="playAudio('http://audio.ibeat.org/content/p1rj1s/p1rj1s_-_rockGuitar.mp3');">Reproducir</a>
        <a href="#" class="btn large" onclick="pauseAudio();">Pausa</a>
        <a href="#" class="btn large" onclick="stopAudio();">Detener</a>
        <p id="audio_position"></p>
      </body>
    </html>