BroadcastReceiver启动Service 3.1之后静态注册

来源:互联网 发布:高收益网络理财平台 编辑:程序博客网 时间:2024/05/20 06:22
/* 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>
0 0
原创粉丝点击