Android电话拦截及拦截后的提示音

1. 电话拦截

这个功能大家可能都知道了,就是利用反射原理调用ITelephony的隐藏方法来实现。这个就不说了,在附件的代码里有。

2.拦截后提示忙音/空号/已关机/已停机

这个功能其实是要用到MMI指令,具体如何设置呼叫转移的指定可以参考这里 http://baike.baidu.com/view/206402.html?fromTaglist 。

在 本文中我们会用到“遇忙转移”转移的功能。中国移动的设置方式是 **67#电话号码#,取消方式为 ##67#。这两个指令可以直接在手机的拨号界面输入测试。ITelephony的endcall方法挂断电话后,会提示电话忙。如果事前设置好了忙时转 移到一个空号/已关机/已停机的电话号码,就会提示您拨的电话号码是空号/已关机/已停机。

其实大家可以下载 xxx卫士看下,它设置来电拒接模式后,都是会启动设置MMI指令的界面。然后再去“设置》通话设置》来电转接”,看看 “占线时转接” 设置好的电话号码,就可以知道空号/已关机/已停机对应的电话号码是什么了。

附件是演示工程文件,有几点要说明下:

1. 修改一下BLOCKED_NUMBER这个变量值,把它设置为你要测试拦截的电话号码。

2. 全部功能是在一个Activity里实现的,所以大家要先运行这个Activity,然后点击“设置呼叫转移”,设置好呼叫转移后,不要关闭这个Activity,关了就拦截不了电话了。有心的朋友可以自己去写一个Service在后台运行拦截功能。

代码如下:

package net.toeach.android.callforwarding;

import java.lang.reflect.Method;

import android.app.Activity;

import android.content.BroadcastReceiver;

import android.content.Context;

import android.content.Intent;

import android.content.IntentFilter;

import android.media.AudioManager;

import android.net.Uri;

import android.os.Bundle;

import android.os.Handler;

import android.os.Message;

import android.os.RemoteException;

import android.telephony.TelephonyManager;

import android.util.Log;

import android.view.View;

import android.view.View.OnClickListener;

import com.android.internal.telephony.ITelephony;

/**

* 演示如何设置呼叫转移,拦截电话(拦截后提示为空号)的例子

* @author Tony from ToEach.

* @email wan1976@21cn.com

*/

public class MainActivity extends Activity {

private static final String TAG = MainActivity.class.getSimpleName();

private final static int OP_REGISTER = 100;

private final static int OP_CANCEL = 200;

private final static String BLOCKED_NUMBER = "1892501xxxx";//要拦截的号码

//占线时转移,这里13800000000是空号,所以会提示所拨的号码为空号

private final String ENABLE_SERVICE = "tel:**67*13800000000%23";

//占线时转移

private final String DISABLE_SERVICE = "tel:%23%2367%23";

private IncomingCallReceiver mReceiver;

private ITelephony iTelephony;

private AudioManager mAudioManager;

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

findViewById(R.id.btnEnable).setOnClickListener(new OnClickListener(){

public void onClick(View v) {

//设置呼叫转移

Message message = mHandler.obtainMessage();

message.what = OP_REGISTER;

mHandler.dispatchMessage(message);

}

});

findViewById(R.id.btnDisable).setOnClickListener(new OnClickListener(){

public void onClick(View v) {

//取消呼叫转移

Message message = mHandler.obtainMessage();

message.what = OP_CANCEL;

mHandler.dispatchMessage(message);

}

});

mReceiver = new IncomingCallReceiver();

IntentFilter filter = new IntentFilter("android.intent.action.PHONE_STATE");

registerReceiver(mReceiver, filter);// 注册BroadcastReceiver

mAudioManager = (AudioManager) getSystemService(Context.AUDIO_SERVICE);

//利用反射获取隐藏的endcall方法

TelephonyManager telephonyMgr = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE);

try {

Method getITelephonyMethod = TelephonyManager.class.getDeclaredMethod("getITelephony", (Class[]) null);

getITelephonyMethod.setAccessible(true);

iTelephony = (ITelephony) getITelephonyMethod.invoke(telephonyMgr, (Object[]) null);

} catch (Exception e) {

e.printStackTrace();

}

}

private Handler mHandler = new Handler() {

public void handleMessage(Message response) {

int what = response.what;

switch(what) {

case OP_REGISTER:{

Intent i = new Intent(Intent.ACTION_CALL);

i.setData(Uri.parse(ENABLE_SERVICE));

startActivity(i);

break;

}

case OP_CANCEL:{

Intent i = new Intent(Intent.ACTION_CALL);

i.setData(Uri.parse(DISABLE_SERVICE));

startActivity(i);

break;

}

}

}

};

private class IncomingCallReceiver extends BroadcastReceiver{

@Override

public void onReceive(Context context, Intent intent) {

String state = intent.getStringExtra(TelephonyManager.EXTRA_STATE);

Log.i(TAG, "State: "+ state);

String number = intent.getStringExtra(TelephonyManager.EXTRA_INCOMING_NUMBER);

Log.d(TAG, "Incomng Number: " + number);

if(state.equalsIgnoreCase(TelephonyManager.EXTRA_STATE_RINGING)){//电话正在响铃

if(number.equals(BLOCKED_NUMBER)){//拦截指定的电话号码

//先静音处理

mAudioManager.setRingerMode(AudioManager.RINGER_MODE_SILENT);

Log.d(TAG, "Turn ringtone silent");

try {

//挂断电话

iTelephony.endCall();

} catch (RemoteException e) {

e.printStackTrace();

}

//再恢复正常铃声

mAudioManager.setRingerMode(AudioManager.RINGER_MODE_NORMAL);

}

}

}

}

}

