我有一个示例phonegapp应用程序,它在应用程序的后台播放音频流(即kalimba.mp3)。在后台播放音频工作正常。当我按下设备主页按钮应用程序正在最小化但音频播放继续但当我按设备返回按钮时,应用程序将被终止,所以作为背景音频。
我添加了这一行,因为我没有点击我的.java文件中的后退按钮退出应用
super.setBooleanProperty("keepRunning", true);
但申请仍在终止。当我在Android设备中按下按钮或主页按钮并播放音频流直到我从任务管理器关闭应用程序时,我希望我的应用程序仍在运行。怎么做?
我使用的是Android V4.0.0。
这是我的代码
<html>
<head>
<title>Media Example</title>
<script type="text/javascript" charset="utf-8" src="cordova.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/Kalimba.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;
}
function disalert(){
alert("extra functionality is working fine");
}
</script>
</head>
<body>
<a href="#" class="btn large" onclick="playAudio('/android_asset/www/Kalimba.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>
<button onclick="disalert();">click to interupt</button>
</body>
</html>
答案 0 :(得分:2)
//Deviceready function
document.addEventListener('deviceready', function() {
document.addEventListener("backbutton", go_back, false);
}, false);
//Function for back button function
function go_back(){
}
答案 1 :(得分:0)
点击后退按钮后,您的应用程序应转到后台。试试这个
function onLoad() {
document.addEventListener("deviceready", onDeviceReady, false);
}
function onDeviceReady() {
document.addEventListener("backbutton", go_back, false);
}
function go_back(){
document.addEventListener("pause", onPause, false);
}
function onPause() {
//Move your application to background.....
}