Android来电拦截的实现方法

本文实例为大家分享了Android来电拦截的方法,供大家参考,具体内容如下

权限

  <uses-permission android:name="android.permission.READ_PHONE_STATE" />
  <uses-permission android:name="android.permission.CALL_PHONE" />
  <uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS" />

 <!-- 注册广播 监听拨出电话 -->
 <receiver android:name="com.example.administrator.endcall.PhoneStateReceiver">
      <intent-filter>
        <action android:name="android.intent.action.PHONE_STATE" />
        <action android:name="android.intent.action.NEW_OUTGOING_CALL" />
      </intent-filter>
 </receiver>

拨号广播—PhoneStateReceiver

package com.example.administrator.endcall;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.telephony.PhoneStateListener;
import android.telephony.TelephonyManager;
import android.util.Log;

public class PhoneStateReceiver extends BroadcastReceiver {
  @Override
  public void onReceive(Context context, Intent intent) {
    if (intent.getAction().equals(Intent.ACTION_NEW_OUTGOING_CALL)) {
      String phoneNumber = intent.getStringExtra(Intent.EXTRA_PHONE_NUMBER);
      Log.i("BlockCallHelper", "BlockCallHelper------->>>>" + phoneNumber);
    }
  }
}

来电挂断
BlockCallHelper

package com.example.administrator.endcall;

import android.content.Context;
import android.content.SharedPreferences;
import android.database.Cursor;
import android.net.Uri;
import android.os.RemoteException;
import android.telephony.PhoneStateListener;
import android.telephony.TelephonyManager;
import android.util.Log;

import com.android.internal.telephony.ITelephony;

import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;

public final class BlockCallHelper {
  private static final String TAG = "BlockCallHelper";

  private Context mContext;

  private TelephonyManager tManger;

  private List<String> phones;

  private BlockCallBack bcb;

  //////////////////////////////////////////
  private static final class Factory {
    private static final BlockCallHelper instance = new BlockCallHelper();
  }

  public static BlockCallHelper getInstance() {
    return Factory.instance;
  }

  /**
   * 初始化上下文以及数据
   * @param context
   */
  public BlockCallHelper init(Context context) {
    if (context == null) {
      throw new NullPointerException("context == null!");
    }

    this.mContext = context;
    this.tManger = (TelephonyManager) mContext.getSystemService(Context.TELEPHONY_SERVICE);
    tManger.listen(new PhoneCallListener(), PhoneCallListener.LISTEN_CALL_STATE);
    return this;
  }

  /**
   * 注入需要拦截的手机号
   * @param phoneL
   */
  public BlockCallHelper injectBlockPhoneNum(ArrayList<String> blockCalls) {
    this.phones = blockCalls;
    return this;
  }
  /**
   * 结束通话
   */
  private void endCall() {
    Class<TelephonyManager> tmc = TelephonyManager.class;
    Method getITelephonyMethod;
    try {
      getITelephonyMethod = tmc.getDeclaredMethod("getITelephony", (Class[]) null);
      getITelephonyMethod.setAccessible(true);
      ITelephony iTelephony = (ITelephony) getITelephonyMethod.invoke(tManger, (Object[]) null);
      iTelephony.endCall();
    } catch (NoSuchMethodException e1) {
      e1.printStackTrace();
    } catch (InvocationTargetException e2) {
      e2.printStackTrace();
    } catch (IllegalAccessException e3) {
      e3.printStackTrace();
    } catch (RemoteException e4) {
      e4.printStackTrace();
    }
  }

  private final class PhoneCallListener extends PhoneStateListener {
    @Override
    public void onCallStateChanged(int state, String incomingNumber) {
      if (state == TelephonyManager.CALL_STATE_RINGING) {
        if (phones.contains(incomingNumber)) {
          Log.i("BlockCallHelper", "contains contains contains");
          endCall();
          if (bcb != null) {
            bcb.callBack(incomingNumber);
          }
        } else {
          Log.i("BlockCallHelper", "contains not-------");
        }
      }
    }
  }

  public BlockCallHelper setBlockCallBack(BlockCallBack back) {
    this.bcb = back;
    return this;
  }

  public interface BlockCallBack {
    void callBack(String incomingNum);
  }
}

看主界面MainActivity

package com.example.administrator.endcall;

import android.app.Activity;
import android.app.NotificationManager;
import android.os.Bundle;
import android.util.Log;
import android.widget.Toast;

import java.util.ArrayList;

public class MainActivity extends Activity {

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    ArrayList<String> blockCalls = new ArrayList();
    blockCalls.add("13581922339");
    blockCalls.add("+8613581922339");
    blockCalls.add("18500813370");
    blockCalls.add("13717717622");
    blockCalls.add("+8613717717622");

    BlockCallHelper.getInstance().init(this).injectBlockPhoneNum(blockCalls).setBlockCallBack(new BlockCallHelper.BlockCallBack() {
      @Override
      public void callBack(String incomingNum) {
        Log.i("BlockCallHelper", "incomingNum-----------" + incomingNum);
      }
    });
  }
}

最后看AIdl层面
ITelephony.aidl

package com.android.internal.telephony;

