android 自动拨打电话和挂断电话(反射和intent方式)
来源:互联网 发布:ug车削编程检查几何体 编辑:程序博客网 时间:2024/04/30 10:23
欢迎来到博主的技术分享博客
今天分享的技术主要内容是自动拨打电话和挂断电话。自动拨打电话分为两种,一种是通过反射ITelephony这个类直接调用call方法,一种是通过intent方法。而挂断电话则只有通过反射ITelephony这个类的endcall方法了。
先看看动图演示(由于csdn有大小限制,就分成2个gif图来演示):
因为我们通过反射获取ITelephony对象主要是通过TelephonyManager这个对象里面的私有getITelephony方法来获取的,现在我们就先看看getITelephony源码部分。
通过上面源码,我们确实发现了TelephonyManager源码里面有个私有getITelephony方法。反射获取ITelephony代码如下:
上述代码最后的地方会返回的Object对象其实就是ITelephony对象,只是你项目是找不到这个类的,所以不能进行强转,只能通过Object再次反射拨打电话call和挂断电话endcall方法。
看完了TelephonyManager源码,我们现在就来看看ITelephony的源码部分。
上面源码能看到call方法和endcall方法,而call方法里面会有2个参数需要传递,第一个参数是你应用的包名,而第二个参数就是你需要拨打的电话号码了。endcall方法就简单了,只需要调用就行了。
然而这里我们说的是拨打电话的两种方式,还有种方式则是intent,请看代码:
这个intent其实是网上传出最多调用拨打电话的方式了,这里不做过多解释。
上面咱们一起看了下ITelephony和TelephonyManager的源码。现在我们直接来看看完整代码:
package com.example.phonedemo;import java.lang.reflect.Method;import android.app.Activity;import android.content.Context;import android.content.Intent;import android.net.Uri;import android.os.Bundle;import android.os.Handler;import android.telephony.TelephonyManager;import android.view.View;import android.view.View.OnClickListener;import android.widget.Button;import android.widget.Toast;public class MainActivity extends Activity { Button btn_phone1; Button btn_phone2; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btn_phone1 = (Button) findViewById(R.id.btn_phone1); btn_phone2 = (Button) findViewById(R.id.btn_phone2); btn_phone1.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { try { // 首先拿到TelephonyManager TelephonyManager telMag = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE); Class<TelephonyManager> c = TelephonyManager.class; // 再去反射TelephonyManager里面的私有方法 getITelephony 得到 ITelephony对象 Method mthEndCall = c.getDeclaredMethod("getITelephony", (Class[]) null); //允许访问私有方法 mthEndCall.setAccessible(true); final Object obj = mthEndCall.invoke(telMag, (Object[]) null); // 再通过ITelephony对象去反射里面的call方法,并传入包名和需要拨打的电话号码 Method mt = obj.getClass().getMethod("call", new Class[] { String.class, String.class }); //允许访问私有方法 mt.setAccessible(true); mt.invoke(obj, new Object[] { getPackageName() + "", "10086" }); Toast.makeText(MainActivity.this, "拨打电话!", Toast.LENGTH_SHORT).show(); new Handler().postDelayed(new Runnable() { public void run() { try { // 延迟5秒后自动挂断电话 // 再通过ITelephony对象去反射里面的endCall方法,挂断电话 Method mt = obj.getClass().getMethod("endCall"); //允许访问私有方法 mt.setAccessible(true); mt.invoke(obj); Toast.makeText(MainActivity.this, "挂断电话!", Toast.LENGTH_SHORT).show(); } catch (Exception e) { e.printStackTrace(); } } }, 5 * 1000); } catch (Exception e) { e.printStackTrace(); } } }); btn_phone2.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { try { // 开始直接拨打电话 Intent intent2 = new Intent(Intent.ACTION_CALL, Uri.parse("tel:" + "10086")); intent2.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); startActivity(intent2); Toast.makeText(MainActivity.this, "拨打电话!", Toast.LENGTH_SHORT).show(); new Handler().postDelayed(new Runnable() { public void run() { try { // 延迟5秒后自动挂断电话 // 首先拿到TelephonyManager TelephonyManager telMag = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE); Class<TelephonyManager> c = TelephonyManager.class; // 再去反射TelephonyManager里面的私有方法 getITelephony 得到 ITelephony对象 Method mthEndCall = c.getDeclaredMethod("getITelephony", (Class[]) null); //允许访问私有方法 mthEndCall.setAccessible(true); final Object obj = mthEndCall.invoke(telMag, (Object[]) null); // 再通过ITelephony对象去反射里面的endCall方法,挂断电话 Method mt = obj.getClass().getMethod("endCall"); //允许访问私有方法 mt.setAccessible(true); mt.invoke(obj); Toast.makeText(MainActivity.this, "挂断电话!", Toast.LENGTH_SHORT).show(); } catch (Exception e) { e.printStackTrace(); } } }, 5 * 1000); } catch (Exception e) { e.printStackTrace(); } } }); }}
通过上面代码,发现TelephonyManager对象是通过getSystemService(Context.TELEPHONY_SERVICE)方式获取到的,获取到了之后直接就.class了然后再用反射去调用私有方法getITelephony获取ITelephony。然后开始拨打电话了都分别是延迟了5秒自后就自动挂断了电话。如果你反射的方法需要传参数的话,则需要在getMethod方法里面先传入第一个参数你需要反射的方法名,再传入第二个参数则是个class[]数组里面包含需要反射方法里面的参数类型。然后再在invoke方法里面先传入第一个参数也就是你的需要反射的类,第二个参数则是反射方法里面的参数数值。这样咱们就能成功的反射到拨打电话和挂断电话的方法了。
哦,对了,各位不要忘记加权限哦。(android:name=”android.permission.CALL_PHONE”)这个权限。
本篇博客就到这里,如果有疑问的欢迎留言讨论。同时希望大家多多关注我的博客,多多支持我。
尊重原创转载请注明:(http://blog.csdn.net/u013895206) !
下面是地址传送门:址:http://download.csdn.net/detail/u013895206/9851063
- android 自动拨打电话和挂断电话(反射和intent方式)
- android 自动拨打电话和挂断电话(反射和intent方式)
- android自动接听和挂断电话
- Android 电话自动接听和挂断详解
- 实现甩动拨打和挂断电话
- 实现甩动拨打和挂断电话
- 实现电话自动拨打、挂断
- 实现电话自动拨打、挂断
- 实现电话自动拨打、挂断
- 实现电话自动拨打、挂断
- Android自动挂断电话
- Android 实现自动接听和挂断电话功能
- Android自动接听和挂断电话实现原理
- Android自动接听和挂断电话实现原理
- Android短信和拨打电话
- android自动拨打电话
- Android 自动拨打电话
- Android拨打、接听、挂断电话操作
- 第60讲 数组的作业讲评
- hdu 1728 逃离迷宫
- JS中String()与new String()的差异浅析
- 导入项目启动报错Unexpectedexception parsing XML document from file[H:\software\apache-tomcat-7.0.77\webapps\
- Q&A——性能优化(二)
- android 自动拨打电话和挂断电话(反射和intent方式)
- iOS中打包.a静态库
- Java 导出Excel 和 打包导出
- 善用 PHP-FPM 的 slow log 分析问题
- css 教程
- 怎么判断一个构造函数有多少个实例
- 查询产生临时表的调优
- Android Animation 动画介绍和实现
- 在构造函数中需要初始化列表初始化的有如下三种情况