BroadcastReceiver启动Service 3.1之后静态注册

时间:2022-11-18 23:23:18
/* BroadcastReceiver广播接收者...3句概述:
1 全局广监听器.用于响应应用程序发出的Broadcast(广播)
2 可实现客户端通过startService()启动的Service进行通信.
3 本质上是一个系统级的监听器.与前面监听级区别(程序级,与应用同进程,随应用结束结束);系统级监听器有自己的进程.

使用分2步:
1 定义继承BroadcastReceiver的子类,重写onReceiver()方法.
2 在AndroidManifest.xml中显示配置元素3属性<receiver name: action:(intent_filter下) priority:(-1000-1000)>
当然也可在Java代码中进行指定可配置的Intent
IntentFilter filter=new IntentFilter("action属性");
BroadcastReceiver receiver=new BroadcastReceiver();
registerReceiver(receiver,filter);

应用发送广播分2步:
1 创建Intent对象(指定要启动的组件),设置action参数
2 sendBroadcast()/发送普通广播 sendOrderingBroadcast()/发有序广播. 若找不到接收对象,不会有任何问题.

广播过程:广播事件(发出广播)-->实例化BroadcastReceiver对象-->执行onReceiver()-->销毁对象
注意:onReceiver()方法内不能进行耗时任务,若有应考虑用Intent启动一个Service,而非新线程(进程里没有组件会优先被结束进程)

广播分2类:普通广播(向四周炸开,大家同时收到);有序广播(sendOrdering()方法.):根据BroadcastReceiver的priority属性优先级排序.
传播3句:
1 优先级高的BroadcastReceiver最先接收到Broadcast
2 对象可以调用abortBroadcast()方法,取消Broadcast继续向下传播,优先级低的将无法接收到.
3 对象可以调用setResultExtras();将处理结果存入到Broadcast中,下一接收者可getResultExtras(true)方法取出上一结果.

接收系统的广播消息:1句,Android应用的大量事件都会向外发出标准广播.
常用的广播Action常量有(查Intent)
ACTION_BOOT_COMPLETED/系统启动完成
ACTION_BATTERY_CHANGED/电池电量改变
ACTION_BATTERY_LOW/电池电量低

通过BroadcastReceiver监听特殊的广播即可随系统执行特定的操作.

开机自动运行:系统启动完成广播-->3步
1 定义BroadcastReceiver子类.
2 注册BroadcastReceiver,能匹配的Intent,action属性加上ACTION_BOOT_COMPLETED
3 加权限
android 3.1之后不允许没有Activity的应用.....

*/



package com.example.tyxiong.myapplication;


import android.app.Activity;
import android.os.Bundle;


public class MainActivity extends Activity {


@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

}
}



/* BroadcastReceiver广播接收者...3句概述:
1 全局广监听器.用于响应应用程序发出的Broadcast(广播)
2 可实现客户端通过startService()启动的Service进行通信.
3 本质上是一个系统级的监听器.与前面监听级区别(程序级,与应用同进程,随应用结束结束);系统级监听器有自己的进程.

使用分2步:
1 定义继承BroadcastReceiver的子类,重写onReceiver()方法.
2 在AndroidManifest.xml中显示配置元素3属性<receiver name: action:(intent_filter下) priority:(-1000-1000)>
当然也可在Java代码中进行指定可配置的Intent
IntentFilter filter=new IntentFilter("action属性");
BroadcastReceiver receiver=new BroadcastReceiver();
registerReceiver(receiver,filter);

应用发送广播分2步:
1 创建Intent对象(指定要启动的组件),设置action参数
2 sendBroadcast()/发送普通广播 sendOrderingBroadcast()/发有序广播. 若找不到接收对象,不会有任何问题.

广播过程:广播事件(发出广播)-->实例化BroadcastReceiver对象-->执行onReceiver()-->销毁对象
注意:onReceiver()方法内不能进行耗时任务,若有应考虑用Intent启动一个Service,而非新线程(进程里没有组件会优先被结束进程)

广播分2类:普通广播(向四周炸开,大家同时收到);有序广播(sendOrdering()方法.):根据BroadcastReceiver的priority属性优先级排序.
传播3句:
1 优先级高的BroadcastReceiver最先接收到Broadcast
2 对象可以调用abortBroadcast()方法,取消Broadcast继续向下传播,优先级低的将无法接收到.
3 对象可以调用setResultExtras();将处理结果存入到Broadcast中,下一接收者可getResultExtras(true)方法取出上一结果.

接收系统的广播消息:1句,Android应用的大量事件都会向外发出标准广播.
常用的广播Action常量有(查Intent)
ACTION_BOOT_COMPLETED/系统启动完成
ACTION_BATTERY_CHANGED/电池电量改变
ACTION_BATTERY_LOW/电池电量低

通过BroadcastReceiver监听特殊的广播即可随系统执行特定的操作.

开机自动运行:系统启动完成广播-->3步
1 定义BroadcastReceiver子类.
2 注册BroadcastReceiver,能匹配的Intent,action属性加上ACTION_BOOT_COMPLETED
3 加权限



*/

