通过 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-plugin-ad-admob 通过 phonegap 构建,无法加载和显示广告
通过 Cordova/Phonegap 应用程序创建一个可以由另一个应用程序 (ios) 打开的文件?
Cordova/Phonegap 通过 JavaScript inappbrowser 打印