android之来电自动拒接并自动回复短信_上课模式app「建议收藏」

上课的时候老师说总是错过电话,对方打来没人接还一遍遍的打,觉得可以有个app在上课期间自动拒接电话,并自动回复短信过去.当然了,需要权限的.尝试做了个雏形出来.界面如下:主要代码如下:package jason.teacher;import java.lang.reflect.Method;import java.util.HashMap;import ja

大家好,又见面了,我是全栈君。

上课的时候老师说总是错过电话,对方打来没人接还一遍遍的打,觉得可以有个app在上课期间自动拒接电话,并自动回复短信过去.

当然了,需要权限的.

尝试做了个雏形出来.

界面如下:

android之来电自动拒接并自动回复短信_上课模式app「建议收藏」

主要代码如下:

package jason.teacher;

import java.lang.reflect.Method;
import java.util.HashMap;
import java.util.List;

import android.app.Activity;
import android.content.Context;
import android.content.SharedPreferences;
import android.content.SharedPreferences.Editor;
import android.os.Bundle;
import android.telephony.PhoneStateListener;
import android.telephony.SmsManager;
import android.telephony.TelephonyManager;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;

import com.android.internal.telephony.ITelephony;

public class MainActivity extends Activity {
	
    public final static String TAG = "jason.com";
    TelephonyManager tpm;
    String num;//存储来电号码
    Button end;//退出按钮
    EditText sms;//回复短信的内容编辑框
    SharedPreferences sp;
    int count = 0;//来电总数
    int peo = 0;//来电的号码个数,跟来电总数有区别,这个不包括重复来电,
    TextView counttext;//拦截数量通知的显示
    HashMap<String, String> numMap;//用来存储来电号码
    @Override
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.activity_main);
        sp = this.getSharedPreferences("SP", MODE_PRIVATE);
        counttext = (TextView) findViewById(R.id.count);
        sms = (EditText) findViewById(R.id.sms);
        end = (Button) findViewById(R.id.start);
        numMap = new HashMap<String, String>();
        if(sp.getString("sms", null) != null){
        	sms.setText(sp.getString("sms", "我现在正在上课,一会儿下课了联系你"));
        }
        tpm = (TelephonyManager) this.getSystemService(Context.TELEPHONY_SERVICE);//获取电话通讯服务
         tpm.listen(new MyPhoneStateListener(),PhoneStateListener.LISTEN_CALL_STATE);//给电话服务增加状态监听器,监听来电,通话,挂断等状态
        end.setOnClickListener(new OnClickListener() {
			@Override
			public void onClick(View v) {
				Editor editor = sp.edit();
				editor.putString("sms", sms.getText().toString());
				editor.commit();//这里是默认自动保存用户编辑过的回复短信内容的,
				finish();
			}
		});
    }
    class MyPhoneStateListener extends PhoneStateListener {
    	@Override
        public void onCallStateChanged(int state, String incomingNumber) {
    		num = incomingNumber;
            switch(state) {
            case TelephonyManager.CALL_STATE_IDLE: //空闲
                break;
            case TelephonyManager.CALL_STATE_RINGING: //来电
            	endCall();//自动挂断
            	if(!numMap.containsKey(num)){//如果之前没有来电,则把这个号码加入已经来电过的列表
            		sendMes();
            		numMap.put(num, null);
            		peo ++;
            		updateUi();//更新来电数目
            	}
            	break;
            case TelephonyManager.CALL_STATE_OFFHOOK: //摘机(正在通话中)
                break;
            }
        }
    	private void updateUi(){
    		if(count > 0){
    			counttext.setVisibility(View.VISIBLE);
    		}
    		counttext.setText("已拒接" + count + "个来电,共" + peo +"个人联系过您,请到通话记录查看");
    	}
    	private void endCall()//估计这里是唯一有点难度的,用到了java的反射
        {  
            Class<TelephonyManager> c = TelephonyManager.class;           
            try
            {  
                Method getITelephonyMethod = c.getDeclaredMethod("getITelephony", (Class[]) null);  
                getITelephonyMethod.setAccessible(true);  
                ITelephony iTelephony = null;
                iTelephony = (ITelephony) getITelephonyMethod.invoke(tpm, (Object[]) null);  
                iTelephony.endCall();
                count ++;
                updateUi();
            }  
            catch (Exception e)  
            {  
                Log.e(TAG, "Fail to answer ring call.", e);  
            }          
        }  
    	
    	private void sendMes(){
    		//直接调用短信接口发短信
    		SmsManager smsManager = SmsManager.getDefault();
    		List<String> divideContents = smsManager.divideMessage(sms.getText().toString()); 
    		for (String text : divideContents) {    
    			smsManager.sendTextMessage(num, null, text, null, null);  
    		}
    	}
    }
}

