android 大喇叭,广播实战

2024-08-25 09:38
文章标签 实战 广播 android 喇叭

本文主要是介绍android 大喇叭,广播实战,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在学校里,通常每个教室都会有一个大喇叭,只要广播室有什么通知,全校师生都能听到,类似的工作原理在计算机领域也有很广泛的应用。

比如一个IP地址中最大的地址是被保留作为广播地址使用的。 一如:IP地址范围是192.1680.0.x,子网掩码为255.255.255.0的网络,广播地址地址就是192.168.0.255.同样android 中也提供了类似机制。

广播的分类:
1)标准广播,是一种异步执行的广播,一个广播发出后,所有的接受者几乎都会在同一时刻接受到广播消息。
2)有序广播,则是一种同步执行的广播,在广播发出后,同一时刻只会有一个接受者会收到消息,当其执行完
后,广播才能继续被传播,当然前面的接受者也可以截断广播,

例子:
1)动态注册监听网络变化

public class MainActivity extends Activity {////////////////////////////////////////////////////////////////////////////////////////////////private IntentFilter            m_intentFilter;private NetWorkChangeReceiver   m_receiver;////////////////////////////////////////////////////////////////////////////////////////////////@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);init();}private void init(){//新建一个广播的过滤器m_intentFilter = new IntentFilter();//当网络状态发生变化时 系统便会发送这个广播 因此这个过滤器就能捕捉到这个广播m_intentFilter.addAction("android.net.conn.CONNECTIVITY_CHANGE");//新建一个广播接受者m_receiver = new NetWorkChangeReceiver();//注册广播registerReceiver(m_receiver, m_intentFilter);}//当活动摧毁的时候 记得把广播取消注册@Overridepublic void onDestroy(){super.onDestroy();unregisterReceiver(m_receiver);}//重写广播接受者的方法class NetWorkChangeReceiver extends BroadcastReceiver{@Overridepublic void onReceive(Context context, Intent intent) {Toast.makeText(context,"网络状态发生变化",Toast.LENGTH_SHORT).show();}}
}

不过这里因为访问了网络状态,所以要在AndroidManifest.xml中加这样一行

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

2)静态注册实现开机自启动

新建一个Java类 继承自BroadcastReceiver

/*** Created by 李嘉诚 on 2015/5/25.* 最后修改时间: 2015/5/25*/
public class BootCompleteReceiver extends BroadcastReceiver {@Overridepublic void onReceive(Context context, Intent intent) {Toast.makeText(context,"开机成功",Toast.LENGTH_LONG).show();}
}

由于接受系统广播,因此还需在AndroidManifest.xml中注册权限,除此之外还有广播接受者
AndroidManifest.xml文件如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="com.broadcast" ><application
        android:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:theme="@style/AppTheme" ><activity
            android:name=".MainActivity"android:label="@string/app_name" ><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity><receiver android:name=".BootCompleteReceiver"><intent-filter><action android:name="android.intent.action.BOOT_COMPLETED"/></intent-filter></receiver></application><uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission><uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"></uses-permission></manifest>

查看一下应用权限 就会发现有了开启自启动 同样你也可以重启一下机器 看有没有使用成功
这里写图片描述
3)自定义广播

新建一个广播接受者

package com.broadcast;import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.widget.Toast;/*** Created by 李嘉诚 on 2015/5/25.* 最后修改时间: 2015/5/25*/
public class ChanBroadcastReceiver extends BroadcastReceiver {//当广播接受者收到广播时 便会调用这个方法@Overridepublic void onReceive(Context context, Intent intent) {Toast.makeText(context, "这是我自定义的广播", Toast.LENGTH_SHORT).show();}
}

在AndroidManifest.xml中注册一下广播

  <receiver android:name=".ChanBroadcastReceiver"><intent-filter><action android:name="com.theOldMen.CHAN_BROADCAST"></action></intent-filter></receiver>

使用的时候 直接发送广播就行了,action要和注册的时候一样

public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);init();}private void init(){findViewById(R.id.m_sendButton).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent x = new Intent("com.theOldMen.CHAN_BROADCAST");sendBroadcast(x);}});}
}

运行效果
这里写图片描述
4)发送有序广播
广播是一种跨进程的通信方式,读者可以自己写另外一个程序,接受同样的广播消息,你会发现当前应用发送的广播,其他注册过的程序都能接受到,这个问题我们会在下面进行讲解

我们现在需要准备的是:两个应用,这两个应用都接受同一个广播,到现在为止,我已经假设你已经完成了那必要的准备,我们开始讲解有序广播

发送有序广播非常简单,只需修改一行代码就行

       findViewById(R.id.m_sendButton).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent x = new Intent("com.theOldMen.CHAN_BROADCAST");sendOrderedBroadcast(x,null);}});

