通过 phonegap 和 cordova for Android 播放音频

Posted

技术标签:

【中文标题】通过 phonegap 和 cordova for Android 播放音频【英文标题】:Playing audio via phonegap and cordova for Android 【发布时间】:2013-01-29 13:20:17 【问题描述】:

我一直在为 android 编写测试应用程序而乱七八糟,但在播放音频文件时遇到了问题。我的问题在于,一旦页面加载音频文件就不会播放,并且不会通过按钮单击播放

我正在使用 cordova 的示例来播放音频,但我无法弄清楚为什么音频会立即播放

谢谢

脚本

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

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

        // Cordova is ready
        //
        function onDeviceReady() 
            playAudio("/android_asset/www/audio/audio.mp3");
        

        // Audio player
        //
        var my_media = null;
        var mediaTimer = null;
    function playAudio(src) 
            if (my_media == null) 
                // Create Media object from src
                my_media = new Media(src, onSuccess, onError);
             // else play current audio
            // 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);
            
        

</script>

html 按钮点击

<a class="button" onclick="playaudio('/android_asset/www/audio/audio.mp3')";>Play that audio!</a>

【问题讨论】:

您在DeviceReady上执行playaudio方法,导致页面加载时播放声音。 【参考方案1】:

因为onDeviceReady()addEventListener 的侦听器回调。

因此,每当此侦听器实例化您的 onDeviceReady() 方法时,都会自动调用。

从那个方法你调用playAudio() 方法,这就是你的音频开始自动播放的原因。

onDeviceReady()回调函数中移除这个playAudio()方法调用。

编辑:

改变这个

<a class="button" onclick="playaudio('/android_asset/www/audio/audio.mp3')";>Play that audio!</a>

与,

<a class="button" onclick="playAudio('/android_asset/www/audio/audio.mp3');">Play that audio!</a>

【讨论】:

嗨 - 我已将其删除,现在根本无法播放音频 感谢您的回复 - 更改了代码但仍然无法正常工作 @Grimlockz 检查您是否通过单击按钮正确拼写playAudio,并在playAudio 中添加警报以检查方法是否被调用? 我已经修改了代码,但仍然无法正常工作。它不能被调用 感谢您的帮助,您对按钮进行了哪些更改?

以上是关于通过 phonegap 和 cordova for Android 播放音频的主要内容,如果未能解决你的问题,请参考以下文章

Cordova/PhoneGap - 通过应用商店验证

cordova-plugin-ad-admob 通过 phonegap 构建,无法加载和显示广告

通过 Cordova/Phonegap 应用程序创建一个可以由另一个应用程序 (ios) 打开的文件?

Cordova/Phonegap 通过 JavaScript inappbrowser 打印

使用 Phonegap 3.3.0 for ios 访问文件

如何通过绝对路径访问我的应用程序文件 - windows phone - Phonegap/Cordova