2012-05-01 55 views
3

嗨,我嘗試使用phoneGap媒體對象來播放音頻內容,但我得到這個錯誤 未捕獲ReferenceError:媒體未定義我得到這個例如代碼的PhoneGap文檔http://docs.phonegap.com/en/1.0.0/phonegap_media_media.md.html enter image description here使用媒體對象來記錄和播放設備上的音頻文件

我使用下面的代碼:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" 
         "http://www.w3.org/TR/html4/strict.dtd"> 
<html> 
    <head> 
    <title>Media Example</title> 

    <script type="text/javascript" charset="utf-8" src="phonegap-1.4.1.js"></script> 
    <script type="text/javascript" charset="utf-8"> 

    // Wait for PhoneGap to load 
    // 
    document.addEventListener("deviceready", onDeviceReady, false); 

    // PhoneGap is ready 
    // 
    function onDeviceReady() { 
     playAudio("http://audio.ibeat.org/content/p1rj1s/p1rj1s_-_rockGuitar.mp3"); 
    } 

    // Audio player 
    // 
    var my_media = null; 
    var mediaTimer = null; 

    // Play audio 
    // 
    function playAudio(src) { 
     // Create Media object from src 
     my_media = new Media(src, onSuccess, onError); 

     // Play audio 
     my_media.play(); 

     // Update my_media position every second 
     if (mediaTimer == null) { 
      mediaTimer = setInterval(function() { 
       // get my_media position 
       my_media.getCurrentPosition(
        // success callback 
        function(position) { 
         if (position > -1) { 
          setAudioPosition((position) + " sec"); 
         } 
        }, 
        // error callback 
        function(e) { 
         console.log("Error getting pos=" + e); 
         setAudioPosition("Error: " + e); 
        } 
       ); 
      }, 1000); 
     } 
    } 

    // Pause audio 
    // 
    function pauseAudio() { 
     if (my_media) { 
      my_media.pause(); 
     } 
    } 

    // Stop audio 
    // 
    function stopAudio() { 
     if (my_media) { 
      my_media.stop(); 
     } 
     clearInterval(mediaTimer); 
     mediaTimer = null; 
    } 

    // onSuccess Callback 
    // 
    function onSuccess() { 
     console.log("playAudio():Audio Success"); 
    } 

    // onError Callback 
    // 
    function onError(error) { 
     alert('code: ' + error.code + '\n' + 
       'message: ' + error.message + '\n'); 
    } 

    // Set audio position 
    // 
    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');">Play Audio</a> 
    <a href="#" class="btn large" onclick="pauseAudio();">Pause Playing Audio</a> 
    <a href="#" class="btn large" onclick="stopAudio();">Stop Playing Audio</a> 
    <p id="audio_position"></p> 
    </body> 
</html> 

任何想法,請,謝謝ü非常

+1

您是否更改了對phonegap.js的引用以匹配您使用的版本? –

+0

這是我又一次我發現這個代碼工作的問題找到它只是與活動中使用的LoadUrl方法的問題,我使用了錯誤的網址 –

+0

先生@SimonMacDonald是這是最好的方式來動畫遊戲添加聲音按鈕,翻轉卡... –

回答

1

林當我在瀏覽器中打開鏈接無法播放聲音時,提供播放聲音無法正常工作。

非常和善烏爾rockGuitar.mp3存儲你的資產/ WWW文件夾內,並同時播放該文件提供文件的src作爲

src= "/android_asset/www/rockGuitar.mp3"; 
newMedia= new Media(src,onSuccess1,onError); 

或提供聲音的src工作環節。

+0

我測試它,它適用於您的情況下鉻與罰款我認爲這是與瀏覽器的問題謝謝 –

相關問題