AndroidManifest.xml如下:

package="net.toeach.android.callforwarding"

android:versionCode="1"

android:versionName="1.0">

android:label="@string/app_name">

由www.J2meGame.com 精心收集。

Android屏蔽呼出电话提示音,Android来电拦截及拦截后的提示音相关推荐

  1. android 拨打电话、 监听来电、监听呼出电话的功能实现

    demo1(通用): 权限 <!-- 监听呼出电话 --> <uses-permission android:name="android.permission.PROCES ...

  2. android+获取未接电话,如何统计Android中未接电话的数量

    我知道如何获得未接电话通知,但我不知道我有多少个未接电话.那么我怎样才能算出这个未接电话的数量呢?如何统计Android中未接电话的数量 我使用oncreate此代码: TelephonyManage ...

  3. 苹果备忘录分享不了微信提示无法连接服务器,关于微信分享后,提示“未验证应用”的解决办法(iOS)...

    目录 关于微信分享后,提示"未验证应用"的解决办法 1.Universal Link : 1.1 通用链接是iOS9推出的一项新功能,如果你的应用(app)支持通用链接(Unive ...

  4. Android呼出电话流程(原)

    一.应用层的流程 1.1.拨号盘初步处理 [java] view plaincopy @DialpadFragment.java public void dialButtonPressed() { / ...

  5. 在android中监听呼出电话(电话拦截、修改呼出电话)

    2019独角兽企业重金招聘Python工程师标准>>> 在android中向外拨打电话时系统会发出一个有序广播,虽然该广播最终会被拔号器里的广播接收者所接收并实现电话拔打,但我们可以 ...

  6. android 修改呼出号码,在android中监听呼出电话(电话拦截、修改呼出电话)

    在android中向外拨打电话时系统会发出一个有序广播,虽然该广播最终会被拔号器里的广播接收者所接收并实现电话拔打,但我们可以在广播传递给拔号广播接收者之前先得到该广播,然后清除传递给拔号广播接收者的 ...

  7. android自动弹出浏览器打开文件,android使用主流浏览器打开网页,无需弹出选择。...

    首先说一下开发需求,需要使用主流的浏览器打开网页,比如QQ浏览器,UC浏览器,opera浏览器,如果此手机里面有安装上述浏览器,则使用上述的浏览器打开网页,无需弹出浏览器选择项,如果这几种都有安装则按 ...

  8. linux下ant编译android,linux(以ubuntu為例)下Android利用ant自動編譯、修改配置文件、批量多渠道,打包生成apk文件...

    原創,轉載請注明:http://www.cnblogs.com/ycxyyzw/p/4555328.html 安裝前所需要准備的軟件: 1. JDK(jdk-7-linux-i586.tar.gz) ...

  9. 如何配置3CX SIP中继线路的呼出显示号码

    文章来源:https://3x.58voip.com/how-to-configure-3cx-outbound-caller-id/ 背景: 我们在使用3CX SIP中继线路时,有些特别的需求,假设 ...

最新文章

  1. eclipse代码模版里设置模版快捷键
  2. 设计模式复习-模板方法模式
  3. 【自动驾驶】28.【右手坐标系】与【右手法则】分析、【右手法则的正方向】 与 【逆时针为正方向】 的分析
  4. 使用Talend Open Studio将数据分步从oracle导入到hive中
  5. 百度商业大规模微服务分布式监控系统-凤睛
  6. C语言malloc,free的用法
  7. eolinker使用初体验(一)
  8. bat文件运行java的jar包不弹出dos窗口,开机自启jar包
  9. LeetCode 75. Sort Colors
  10. JavaScript(一)—— 初识JavaScript/注释/输入输出语句/变量/数据类型
  11. Python开发【第五篇】迭代器、生成器、递归函数、二分法
  12. 老年代的更新机制_如何理解Java GC机制
  13. iOS最安全?细数iOS曝过的安全漏洞|苹果|iOS|漏洞
  14. LincSNP:lncRNA相关SNP位点数据库
  15. 一线城市中小公司的月薪10k前端工程师应该会什么?
  16. 数据分析——DAU下降问题(转)
  17. SNIPER—— SNIP的实战版本 (目标检测)(two-stage)(深度学习)(Arvix 2018)
  18. FPGA经验谈系列文章——FPGA资源评估
  19. 计算机中的速率、带宽、时延、利用率解读
  20. 出行者信息服务器,出行者信息服务系统解析.ppt

热门文章

  1. [官方Flink入门笔记 ] 三、开发环境搭建和应用的配置、部署及运行
  2. 绿厂Oppo年终刚刚开奖!只有去年的3-5折,员工心态炸了!
  3. python:机器学习(sklearn)(一)
  4. 第三天,【1124】接口,注册,登录
  5. Linux内存管理(二十六):slub 分配器初始化
  6. 笔记:文澜:桥接视觉和语言的大规模多模态预训练 WenLan: Bridging Vision and Language by Large-Scale Multi-Modal Pre-Training
  7. RedHat 6.4配置本地镜像源(适用于已停止更新的Linux系统)
  8. linux哪个版本支持tipc,Linux TIPC 2.0 Programmerapos;s Guide文档.doc
  9. 浏览器创建render 树_如何为浏览器创建出色的游戏
  10. linux——dmidecode