Reproduzir som no Phonegap app para Android

? Malcolm Frexner @ | Original: StackOverFlow
---

Eu tento reproduzir um arquivo mp3. Isso funciona se eu alterar o caminho para o arquivo no servidor web local, mas se eu executar isso em um dispositivo Android o som não é reproduzido e nenhum erro é mostrado .

Estou bastante shure que o arquivo mp3 não é encontrado, mas eu ainda não sei como corrigi-lo .

Este é o HTML

  <body>

        <audio id="successSound" src="/android_asset/www/sound/successSound.mp3" type="audio/mpeg" ></audio>
           <audio id="errorSound" src="/android_asset/www/sound/errorSound.mp3" type="audio/mpeg" ></audio>
<!-- some more UI -->
  </body>

Este é o Javascript

document.getElementById('errorSound').play();

O é a estrutura do arquivo

phonyapp
`-- www
    `-- index.html
        |-- sound
        |   |-- errorSound.mp3
        |   `-- successSound.mp3
        |-- res
        `-- spec

Edit 1

I tried

<audio id="successSound" src="sound/successSound.mp3" type="audio/mpeg" ></audio>

Isso funcionou em cromo no meu servidor web local, mas não no Android.

I tried

<audio id="successSound" src="http://html5multimedia.com/media/sayHello.mp3" type="audio/mpeg" ></audio>

Isso funcionou, mas eu preciso para obter arquivos locais jogar

---

Top 5 Responder

1Joram Teusink @

Você tentou remover o /android_asset/www/ parte em seu código ? Seu aplicativo funciona como um site e ele acha que sua raiz é a pasta www própria .

Edit: Vou editar comentários. Código não mostrando alguma forma.

2SatelliteSD @

Se você estiver usando arquivos locais, tente fazer referência a eles com src="file:///yourpath/sayHello.mp3"

3Surajit Sarkar @

O método de jogo que a API HTML5 fornece é útil para reproduzir arquivos de mídia disponíveis na web.Phonegap fornece o plugin de mídia para reproduzir mídia files.I local, check-out o seu código e executar o som com sucesso, fazendo a seguinte verificação changes.Please em seu fim.

1.Add a seguinte linha ao config.xml

<gap:plugin name="org.apache.cordova.media" />

2.Replace as linhas em index.html

<button onclick="document.getElementById('successSound').play()">Play successSound local</button>
<button onclick="document.getElementById('successSound').play()">Play successSound local</button>

com estas linhas

<button onclick="playAudio('successSound')">Play successSound local</button>
<button onclick="playAudio('errorSound')">Play errorSoundlocal</button>

3.Adicionar a seguinte função para js / index.js

function playAudio(id) {
    var audioElement = document.getElementById(id);
    var url = audioElement.getAttribute('src');
    var my_media = new Media(url,
            // success callback
             function () { console.log("playAudio():Audio Success"); },
            // error callback
             function (err) { console.log("playAudio():Audio Error: " + err); }
    );
           // Play audio
    my_media.play();
}
4Praveen @

Use this code

  <body>

    <audio id="successSound" src="file:///android_asset/www/sound/successSound.mp3"      type="audio/mpeg" ></audio>
       <audio id="errorSound" src="file///android_asset/www/sound/errorSound.mp3"   type="audio/mpeg" ></audio>
<!-- some more UI -->
 </body>