interface ITelephony {
   void dial(String number);
   void call(String number);
   boolean showCallScreen();
   boolean showCallScreenWithDialpad(boolean showDialpad);
   boolean endCall();
   void answerRingingCall();
   void silenceRinger();
   boolean isOffhook();
   boolean isRinging();
   boolean isIdle();
   boolean isRadioOn();
   boolean isSimPinEnabled();
   void cancelMissedCallsNotification();
   boolean supplyPin(String pin);
   boolean handlePinMmi(String dialString);
   void toggleRadioOnOff();
   boolean setRadio(boolean turnOn);
   void updateServiceLocation();
   void enableLocationUpdates();
   void disableLocationUpdates();
   int enableApnType(String type);
   int disableApnType(String type);
   boolean enableDataConnectivity();
   boolean disableDataConnectivity();
   boolean isDataConnectivityPossible();

   Bundle getCellLocation();
   List<NeighboringCellInfo> getNeighboringCellInfo();

    int getCallState();
    int getDataActivity();
    int getDataState();
}

NeighboringCellInfo.aidl

// NeighboringCellInfo.aidl
package android.telephony;
parcelable NeighboringCellInfo;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android指纹解锁方法解析

    我先说说这两种的方式的不同之处吧 第一种: 在调动成功之后 不会让你指纹解锁 而是调转到当初你设置指纹解锁时的 手势解锁页面 第二种: 在调动成功之后,是进行指纹解锁 不调转 你直接把手指放到金属感应环 上面进行指纹验证 大家可以根据需求 自行选择 ok 那就亮代码了 第一种: xml 布局: 一个 文本显示 一个按钮(不解释) MainActivity.java源码 public class MainActivity extends FragmentActivity { Fingerprint

  • Android编程实现TCP、UDP客户端通信功能示例

    本文实例讲述了Android编程实现TCP.UDP客户端通信功能.分享给大家供大家参考,具体如下: 在进行Android开发的过程中,免不了,要开发TCP/UDP通讯的程序,下面这两段代码,分别介绍了TCP/UCP通过的一个实例: 代码一 TCP通讯: private void tcpdata() { try { Socket s = new Socket("192.168.0.25", 65500); // outgoing stream redirect to socket Out

  • android-wheel控件实现三级联动效果

    本文实例为大家分享了android wheel省市县三级联动效果,供大家参考,具体内容如下 在github上面有一个叫做 Android-wheel 的开源控件, 代码地址:https://github.com/maarek/android-wheel 源码下载地址:http://xiazai.jb51.net/201610/yuanma/AndroidCascadeMaster(jb51.net).rar 主界面布局 activity_main.xml <LinearLayout xmlns:

  • Android自定义UI手势密码改进版源码下载

    在之前文章的铺垫下,再为大家分享一篇:Android手势密码,附源码下载,不要错过. 源码下载:http://xiazai.jb51.net/201610/yuanma/androidLock(jb51.net).rar 先看第一张图片的布局文件 activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://sc

  • Android中button点击后字体的变色效果

    button的点击效果无疑是非常简单的,以致于我懒到当UI告诉我说在点击的时候button字体的颜色也要随着背景改变的时候我毫不犹豫的告诉他让他切两个图过来,后来想想着实是不太靠谱,于是了解了一下如何添加button点击的字体颜色变化效果. 1.首先你要在你的color文件下加入几个你需要的色值,注意不同的是不是一般的color标签,而是drawable标签,就像这样: <drawable name="color_red">#fffa3d39</drawable>

  • Android加载Gif动画实现代码

    Android加载Gif动画如何实现?相信大家都很好奇,本文就为大家揭晓,内容如下 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_he

  • Android项目类似淘宝 电商 搜索功能,监听软键盘搜索事件,延迟自动搜索,以及时间排序的搜索历史记录的实现

    最近跳槽去新公司,接受的第一个任务是在 一个电商模块的搜索功能以及搜索历史记录的实现. 需求和淘宝等电商的功能大体差不多,最上面一个搜索框,下面显示搜索历史记录.在EditText里输入要搜索的关键字后,按软键盘的搜索按键/延迟xxxxms后自动搜索.然后将搜索的内容展示给用户/提示用户没有搜到相关信息. 历史记录是按时间排序的,最新的在前面,输入以前搜索过的关键字,例如牛仔裤(本来是第二条),会更新这条记录的时间,下次再看,牛仔裤的排列就在第一位了.并且有清除历史记录的功能. 整理需求,大致需

  • Android 屏幕横竖切换详解

    Android 屏幕横竖切换 Android 里面控制Activity的方向,只要在AndroidManifest.xml里面对应的Activity节点下加一句 android:screenOrientation="landscape"(landscape是横屏,portrait竖屏). 我凭这句话混了一年,基本都可以的,但是这几天我发现这招不是万能的了. 项目里面有一个横屏播放视频的PlayAcitivity,我和之前一样设置了android:screenOrientation=&q

  • Android自定义UI手势密码改进版

    接着第一个Android UI手势密码设计的基础上继续改进,效果图如下 activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layo

  • Android中使用TextView实现高仿京东淘宝各种倒计时效果

    今天给大家带来的是仅仅使用一个TextView实现一个高仿京东.淘宝.唯品会等各种电商APP的活动倒计时.最近公司一直加班也没来得及时间去整理,今天难得休息想把这个分享给大家,只求共同学习,以及自己后续的复习.为什么会想到使用一个TextView来实现呢?因为最近公司在做一些优化的工作,其中就有一个倒计时样式,原来开发的这个控件的同事使用了多个TextView拼接在一起的,实现的代码冗余比较大,故此项目经理就说:小宏这个就交给你来优化了,并且还要保证有一定的扩展性,当时就懵逼了.不知道从何处开始

随机推荐