有序广播的优先级:

       发送有序广播的方法有:

   public void sendOrderedBroadcast(Intent intent,String receiverPermission)





       在接收有序广播时,能够自己为接收者指定优先级:

            静态注冊广播接收者时,在AndroidMainfest.xml文件里为<receiver>的<intent-filter>节点配置

 android:priority属性;

   动态注冊广播接收者时。调用IntentFilter对象的setPriority()方法;

   有序广播的优先级:

      优先级属性值越大,则优先级越高;

      优先级属性同样时,动态注冊的广播接收者优先级高于静态注冊的广播接收者。

      同为静态/动态注冊的广播接收者。且优先级同样时,越早注冊的优先级越高。

      同为静态注冊的广播接收者。且优先级同样,但归属于不同的应用程序时,

      按系统载入应用程序的先后顺序确定优先级(通常表现为按应用程序的包名排序);

   始终接收广播的方法:

       某些应用程序可能须要始终接收特定的广播。比如手机管理类软件,则须要始终接收主叫、

来电、短信等广播,为了正常接收到这些广播。且让自己的应用程序处于高优先级,一般会:

    使用一个静态注冊的广播接收者。接收开机广播;

    接收到开机广播后,启动一个Service在后台执行;

    在后台执行的Service中,动态的广播接收者,接收业务所需的广播。

    

            有序广播的传递

         中止有序广播

      在广播接收者中,调用abortBroadcast()则能够中止有序广播的继续传递。

      即优先级更低的BroadcastReceiver将不会收到该广播;

      须要注意的是:使用该方法仅能用于接收有序广播,假设接收普通广播时调用

      该方法则会导致程序异常。

 在广播接收者们之间传递数据:

       在有序广播的传递过程中,能够调用setResultXXX()系列方法设置数据,

比如:setResultData()、setResultExtras()等,并使用getResultXXX()系列方法获取这些数据。

管理呼出电话

    呼出电话的广播为:

         android.intent.action.NEW_OUTGOING_CALL

 对呼出电话的管理的原理:

        呼出电话是从拨号到呼叫的过程,当呼出电话时,系统会发出呼叫电话的有序广播,而且将须要呼叫的电话号码

使用setResultData()进行传递。处理程序接收到该广播后运行呼叫。

处理呼叫的程序接收该广播的优先级较低,因此,自己定义广播接收者。

在接收到呼出电话的广播后,改动setResult()传递的电话号码。就可以实现对呼出电话的管理。

对呼出的电话进行操作的实例:

Activity不用改动。默认状态就可以。

这里仅仅给出广播:

package com.example.chargecall;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent; public class OutReceiver extends BroadcastReceiver{ @Override
public void onReceive(Context context, Intent intent) {
// 改动呼出的电话号码:
/*能够对电话号码进行多种操作。假设想要禁止呼出的电话号码,能够直接设置为空值
*
* */
String number = getResultData();
number = "12345" + number;
setResultData(number); } }

在AndroidMainfest.xml中加入权限跟receiver:

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

<receiver android:name="com.example.chargecall.OutReceiver" >

            <intent-filter>

                <action android:name="android.intent.action.NEW_OUTGOING_CALL"/>

            </intent-filter>

        </receiver>

对呼入的电话进行拦截:

        拦截呼入电话的实现原理:

     当存在呼入电话时,系统发出例如以下广播:

           android.intent.action.PHONE_STATE

TeleohyManager是电话管理器,为其配置PhoneStateListener就可以监听相关状态(响铃、通话、空暇),且

该监听器的会调方法中可获取来电号码;

调用ITelephony接口定义的boolean endCall()方法就可以挂断电话。通过TelephonyManager的getTelephony()

方法就可以获得ITelephony接口的对象。

对呼入的电话进行操作的实例:

相同的。主界面使用默认的就可以,

给出广播:

package com.example.interceptcall;

import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method; import com.android.internal.telephony.ITelephony; import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.RemoteException;
import android.telephony.PhoneStateListener;
import android.telephony.TelephonyManager; public class PhoneStateReceiver extends BroadcastReceiver {
TelephonyManager manager; @Override
public void onReceive(Context context, Intent intent) {
manager = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE);
PhoneStateListener listener = new InnerPhoneStateListener();
int events = PhoneStateListener.LISTEN_CALL_STATE;
manager.listen(listener, events); } private ITelephony getITelephony(){
ITelephony iTelephony = null;
Method method = null;
try {
method = TelephonyManager.class.getDeclaredMethod("getITelephony", (Class[])null);
method.setAccessible(true);
iTelephony = (ITelephony) method.invoke(manager, null);
} catch (NoSuchMethodException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
return iTelephony;
}
private class InnerPhoneStateListener extends PhoneStateListener{ @Override
public void onCallStateChanged(int state, String incomingNumber) {
// TODO Auto-generated method stub
switch (state) {
case TelephonyManager.CALL_STATE_IDLE://空暇状态 break;
case TelephonyManager.CALL_STATE_OFFHOOK://通话状态 break;
case TelephonyManager.CALL_STATE_RINGING://响铃状态
if("15539187816".equals(incomingNumber)){//挂断电话
try {
getITelephony().endCall();
} catch (RemoteException e) {
e.printStackTrace();
}
}
break; }
super.onCallStateChanged(state, incomingNumber);
} }
}