package com.example.tyxiong.myapplication;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.util.Log;

public class MyReceiver extends BroadcastReceiver {

public MyReceiver() {
}

@Override
public void onReceive(Context context, Intent intent) {

switch (intent.getAction()) {
case Intent.ACTION_BOOT_COMPLETED: {
Intent intent1 = new Intent(context, MyService.class);
intent1.putExtra("boot", "开机完成>>>>");
context.startService(intent1);
}
case "android.provider.Telephony.SMS_RECEIVED":

{
Log.w("xxx", "收到短信>>>");
}
case Intent.ACTION_TIME_CHANGED: {

Log.w("xxx", "日期更改>>>");
Intent intent1 = new Intent(context, MyService.class);
intent1.putExtra("boot", "日期更改>>>>");
context.startService(intent1);
}

}
}


}





/*
*Service服务:与Activity最相似;都继承了Context;有自己的生命周期;也可作为可执行的程序.
*区别是运行在后台,不会有界面.
* 使用中如果需要用户交互应该用Activity;否则应该选用Service.
* 生命周期方法5个:onCreate() onBind() onStartCommand() onUnbind() onDestroy()
* onCreate() Service第一次实例化回调
* onBind() 该方法返回IBinder对象,用于应用程序与Service通信;必须重官吏的方法,通常继承Binder()子类来实现自己的IBinder对象.
* onStartCommand()当调用startService()方法启动Service时会回调方法.
* onUnbind()Service上的客户端都断开连接时回调
* onDestroy()Service被关闭时回调.
*
*同样使用Service需要继承基类或其子类 IntentService
* 使用步骤2
* 1 定义继承Service的子类,重写其周期方法 onBind()为必须重写的方法.
* 2 在AndroidManifest.xml中配置<service name:> 四大组件须显式配置.
*
* Android5.0开始,要求须显式Intent启动Service.
* 启动关闭(配套使用的)Service startService() stopService() 这样启动的Service与启动它的客户端没有什么联系.
* bindService() unBindService()这样启动的Service与客户端绑定在一起了,当
* 访问者退出,Service与退出.
*
* 当bindService(ServiceConnection)方法启动, onBinder()方法返回的IBinder对象会给到 ServiceConnection对象onServiceConnected()方法
*
* 当客户端连接到Service,onServiceConnected()被回调;异常中止回调onServiceDisconnected();(正常unBindService()不会回调)
*
*生命周期分2种:客户端调用startService()方法-->onCreate()回调-->onStartCommand()回调-->调用stopService()-->onDestroy()回调.
* 客户端调用bindService()方法-->onCreate()回调-->onBind()回调-->unBindService()-->onUnBind()回调-->onDestroy()回调
*
* Service有2缺陷: 与所在的应用为同一进程;不是单独的线程,不能进行耗时任务.
*
* IntentService:继承了Service, 5个优点:
* 1 用队列的形式来处理Intent.
* 2 单独的线程处理onHandlerIntent()方法
* 3 当Intent处理完成,自动停止.
* 4 重写了onBind()方法 onStartCommand()方法
* 5 使用IntentService只需要实现OnHandlerIntent()方法即可...(由于会单独线程,无须担心阻塞线程或ANR)
*
* */


package com.example.tyxiong.myapplication;

import android.app.IntentService;
import android.content.Intent;
import android.os.Handler;
import android.widget.Toast;


public class MyService extends IntentService {


public MyService() {
super("MyService");//指定该线路线线程的线线程名...
}


@Override
protected void onHandleIntent(final Intent intent) {//该方法不会阻塞UI线程,也不会ANR, 单独的线程.
// Log.w("xxx",intent.getStringExtra("boot"));
Handler handler = new Handler(getMainLooper());
handler.post(new Runnable() {
@Override
public void run() {
Toast.makeText(getApplicationContext(), intent.getStringExtra("boot"),
Toast.LENGTH_SHORT).show();

}
});//这里不能直接处理Toast,隐藏显示的时候,onHandleIntent()线程挂了,需要交给主线程的Handler处理.
}

}



<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.example.tyxiong.myapplication">

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


<application
android:name="MainActivity"
android:allowBackup="true"

android:icon="@mipmap/ic_launcher"
android:supportsRtl="true"
android:theme="@android:style/Theme.Holo.Light"
tools:ignore="AllowBackup,GoogleAppIndexingWarning">

<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />


<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>

<service android:name=".MyService" />

<receiver
android:name=".MyReceiver"
android:exported="true">
<intent-filter android:priority="1000">
<action android:name="android.intent.action.BOOT_COMPLETED" />
<action android:name="android.provider.Telephony.SMS_RECEIVED" />
<action android:name="android.intent.action.TIME_SET" />

</intent-filter>
</receiver>
</application>

</manifest>