这里解释一下,在android在1.1版本后就已经把Phone类的相关API给隐藏起来了,想要用代码实现挂断电话的功能,就必须通过AIDL才行,然后利用反射来使用其方法。

第一步:在程序中新建一个包,包名必须为:com.android.internal.telephony,因为要使用aidl。

第二步:在这个包里面新建一个名为ITelephony.aidl的文件,然后在文件里面写入代码:

package com.android.internal.telephony;
	interface ITelephony{
		boolean endCall();
		void answerRingingCall();
	}

这样就可以通过如下代码进行进一步获取拒接电话的api的操作了.

 

private void endCall()
        {  
            Class<TelephonyManager> c = TelephonyManager.class;           
            try
            {  
                Method getITelephonyMethod = c.getDeclaredMethod("getITelephony", (Class[]) null);  
                getITelephonyMethod.setAccessible(true);  
                ITelephony iTelephony = null;
                iTelephony = (ITelephony) getITelephonyMethod.invoke(tpm, (Object[]) null);  
                iTelephony.endCall();
                count ++;
                updateUi();
            }  
            catch (Exception e)  
            {  
                Log.e(TAG, "Fail to answer ring call.", e);  
            }          
        }  

还有就是别忘了加权限,否则是一点效果都没有的.

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

不过有一点不解的是在这里没有用到打电话的权限,但是如果不加

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

的话,来电话的时候竟然不会进行挂断操作,尝试了好几次都是如此,最后只能再把这个权限加上,虽然在我看来完全没用,安装的时候还会让人觉得你这个应用会不会偷偷打电话啊.

当然了,这个完全可以做成后台服务的形式,不过老师就是上课才用,也没那么多要求,如果继续丰富一下,还是比较实用的.

作者:jason0539

博客:http://blog.csdn.net/jason0539(转载请说明出处)

扫码关注我微信公众号

android之来电自动拒接并自动回复短信_上课模式app「建议收藏」

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/121400.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 图片url地址的生成获取方法

    图片url地址的生成获取方法图片url地址的生成获取方法  在写博客插入图片时,许多时候需要提供图片的url地址。作为菜鸡的我,自然是一脸懵逼。那么什么是所谓的url地址呢?又该如何获取图片的url地址呢?  首先来看一下度娘对url地址的解释:url是统一资源定位符,对可以从互联网上得到的资源的位置和访问方法的一种简洁的表示,是互联网上标准资源的地址。互联网上的每个文件都有一个唯一的url,它包含的信息指出文件的位置以及浏览器应该怎么处理它。  简单来说,url地址是是用来定位、访问网上资源用的。常见的网址也属于url地

    2022年9月22日
    2
  • 串口服务器中文使用文档,MOXA 串口服务器中文使用文档.doc

    MOXA串口服务器中文使用文档MOXA串口联网服务器NPORT5130特点-以太网口支持100/10M自适应,串口支持RS-422,RS-485(2w/4w)-低成本、信用卡大小-支持Windows/LinuxCOM串口驱动程序模式-提供包括TCPServer、TCPClient、UDPServer/Client和EthernetModem在内的不同socket操作模式-…

    2022年4月7日
    44
  • navicat的注册码_navicat密钥注册

    navicat的注册码_navicat密钥注册Navicat相关注册码用户名和组织随便起。注册码如下 –NavicatforSQLServerV10.0.10NAVD-3CG2-6KRN-IEPMNAVL-NIGY-6MYY-XWQENAVI-C3UU-AAGI-57FW -NavicatPremium注册码NAVJ-E6YF-JULL-KKIGNAVE-BOCL-CE3X-TAGYNAVC-KAIA-NU5I-SPOXNAVL-…

    2022年10月13日
    2
  • 【报表制作技巧】动态列报表的制作「建议收藏」

    【报表制作技巧】动态列报表的制作「建议收藏」【报表制作技巧】动态列报表的制作

    2022年4月20日
    57
  • linux route源码,traceroute[通俗易懂]

    linux route源码,traceroute[通俗易懂]traceroute……….\traceroute-1.4a12……….\……………..\aclocal.m4……….\……………..\CHANGES……….\……………..\config.guess……….\……………..\config.sub……….

    2022年6月30日
    28
  • CreatePipe/CreateProcess[通俗易懂]

    CreatePipe/CreateProcess[通俗易懂]管道(Pipe)实际是用于进程间通信的一段共享内存,创建管道的进程称为管道服务器,连接到一个管道的进程为管道客户机。一个进程在向管道写入数据后,另一进程就可以从管道的另一端将其读取出来。匿名管道(AnonymousPipes)是在父进程和子进程间单向传输数据的一种未命名的管道,只能在本地计算机中使用,而不可用于网络间的通信。      匿名管道实施细则      匿名管道由Cre

    2022年7月26日
    22

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号