如何在phonegap应用程序中按下Android设备后退按钮禁用退出功能?

时间:2013-10-03 08:00:20

标签: android cordova audio-streaming back-button

我有一个示例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>

2 个答案:

答案 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.....
          }