android - 阻止应用程序在后台运行

标签 android background app-store radio

现在我要写一个快速的问题,我正在编写一个应用程序,该应用程序应该能够流式传输完所有广播节目。

我现在需要做的是在停止音乐的同时,单击停止时不允许该应用在后台运行,但是我需要它也停止从后台运行而不退出该应用,因为这是一个停止音乐按钮。

我需要这个,因为我正在使用电话管理器来检测来电等,以便在用户通话时停止音乐

package com.beanie.samples.streaming;

import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;

import com.beanie.samples.streaming.R;
import com.beanie.samples.streaming.MyService;

import android.app.Activity;
import android.app.IntentService;
import android.app.Service;
import android.content.Context;
import android.content.Intent;
import android.media.MediaPlayer;
import android.media.MediaPlayer.OnBufferingUpdateListener;
import android.media.MediaPlayer.OnPreparedListener;
import android.os.Bundle;
import android.os.Environment;
import android.os.Handler;
import android.os.HandlerThread;
import android.os.IBinder;
import android.os.Looper;
import android.os.Message;
import android.telephony.PhoneStateListener;
import android.telephony.TelephonyManager;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ProgressBar;
import android.widget.Toast;

;



public class HomeActivity extends Activity implements OnClickListener {
      private static final String TAG = "MyServices";

    private final static String RADIO_STATION_URL = "http://195.154.237.162:8936/";

    private static final String START_STICKY = null;
      Button buttonPlay, buttonStopPlay;



      @Override
      public void onBackPressed() {

          android.os.Process.killProcess(android.os.Process.myPid());
          // This above line close correctly
      }








      public void ring()
                {
       Bundle savedInstanceState = null;
    super.onCreate(savedInstanceState);
      setContentView(R.layout.main);

       TelephonyManager telephonyManager = (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);     
          // register PhoneStateListener 
            PhoneStateListener callStateListener = new PhoneStateListener() {


           public void onCallStateChanged(int state, String incomingNumber) 
               {


                 // If phone ringing
           if(state==TelephonyManager.CALL_STATE_RINGING)
                    {
               stopPlaying();                                        
                       }
               // If incoming call received or making a call
                  if(state==TelephonyManager.CALL_STATE_OFFHOOK)
                      {
                      Toast.makeText(getApplicationContext(),"Music will keep playing after your call", Toast.LENGTH_LONG).show();
                      stopPlaying();

                         }


                  if(state==TelephonyManager.CALL_STATE_IDLE)
                       {
                     startPlaying();
                 Toast.makeText(getApplicationContext(),"Music Will Now Keep Playing!", Toast.LENGTH_LONG).show();
                     }
                   }
                       };
             telephonyManager.listen(callStateListener,PhoneStateListener.LISTEN_CALL_STATE);







                }




      public void unregister_ring()
                {


       Bundle savedInstanceState = null;
    super.onCreate(savedInstanceState);
      setContentView(R.layout.main);

       TelephonyManager telephonyManager = (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);     
          // register PhoneStateListener 
            PhoneStateListener callStateListener = new PhoneStateListener() {


           public void onCallStateChanged(int state, String incomingNumber) 
               {



                   }
                       };
             telephonyManager.listen(callStateListener,PhoneStateListener.LISTEN_NONE);







                }





        /** Called when the activity is first created.
         * Keep this here all the application will stop working */
        @Override
        public void onCreate(Bundle savedInstanceState) {
            ring();
            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);

            initializeUIElements();