第二个参数可以不予理会,它是跟权限有关的

好像并没有什么特别,别急,有序广播是有优先级的,因而还需指定优先级

  <receiver android:name=".ChanBroadcastReceiver"><intent-filter android:priority="100"><action android:name="com.theOldMen.CHAN_BROADCAST"></action></intent-filter></receiver>

这里设置了优先级 为100

刚刚说到,其实当前的广播接受者是可以丢弃广播的
如下:

/*** Created by 李嘉诚 on 2015/5/25.* 最后修改时间: 2015/5/25*/
public class ChanBroadcastReceiver extends BroadcastReceiver {//当广播接受者收到广播时 便会调用这个方法@Overridepublic void onReceive(Context context, Intent intent) {Toast.makeText(context, "这是我自定义的广播", Toast.LENGTH_SHORT).show();//丢弃广播 后面的人无法收到消息abortBroadcast();}
}

5)使用本地广播

会看第四部分的内容,我们了解到,其实普通广播发送的时候,任何注册了接受者的应用都能够收到广播消息,那么这就必然带来安全问题,那么当我们要发送的数据带有一些敏感信息的时候呢,我们是不是应该换种方式。幸运的是android提供了一种机制,他也是一种广播,但只能让本应用的接受者能够收到消息。这就是本地广播。

本地广播的使用并不复杂,主要使用一个LocalBroadcastManager来对广播进行管理,并提供了发送广播和注册广播的方法,实例如下

public class MainActivity extends Activity {////////////////////////////////////////////////////////////////////////////////////////////////private static final String     s_action = "com.chan.LOCAL_BROADCAST";////////////////////////////////////////////////////////////////////////////////////////////////private LocalBroadcastManager   m_manager;private LocalReceiver           m_receiver;private IntentFilter            m_filter;////////////////////////////////////////////////////////////////////////////////////////////////@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);init();}private void init(){//获得本地广播管理器m_manager = LocalBroadcastManager.getInstance(this);//设置接受者m_receiver = new LocalReceiver();//获得过滤器m_filter = new IntentFilter();m_filter.addAction(s_action);//注册广播m_manager.registerReceiver(m_receiver,m_filter);findViewById(R.id.m_sendButton).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent x = new Intent(s_action);//发送广播m_manager.sendBroadcast(x);}});}@Overridepublic void onDestroy(){super.onDestroy();//取消注册m_manager.unregisterReceiver(m_receiver);}class LocalReceiver extends BroadcastReceiver{@Overridepublic void onReceive(Context context, Intent intent) {Toast.makeText(context,"本地广播",Toast.LENGTH_SHORT).show();}}
}

运行结果
这里写图片描述

这篇关于android 大喇叭,广播实战的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1105203

相关文章

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例

《PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例》词嵌入解决NLP维度灾难,捕捉语义关系,PyTorch的nn.Embedding模块提供灵活实现,支持参数配置、预训练及变长... 目录一、词嵌入(Word Embedding)简介为什么需要词嵌入?二、PyTorch中的nn.Em

在IntelliJ IDEA中高效运行与调试Spring Boot项目的实战步骤

《在IntelliJIDEA中高效运行与调试SpringBoot项目的实战步骤》本章详解SpringBoot项目导入IntelliJIDEA的流程,教授运行与调试技巧,包括断点设置与变量查看,奠定... 目录引言:为良驹配上好鞍一、为何选择IntelliJ IDEA?二、实战:导入并运行你的第一个项目步骤1

Spring Boot3.0新特性全面解析与应用实战

《SpringBoot3.0新特性全面解析与应用实战》SpringBoot3.0作为Spring生态系统的一个重要里程碑,带来了众多令人兴奋的新特性和改进,本文将深入解析SpringBoot3.0的... 目录核心变化概览Java版本要求提升迁移至Jakarta EE重要新特性详解1. Native Ima

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor

从入门到进阶讲解Python自动化Playwright实战指南

《从入门到进阶讲解Python自动化Playwright实战指南》Playwright是针对Python语言的纯自动化工具,它可以通过单个API自动执行Chromium,Firefox和WebKit... 目录Playwright 简介核心优势安装步骤观点与案例结合Playwright 核心功能从零开始学习

Java docx4j高效处理Word文档的实战指南

《Javadocx4j高效处理Word文档的实战指南》对于需要在Java应用程序中生成、修改或处理Word文档的开发者来说,docx4j是一个强大而专业的选择,下面我们就来看看docx4j的具体使用... 目录引言一、环境准备与基础配置1.1 Maven依赖配置1.2 初始化测试类二、增强版文档操作示例2.