BroadcastReceiver启动Service 3.1之后静态注册

/* 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
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋葵好吃吗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值