Прослушайте входящие звонки через BroadCastreceiver, без PhonestateIntentReceiver или PhonestateListener
-
14-11-2019 - |
Вопрос
Есть ли способ прослушивать входящие вызовы, протягивая широковещатель для прослушивания трансляции ОС без использования PhonestateIntentReceiver или PhonestateListener. Также, пожалуйста, скажите мне, что будет действием и разрешений в манифесте.
Я пробовал следующим образом, но он не работает для входящих звонков, но работает для исходящих
единственный файл приложения .java следующим образом (приложение только один файл .java и один файл манифеста)
package com.crsardar.media.audio;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.util.Log;
public class IncommingCallReceiverCRS extends BroadcastReceiver{
@Override
public void onReceive(Context context, Intent intent) {
Log.e("Chitta : ", "Its working");
}
}
.
Манифест
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.crsardar.media.audio"
android:versionCode="1"
android:versionName="1.0">
<application android:icon="@drawable/icon" android:label="@string/app_name">
<receiver android:name="IncommingCallReceiverCRS" android:enabled="true">
<intent-filter>
<!--action android:name="android.intent.action.NEW_OUTGOING_CALL"/-->
<action android:name="android.intent.action.ANSWER" >
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</receiver>
</application>
<uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS"/>
<uses-permission android:name="android.permission.READ_PHONE_STATE"/>
<uses-permission android:name="android.permission.RECORD_AUDIO"/>
</manifest>
. Решение
Действие, которое вы определили в вашем манифесте, неверно.Это намерение действий, которое можно использовать для ответа на вызов и не мониторируйте входящие вызовы.
Вы можете использовать два широковещательных приемника, которые слушают action_phone_state_changed и new_Outgoing_call
Action_phone_state_Changed будет получен, когда появится новый входящий вызов, позвоните, ответили или зависают (см. Документацию для получения дополнений, полученных с этим намерением).
new_outgoing_call будет получен, когда на вашем устройстве установлен новый исходящий вызов.
Что касается разрешений, я думаю, что вы получили его в своем манифесте (я предполагаю, что разрешение RECORE_AUDIO используется для чего-то другого в вашем приложении)
Другие советы
Вот мой демо-демонстрационный тест на андроид.Вы можете обратиться к этому.
public interface ICallVerify {
void onOutgoing(Context context, Intent intent);
void onCallStateChange(Context context, Intent intent);
}
protected void setUpCallVerify(final ICallVerify callVerify) { //listen ingoing and outgoing
final CountDownLatch latch = new CountDownLatch(1);
BroadcastReceiver receiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
if (intent.getAction().equals(Intent.ACTION_NEW_OUTGOING_CALL)) { //state change
Log.i(TAG, "outgoing call...");
callVerify.onOutgoing(context, intent);
} else if (intent.getAction().equals(TelephonyManager.ACTION_PHONE_STATE_CHANGED)){ // state changed
String state = intent.getStringExtra(TelephonyManager.EXTRA_STATE);
if (state.equals("RINGING")) {
state += " number:" + intent.getStringExtra(TelephonyManager.EXTRA_INCOMING_NUMBER);
}
Log.i(TAG, "call state changed.... " + state);
callVerify.onCallStateChange(context, intent);
}
}
};
IntentFilter filter = new IntentFilter(TelephonyManager.ACTION_PHONE_STATE_CHANGED);
filter.addAction(Intent.ACTION_NEW_OUTGOING_CALL);
ContextUtils.getTargetContext().registerReceiver(receiver, filter);
try {
latch.await(5, TimeUnit.MINUTES);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
.
Не забудьте добавить разрешения
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
<uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS"></uses-permission>
.