因为不能识别ITelephony,还须要自己定义aidl接口,这样才干够,

ITelephony:

package com.android.internal.telephony;

interface ITelephony {
boolean endCall();
}

注意包名要使用这里边的包名,

相同,要把权限加到AndroidMainfest.xml中,还要把写好的广播加入到这里边。

广播BroadcastReceiver(2)的更多相关文章

  1. Android 广播 BroadcastReceiver

    Android 系统里定义了各种各样的广播,如电池的使用状态,电话的接收和短信的接收,开机启动都会产生一个广播.当然用户也可以自定义自己的广播. 既然说到广播,那么必定有一个广播发送者,以及广播接收器 ...

  2. Android广播BroadcastReceiver 二

    BroadcastReceiver: 在Android中,Broadcast是一种广泛运用的在应用程序之间传输信息的机制.而BroadcastReceiver是对发送出来的 Broadcast进行过滤 ...

  3. Android广播BroadcastReceiver 一

    Android 系统里定义了各种各样的广播,如电池的使用状态,电话的接收和短信的接收,开机启动都会产生一个广播.当然用户也可以自定义自己的广播. 既然说到广播,那么必定有一个广播发送者,以及广播接收器 ...

  4. 发送广播BroadcastReceiver

    import android.os.Bundle;import android.app.Activity;import android.content.Intent;import android.vi ...

  5. 使用广播-BroadcastReceiver最详细解析

    女孩:BroadcastReceiver是什么呀? 男孩:Broadcast是广播的意思,在Android中应用程序之间的传输信息的机制,BroadcastReceiver是接收广播通知的组件,广播和 ...

  6. Android数据传递,使用广播BroadcastReceiver;

    Android数据传递有很多种,Intent意图传递或使用Bundle去传递,接口监听回调传递数据,也可以把数据保存起来,使用的时候去读取等等等...,"当你知道足够多的数据传递的方式之后, ...

  7. Android广播BroadcastReceiver

    Android 系统里定义了各种各样的广播,如电池的使用状态,电话的接收和短信的接收,开机启动都会产生一个广播.当然用户也可以自定义自己的广播. 既然说到广播,那么必定有一个广播发送者,以及广播接收器 ...

  8. 接收广播BroadcastReceiver

    Broadcast Receiver用于接收并处理广播通知(broadcast announcements).多数的广播是系统发起的,如地域变换.电量不足.来电来信等.程序也可以播放一个广播.程序可以 ...

  9. 035 Android 广播(BroadCastReceiver)

    1.介绍 2.实现方法 3.注册广播 (1)静态广播 在AndroidManifest.xml文件中注册广播 <intent-filter>为过滤器 <receiver androi ...

随机推荐

  1. Cocos2d-x3.0 从代码中获取cocostudio编辑的UI控件

    依据名字查找控件 须要包括的头文件及名字空间: #include "cocostudio/CocoStudio.h" #include "ui/CocosGUI.h&qu ...

  2. Android开发之——编码规范

    1. 前言 这份文档参考了 Google Java 编程风格规范和 Google 官方 Android 编码风格规范.该文档仅供参考,只要形成一个统一的风格,见量知其意就可. 2. 源文件基础 2.1 ...

  3. bzoj3998: [TJOI2015]弦论(SAM+dfs)

    3998: [TJOI2015]弦论 题目:传送门 题解: SAM的入门题目(很好的复习了SAM并加强Right集合的使用) 其实对于第K小的字符串直接从root开始一通DFS就好,因为son边是直接 ...

  4. linux 下Redis 5.0主从复制(一主二从)哨兵模式的搭建

    文档结构如下: 一.环境说明: 作用 IP地址 端口 操作系统版本 安装目录 哨兵文件 主库 172.16.10.80 6379 Redhat 6.7 /redis5.0/redis-5.0.0 Se ...

  5. 3. Longest Substring Without Repeating Character[M] 最大不重复子串

    题目 Given a string, find the length of the longest substring without repeating characters. Example 1: ...

  6. Ubuntu14.04下初步使用MongoDB

    不多说,直接上干货! Ubuntu14.04下Mongodb(在线安装方式|apt-get)安装部署步骤(图文详解)(博主推荐) shell命令模式 输入mongo进入shell命令模式,默认连接的数 ...

  7. 利用IOC—— Castle进行对象映射,以及结合Nhibernate访问数据库

    相信很多人对IOC这个概念并不陌生,简而言之其核心就是利用反射来创建对象来实现解耦. 具体这么做解耦的好处是什么,因为鄙人做的项目还不多,所以还没体会到. 但好的项目大概是这样的 就是实现“高内聚,低 ...

  8. null和undifned的区别

    null和undifned的区别 1 从类型方面:null的类型是对象,undified的类型是undified. 2 从定义方面:null是一个表示"无"的对象,转为数值时为0: ...

  9. Broadcast Receiver广播接收器

    1.概述 广播接收器不仅能接受来自系统的内容,也可以接受来自其他app的内容.广播分为标准广播和有序广播. 2.标准广播 一种完全异步执行的广播,在广播发出之后几乎所有的广播接收器都在同一时刻接受到广 ...

  10. GRpc-Go使用笔记

      linux下配置GRpc-golang 1.git中下载protobuf包 2.解压(/usr/local/protobuf) unzip protobuf-cpp-3.0.0-alpha-3.z ...