Блокировка входящего вызова при открытом приложении

Я успешно внедрил код для блокировки вызова, но он блокирует все вызовы, даже если я закрыл приложение. Мне нужно заблокировать вызов, когда открывается определенное действие (если это невозможно, вызов блокировки, когда приложение открыто, также в порядке). Я прилагаю свой код ниже. Пожалуйста, пройдите через это. За любой положительный ответ заранее спасибо.

BlockCallReceiver.java

import java.lang.reflect.Method;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.telephony.TelephonyManager;

public class BlockCallReceiver extends BroadcastReceiver{
    Context context;
    @Override
    public void onReceive(Context context, Intent intent) {
        // TODO Auto-generated method stub
        Bundle myBundle = intent.getExtras();
        if (myBundle != null)
        {
            System.out.println("--------Not null-----");
            try
            {
                if (intent.getAction().equals("android.intent.action.PHONE_STATE"))
                {
                    String state = intent.getStringExtra(TelephonyManager.EXTRA_STATE);
                    System.out.println("--------in state-----");
                    if (state.equals(TelephonyManager.EXTRA_STATE_RINGING))
                    {
                        // Incoming call
                        String incomingNumber =intent.getStringExtra(TelephonyManager.EXTRA_INCOMING_NUMBER);
                        System.out.println("--------------my number---------"+incomingNumber);

// this is main section of the code,. could also be use for particular number.
                        // Get the boring old TelephonyManager.
                        TelephonyManager telephonyManager =(TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE);

                        // Get the getITelephony() method
                        Class<?> classTelephony = Class.forName(telephonyManager.getClass().getName());
                        Method methodGetITelephony = classTelephony.getDeclaredMethod("getITelephony");

                        // Ignore that the method is supposed to be private
                        methodGetITelephony.setAccessible(true);

                        // Invoke getITelephony() to get the ITelephony interface
                        Object telephonyInterface = methodGetITelephony.invoke(telephonyManager);

                        // Get the endCall method from ITelephony
                        Class<?> telephonyInterfaceClass = Class.forName(telephonyInterface.getClass().getName());
                        Method methodEndCall = telephonyInterfaceClass.getDeclaredMethod("endCall");

                        // Invoke endCall()
                        methodEndCall.invoke(telephonyInterface);

                    }

                }
            }
            catch (Exception ex)
            { // Many things can go wrong with reflection calls
                ex.printStackTrace();
            }
        }
    }
}

MainActivity.java

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

import com.karan.churi.PermissionManager.PermissionManager;

import java.lang.reflect.Method;

public class MainActivity extends AppCompatActivity {
    PermissionManager permission;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        permission=new PermissionManager() {};
        permission.checkAndRequestPermissions(this);
    }
}

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.arjun.myapplication">
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.MODIFY_PHONE_STATE" />
    <uses-permission android:name="android.permission.CALL_PHONE" />
    <uses-feature
        android:name="android.hardware.telephony"
        android:required="false" />
    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <receiver android:name=".BlockCallReceiver" >
            <intent-filter android:priority="100" >
                <action android:name="android.intent.action.PHONE_STATE" >
                </action>
            </intent-filter>
        </receiver>
    </application>

</manifest>

person arjun babu    schedule 24.08.2017    source источник


Ответы (2)


Вам нужно инициализировать BroadcastReceiver в вашем MainActivity следующим образом.

private final BroadcastReceiver mBloackCallReceiver = new BlockCallReceiver();

Затем зарегистрируйте BroadcastReceiver, используя приведенный ниже код, в функции onCreate вашей активности.

registerReceiver(mBloackCallReceiver , new IntentFilter(TelephonyManager.ACTION_PHONE_STATE_CHANGED));

Не забудьте отменить регистрацию BroadcastReceiver, используя приведенный ниже код в функции onDestroy вашей активности.

unregisterReceiver(mybroadcast);

Удалите тег receiver из AndroidManifest.xml.

person karthik    schedule 24.08.2017
comment
удаленный тег получателя из манифеста работает отлично. Спасибо друг - person arjun babu; 24.08.2017
comment
просто хедз-ап, onDestroy не гарантируется при выходе из активности, вы должны поместить свой registerReceiver в onResume, а unregisterReceiver в onPause, чтобы убедиться, что вы всегда очищаете после себя - person marmor; 25.08.2017

Я добавил этот код в свой класс приложения и вызываю этот метод каждые 10 секунд с помощью таймера. Надеюсь, это вам поможет. Попробуйте этот код:

    public  boolean isAppIsInBackground(Context context) {
    boolean isInBackground = true;
    ActivityManager am = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);
    if (Build.VERSION.SDK_INT > Build.VERSION_CODES.KITKAT_WATCH) {
        List<ActivityManager.RunningAppProcessInfo> runningProcesses = am.getRunningAppProcesses();
        for (ActivityManager.RunningAppProcessInfo processInfo : runningProcesses) {
            if (processInfo.importance == ActivityManager.RunningAppProcessInfo.IMPORTANCE_FOREGROUND) {
                for (String activeProcess : processInfo.pkgList) {
                    if (activeProcess.equals(context.getPackageName())) {
                        isInBackground = false;
                    }
                }
            }
        }
    } else {
        List<ActivityManager.RunningTaskInfo> taskInfo = am.getRunningTasks(1);
        ComponentName componentInfo = taskInfo.get(0).topActivity;
        if (componentInfo.getPackageName().equals(context.getPackageName())) {
            isInBackground = false;
        }
    }

    Log.i(TAG, "isAppIsInBackground: "+isInBackground);
    return isInBackground;
}
person Payal    schedule 24.08.2017
comment
Я знаю решение, если я зарегистрирую и отменю регистрацию этого широковещательного приемника из активности вместо манифеста, проблема будет решена, но я не знаю, как это делается в этом случае. - person arjun babu; 24.08.2017
comment
На самом деле я реализую этот код, чтобы проверить, находится ли приложение на переднем плане или в фоновом режиме, и в соответствии с этим я отправляю свои данные на сервер. Я думаю, что у вас тоже есть такая же проблема, поэтому я делюсь с вами своим кодом. - person Payal; 24.08.2017
comment
Да, мое приложение не перейдет в фоновый режим, поэтому фоновое состояние приложения невозможно. Я выбираю эту блокировку вызова, потому что в некоторых телефонах вызов появляется сверху, как всплывающее окно. Это будет держать приложение в состоянии переднего плана, но пользователь может посещать вызов через это всплывающее окно. - person arjun babu; 24.08.2017