zoukankan      html  css  js  c++  java
  • 【Android中Broadcast Receiver组件具体解释 】

    BroadcastReceiver(广播接收器)是Android中的四大组件之中的一个。

     

    以下是Android Doc中关于BroadcastReceiver的概述:
    ①广播接收器是一个专注于接收广播通知信息,并做出相应处理的组件。非常多广播是源自于系统代码的──比方,通知时区改变、电池电量低、拍摄了一张照片或者用户改变了语言选项。应用程序也能够进行广播──比方说,通知其他应用程序一些数据下载完毕并处于可用状态。
    ②应用程序能够拥有随意数量的广播接收器以对全部它感兴趣的通知信息予以响应。全部的接收器均继承自BroadcastReceiver基类。
    ③广播接收器没实用户界面。然而,它们能够启动一个activity来响应它们收到的信息,或者用NotificationManager来通知用户。通知能够用非常多种方式来吸引用户的注意力──闪动背灯、震动、播放声音等等。一般来说是在状态栏上放一个持久的图标,用户能够打开它并获取消息。

     

    Android中的广播事件有两种,一种就是系统广播事件,比方:ACTION_BOOT_COMPLETED(系统启动完毕后触发),ACTION_TIME_CHANGED(系统时间改变时触发),ACTION_BATTERY_LOW(电量低时触发)等等。第二种是我们自己定义的广播事件。

     

    广播事件的流程
    ①注冊广播事件:注冊方式有两种,一种是静态注冊,就是在AndroidManifest.xml文件里定义,注冊的广播接收器必需要继承BroadcastReceiver;还有一种是动态注冊,是在程序中使用Context.registerReceiver注冊,注冊的广播接收器相当于一个匿名类。两种方式都需要IntentFIlter
    ②发送广播事件:通过Context.sendBroadcast来发送,由Intent来传递注冊时用到的Action。
    ③接收广播事件:当发送的广播被接收器监听到后,会调用它的onReceive()方法,并将包括消息的Intent对象传给它。onReceive中代码的运行时间不要超过5s,否则Android会弹出超时dialog。

     

    以下我通过代码演示自己定义广播事件和系统广播事件的使用。完整代码下载地址:android_broadcastreceiver.rar

    Step1:在MainActivity的onStart方法中注冊广播事件。静态注冊方式是在AndroidManifest.xml文件里。

    Step2: 点击对应button后会触发对应的方式来发送广播消息。

    Step3:接收广播消息。下面为两个静态注冊的广播接收器。

    以下是AndroidManifest.xml文件:

    界面布局文件main.xml

    解说结束,只是有一点我自己也没弄清楚,这个系统广播事件假设我在程序中sendBroadcast的话,那就是自己定义广播了。假设不写的话,那是不是系统自己来发送相应Action广播呢?有知道的同学请告诉我一下,再此先谢过。  

    执行界面:

  • 相关阅读:
    SQL练习题28:创建一个actor表,包含如下列信息(注:sqlite获取系统默认时间是datetime('now','localtime'))
    SQL练习题27:你能使用子查询的方式找出属于Action分类的所有电影对应的title,description吗
    SQL练习题26: 将employees表的所有员工的last_name和first_name拼接起来作为Name,中间以一个空格区分 (注:该数据库系统是sqllite,字符串拼接为 || 符号,不支持concat函数)
    SQL练习题25:使用join查询方式找出没有分类的电影id以及名称
    SQL练习题24:给出每个员工每年薪水涨幅超过5000的员工编号emp_no、薪水变更开始日期from_date以及薪水涨幅值salary_growth,并按照salary_growth逆序排列。 (数据保证每个员工的每条薪水记录to_date-from_date=1年,而且同一员工的下一条薪水记录from_data=上一条薪水记录的to_data)
    SQL练习题23:汇总各个部门当前员工的title类型的分配数目,即结果给出部门编号dept_no、dept_name、其部门下所有的当前(dept_emp.to_date = '9999-01-01')员工的当前(titles.to_date = '9999-01-01')title以及该类型title对应的数目count
    SQL练习题23:获取员工其当前的薪水比其manager当前薪水还高的相关信息,当前表示to_date='9999-01-01', 结果第一列给出员工的emp_no, 第二列给出其manager的manager_no, 第三列给出该员工当前的薪水emp_salary, 第四列给该员工对应的manager当前的薪水manager_salary
    SQL练习题22:获取所有非manager员工当前的薪水情况,给出dept_no、emp_no以及salary ,当前表示to_date='9999-01-01'
    SQL练习题22:查找所有员工自入职以来的薪水涨幅情况,给出员工编号emp_no以及其对应的薪水涨幅growth,并按照growth进行升序
    SQL练习题21:查找当前薪水(to_date='9999-01-01')排名第二多的员工编号emp_no、薪水salary、last_name以及first_name,你可以不使用order by完成吗
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/4553778.html
Copyright © 2011-2022 走看看