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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • HDU 2896 病毒侵袭 AC自己主动机题解

    HDU 2896 病毒侵袭 AC自己主动机题解

    2022年1月25日
    66
  • Dreamweaver 2020 安装教程

    Dreamweaver 2020 安装教程AdobeDreamweaver,简称“DW”,中文名称”梦想编织者”,是集网页制作和管理网站于一身的所见即所得网页代码编辑器。利用对HTML、CSS、JavaScript等内容的支持,设计人员和开发人员可以在几乎任何地方快速制作和进行网站建设。它第一套针对专业网页设计师特别发展的视觉化网页开发工具,利用它可以轻而易举地制作出跨越平台限制和跨越浏览器限制的充满动感的网页。受众人群:网页设计师,UI设计师,电商美工,学生及业余爱好者1、所见即所得的强大功能没有一个Web编辑软件能像Dream

    2022年5月29日
    38
  • Lombok插件的简介「建议收藏」

    Lombok插件的简介「建议收藏」Lombok插件的简介1Lombok引入2Lombok常见注解使用1@Data2@AllArgsConstructor3@NoArgsConstructor4@ToString5@EqualsAndHashCode6@Getter/@Setter7@Slf4j8@NonNull9@Value10@Builder11@Synchronized12@SneakyThrows13@Cleanup3Lombok原理4关于Lombok总结官网:https://projectlom

    2022年9月8日
    0
  • ANDROID 中设计模式的採用–创建型模式[通俗易懂]

    ANDROID 中设计模式的採用–创建型模式

    2022年1月23日
    49
  • Navicat Premium 15激活【2021最新】

    (Navicat Premium 15激活)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月28日
    65
  • Java和Python哪个更适合初学者的问题

    Java和Python哪个更适合初学者的问题我个人不是很喜欢讨论这个问题,为什么呢,每个人都学习能力不一样,你要是不行,哪个对于你也不简单。客观分析,这两种语言都在程序员的工具箱中都占有一席之地。学习哪个并不重要,个人觉得对于入门级同学来说,你要学的是“编程思想的基础知识“,而不是”特定的编程语言“。那这两门语言有区别吗?当然有,对于有一定编程经验的人来说…

    2022年7月7日
    16

发表回复

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

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