            initializeMediaPlayer();

            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);

            buttonPlay = (Button) findViewById(R.id.buttonPlay);
            buttonStopPlay = (Button) findViewById(R.id.buttonStopPlay);

            buttonPlay.setOnClickListener(this);
            buttonStopPlay.setOnClickListener(this);


        }





    private ProgressBar playSeekBar;





    private MediaPlayer player;

    private InputStream recordingStream;

    private RecorderThread recorderThread;

    private boolean isRecording = false;







    private void initializeUIElements() {

        playSeekBar = (ProgressBar) findViewById(R.id.progressBar1);
        playSeekBar.setMax(100);
        playSeekBar.setVisibility(View.INVISIBLE);

        buttonPlay = (Button) findViewById(R.id.buttonPlay);
        buttonPlay.setOnClickListener(this);

        buttonStopPlay = (Button) findViewById(R.id.buttonStopPlay);
        buttonStopPlay.setEnabled(false);
        buttonStopPlay.setOnClickListener(this);


    }




    public void startPlaying() {
        buttonStopPlay.setEnabled(true);
        buttonPlay.setEnabled(false);

        playSeekBar.setVisibility(View.VISIBLE);

        player.prepareAsync();

        player.setOnPreparedListener(new OnPreparedListener() {

            public void onPrepared(MediaPlayer mp) {
                player.start();



            }
        });

    }







    private void onBufferingUpdate(MediaPlayer mp, int percent) {

         playSeekBar.setSecondaryProgress(percent);
        Toast.makeText(this, "Buffering ", percent).show();


          Log.i("Buffering", "" + percent);
    }











    public void onClick(View v) {
        if (v == buttonPlay) {

         startPlaying();









  player.setLooping(false); // Set looping










        } else if (v == buttonStopPlay) {

            Log.d(TAG, "onClick: stopping srvice");
            stopPlaying();
            unregister_ring();
            Toast.makeText(getApplicationContext(),"Stopped!", Toast.LENGTH_LONG).show();


        }
    }








    private void stopPlaying() {

            player.pause();
            player.release();
            initializeMediaPlayer();


        buttonPlay.setEnabled(true);
        buttonStopPlay.setEnabled(false);
        playSeekBar.setVisibility(View.INVISIBLE);

        stopRecording();
    }

    private void initializeMediaPlayer() {
        player = new MediaPlayer();
        try {
            player.setDataSource(RADIO_STATION_URL);
        } catch (IllegalArgumentException e) {
            e.printStackTrace();
        } catch (IllegalStateException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }

    }


    private void startRecording() {

        BufferedOutputStream writer = null;
        try {
            URL url = new URL(RADIO_STATION_URL);
            URLConnection connection = url.openConnection();
            final String FOLDER_PATH = Environment.getExternalStorageDirectory().getAbsolutePath()
                    + File.separator + "Songs";

            File folder = new File(FOLDER_PATH);
            if (!folder.exists()) {
                folder.mkdir();
            }

            writer = new BufferedOutputStream(new FileOutputStream(new File(FOLDER_PATH
                    + File.separator + "sample.mp3")));
            recordingStream = connection.getInputStream();

            final int BUFFER_SIZE = 100;

            byte[] buffer = new byte[BUFFER_SIZE];

            while (recordingStream.read(buffer, 0, BUFFER_SIZE) != -1 && isRecording) {
                writer.write(buffer, 0, BUFFER_SIZE);
                writer.flush();
            }

        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                recordingStream.close();
                writer.flush();
                writer.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

    private void stopRecording() {

        try {
            isRecording = false;
            if (recordingStream != null) {
                recordingStream.close();
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    private class RecorderThread extends Thread {
        @Override
        public void run() {
            isRecording = true;
            startRecording();
        }

    };
}

谢谢

最佳答案

要停止使用TelephonyManager,可以“注销”监听器:

telephonyManager.listen(callStateListener, PhoneStateListener.LISTEN_NONE);

这样就无需杀死应用程序。

参见documentation of TelephonyManager。另外,www.developer.android.com是学习更多信息和查看文档的好地方。

关于android - 阻止应用程序在后台运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21984261/

相关文章:

android - 如何防止收到 OneSignal 通知的警报?

php - 无法从 JSON 接收数据 - PHPMyAdmin

java - 如何在android中复制drawable?

java - 保留对 assetmanager 的全局引用

滚动时出现 CSS/Chrome 白色 block

iphone - iPhone:应用程序新版本未出现在“AppStore更新”列表中!

ios - 触发显着位置变化更新所需的行程距离和给定位置的准确性

ios - 有没有办法知道用户在使用我的应用程序时是否正在通话?

in-app-purchase - 为B2B目的,在IAP旁边提供其他订阅机制

ios - iOS App 的私有(private)用户集