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
- BroadcastReceiver启动Service 3.1之后静态注册
- BroadCastReceiver 静态动态注册
- BroadCastReceiver 静态动态注册
- Android:静态注册BroadcastReceiver
- Android:静态注册BroadcastReceiver
- BroadcastReceiver 静态注册
- BroadcastReceiver组件 静态注册
- BroadcastReceiver注册与启动
- BroadcastReceiver在Service中注册
- BroadcastReceiver广播静态注册细节
- Service (在Service中注册BroadcastReceiver)
- BroadcastReceiver(静态注册和动态注册)
- BroadcastReceiver+Service .开机启动服务
- Service 里面注册BroadcastReceiver onReceiver为响应
- Android静态注册内部类广播BroadcastReceiver
- Android静态注册内部类广播BroadcastReceiver
- 谨慎使用静态注册的BroadcastReceiver
- 内部类广播BroadcastReceiver的静态注册
- Csensors云和图床--七牛客户端
- 数据结构实验之二叉树六:哈夫曼编码
- HDU 1232 畅通工程(并查集)
- pyqt4文档阅读(6.1):QBoxLayout-QHBoxLayout-QVBoxLayout
- Mysql之视图
- BroadcastReceiver启动Service 3.1之后静态注册
- {长郡内考}·11.5-数字乘积
- shell读取脚本同一个目录下的xml格式的文件
- RecyclerView使用Dome
- ios 中的UIControl类
- MediaPlayer播放音频
- Android.mk的用法和基础 && m、mm、mmm编译命令
- 【Java】Java的继承和多态详解
- 解决UltraEdit中文乱码