Как обрабатывать телефонные звонки во время потокового аудио в Android

1

Я делаю аудио-потоковое воспроизведение в прямом эфире, которое отлично воспроизводится как в эмуляторе, так и в устройстве. Но проблема заключается в том, когда я звоню на устройство одновременно с потоковой передачей. Мне нужно сделать паузу и воспроизвести аудио обратно во время вызова. Можете ли вы помочь справиться с этим трансляцией.

    public class BhajanStream extends Activity {
protected static final String TAG = null;
/** Called when the activity is first created. */

final String rs_bhajan_uri = "Media URL";
MediaPlayer mediaPlayer;
AudioManager audioManager;
Button bhajan_play;
Button bhajan_stop;
ImageView loadanim, effectbhajan;
AnimationDrawable loadanimation, effectanimation;
ProgressDialog dialog;
MusicServicePhoneStateListener mPhoneListener;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.bhajan);
    bhajan_play = (Button) findViewById(R.id.btn_play);
    bhajan_stop = (Button) findViewById(R.id.btn_stop);
    bhajan_stop.setVisibility(View.GONE);

    loadanim = (ImageView) findViewById(R.id.loadeffectview);
    effectbhajan = (ImageView) findViewById(R.id.bhajan_effect);

    /*if (mediaPlayer != null) {
           mediaPlayer.stop();
           mediaPlayer= null;    
          }*/


    mediaPlayer = new MediaPlayer();
    mediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
    // mediaPlayer.reset();

    bhajan_play.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            ConnectivityManager conMan = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
            NetworkInfo Info = conMan.getActiveNetworkInfo();
            if (Info == null) {
                Toast.makeText(BhajanStream.this, "POOR SIGNALS ",
                        Toast.LENGTH_LONG).show();
                // startActivity(new Intent(Settings.ACTION_WIFI_SETTINGS));
            }



                loadanim.setBackgroundResource(R.drawable.loader_1);
                loadanim.setBackgroundResource(R.anim.loadanim);
                loadanimation = (AnimationDrawable) loadanim
                        .getBackground();
                loadanimation.isVisible();
                effectbhajan.setBackgroundResource(R.drawable.effect_bhajan1);
                effectbhajan.setBackgroundResource(R.anim.bhajaneffect);
                effectanimation = (AnimationDrawable) effectbhajan
                        .getBackground();

                     bhajan_play.setBackgroundResource(R.drawable.bhajan_start);
                bhajan_play.setVisibility(View.GONE);
                bhajan_stop.setVisibility(View.VISIBLE);
                loadanim.setVisibility(View.VISIBLE);
                effectbhajan.setVisibility(View.VISIBLE);


            try {
                mediaPlayer.reset();
                mediaPlayer.setDataSource(rs_bhajan_uri);

            } catch (IllegalArgumentException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            } catch (IllegalStateException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }

            try {
                 mediaPlayer.prepareAsync();

            } catch (IllegalStateException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }

            mediaPlayer.setOnPreparedListener(new OnPreparedListener() {
                @Override
                public void onPrepared(MediaPlayer mp) {
                    mediaPlayer.start();

                }
            });
        }

    });

    bhajan_stop.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            if (mediaPlayer.isPlaying()) {
                if (mediaPlayer != null) {
            bhajan_stop.setVisibility(View.GONE);
            bhajan_play.setVisibility(View.VISIBLE);

            mediaPlayer.stop();
            loadanimation.stop();
            effectanimation.stop();
            loadanim.setVisibility(View.GONE);
            effectbhajan.setVisibility(View.GONE);
                }}

        }
    });

}

protected void onPreExecute() {
    // UI work allowed here

    loadanimation.start();


}

@Override
public void onBackPressed() {
    // do something
    if (mediaPlayer.isPlaying()) {
        if (mediaPlayer != null) {

            mediaPlayer.stop();
            loadanimation.stop();
            effectanimation.stop();
            bhajan_stop.setVisibility(View.GONE);
            bhajan_play.setVisibility(View.VISIBLE);
            loadanim.setVisibility(View.GONE);
            effectbhajan.setVisibility(View.GONE);
        }
    } else{
        startActivity(new Intent(BhajanStream.this, SaiStreams.class));
        finish();
    }
    }

private class MusicServicePhoneStateListener extends PhoneStateListener {
    private boolean mResumeAfterCall = false;

    @Override
    public void onCallStateChanged(int state, String incoming_number) {
        switch (state) {
        case TelephonyManager.CALL_STATE_OFFHOOK:
        case TelephonyManager.CALL_STATE_RINGING:
            Log.i(TAG, "phone active, suspending music service");
            mResumeAfterCall = mediaPlayer.isPlaying();
            mediaPlayer.pause();
            break;
        case TelephonyManager.CALL_STATE_IDLE:
            Log.i(TAG, "phone inactive, resuming music service");
            if (mResumeAfterCall) {
               mediaPlayer.start();
            }
            break;
        default:
            break;
        }
    }
}
public void onCreate(){
    mPhoneListener = new MusicServicePhoneStateListener();
    ((TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE)).listen(mPhoneListener, PhoneStateListener.LISTEN_CALL_STATE);
}
public void onDestroy(){
    mPhoneListener = new MusicServicePhoneStateListener();
    ((TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE)).listen(mPhoneListener, 0);
}

}

  • 0
    Огромное спасибо!! для исправления вашего вопроса. Я просто хочу добавить для пользователей, которые будут читать ваш код: не забудьте добавить в свой манифест следующее разрешение: android.permission.READ_PHONE_STATE, поэтому вам нужно добавить эту строку: <использование-разрешения android: name = "android. разрешение.READ_PHONE_STATE "/>
Теги:
handler
broadcastreceiver
http-live-streaming

1 ответ

1
Лучший ответ

В своей деятельности вы можете зарегистрировать прослушиватель состояния телефона, вызвав public void listen (PhoneStateListener listener, int events) в классе TelephonyManager. См. Здесь. Кроме того, вы можете вызвать Context.getSystemService(Context.TELEPHONY_SERVICE) чтобы получить экземпляр объекта TelephonyManager.

  • 0
    @ Хуан, ты можешь показать мне пример использования этого в моем коде?
  • 0
    @ user1051599 У меня нет под рукой затмения. Хорошо, я могу показать вам фрагменты кода, чтобы вы поняли, как его использовать, но я не могу проверить это. На самом деле, чтение документа в SDK - хорошая привычка.
Показать ещё 5 комментариев

Ещё вопросы

Сообщество Overcoder
Наверх
Меню