GDPU Android移动应用 Broadcast Receiver

聆听广播,跟着节拍吧。

计时器

新建一个名为PhoneStateMonitor的工程;

实现一个应用运行时长的计时器,并在界面上刷新计数器,要求包括:

(1)在Layout中包含两个TextView控件,横向分布,左边的TextView固定显示文本“运行时长”,右边的TextView显示计时时长(单位:分钟)

(2)通过静态方式注册系统广播android.intent.action.TIME_TICK,执行计时器的刷新。

注,本次可以不用重名原来自带的xml跟main活动,然后记得每题分模块写即可。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="horizontal"android:padding="16dp"android:gravity="center_vertical"><!-- 左侧 TextView 显示 "运行时长" --><TextViewandroid:id="@+id/textViewLabel"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="运行时长"android:textSize="20sp"android:layout_marginEnd="16dp"/><!-- 右侧 TextView 显示计时时长 --><TextViewandroid:id="@+id/textViewTimer"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="0"android:textSize="20sp"android:gravity="end"/></LinearLayout>

这里的Receiver内部类写在主活动里,当然你也可以另外写多一个Receiver文件。 

package com.example.phonestatemonitorimport android.app.Activity
import android.content.BroadcastReceiver
import android.content.Context
import android.content.Intent
import android.content.IntentFilter
import android.os.Bundle
import android.widget.TextViewclass MainActivity : Activity() {// 定义广播接收器,接收系统时间更新广播private lateinit var timeTickReceiver: TimeTickReceiveroverride fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main)// 获取布局中的 TextView 控件val textViewTimer: TextView = findViewById(R.id.textViewTimer)// 创建 TimeTickReceiver 实例并传递 textViewTimertimeTickReceiver = TimeTickReceiver(textViewTimer)// 注册系统广播val intentFilter = IntentFilter()
//        intentFilter.addAction("android.intent.action.TIME_TICK")intentFilter.addAction(Intent.ACTION_TIME_TICK)// 使用系统时间更新广播的正确 actionregisterReceiver(timeTickReceiver, intentFilter)}override fun onDestroy() {super.onDestroy()// 注销广播接收器,避免内存泄漏unregisterReceiver(timeTickReceiver)}// 广播接收器类class TimeTickReceiver(private val textViewTimer: TextView) : BroadcastReceiver() {private var totalMinutes: Int = 0override fun onReceive(context: Context, intent: Intent) {// 更新计时器updateTimer()}private fun updateTimer() {totalMinutes += 1val timeString = String.format("%02d分钟", totalMinutes)// 更新 TextView 显示的计时textViewTimer.text = timeString}}
}
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="com.example.phonestatemonitor"><applicationandroid:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:roundIcon="@mipmap/ic_launcher_round"android:supportsRtl="true"android:theme="@style/Theme.T7"><activityandroid:name=".MainActivity"android:exported="true"><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity></application></manifest>

手机WIFI状态显示

 实现手机WI-FI状态显示:

(1)WI-FI只有“打开”和“关闭”两种状态;

(2)Layout中根据自己的想法设计合理的WI-FI状态显示方式;

(3)注意,要在AndroiManifest.xml添加wifi状态的权限,

(4)设计一个广播接收器来监听广播android.net.wifi.WIFI_STATE_CHANGED

(5)创建一个私有方法wifiStateUpdate(),里面包括:

创建一个wifiManager:

val wifiManager = applicationContext.getSystemService(Context.WIFI_SERVICE) as WifiManager

获取WI-FI的状态:

val wifiState = wifiManager.wifiState

如果wifiState为WifiManager.WIFI_STATE_ENABLED,则显示“打开”,如果为wifiState为WifiManager.WIFI_STATE_DISABLED,则显示“关闭”。

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><androidx.appcompat.widget.Toolbarandroid:id="@+id/toolbar"android:layout_width="match_parent"android:layout_height="?attr/actionBarSize"android:background="?attr/colorPrimary"android:elevation="4dp"android:theme="@style/ThemeOverlay.AppCompat.ActionBar" /><TextViewandroid:id="@+id/statusWifi"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="@string/status_wifi_open"android:layout_gravity="center"android:layout_marginTop="50dp"android:textSize="30sp"android:textColor="#EF9DB9" />
</LinearLayout>

在res的values文件下找到strings.xml

<resources><string name="app_name">T7</string><string name="status_wifi_open">Wifi已打开</string><string name="status_wifi_close">Wifi已关闭</string>
</resources>

在另一个模块或项目的模块,直接用默认的活动写即可。 

import android.app.Activity
import android.content.BroadcastReceiver
import android.content.Context
import android.content.Intent
import android.content.IntentFilter
import android.net.wifi.WifiManager
import android.os.Bundle
import android.util.Log
import android.widget.TextView
import androidx.appcompat.widget.Toolbar
import androidx.appcompat.app.AppCompatActivity
class MainActivity : AppCompatActivity() {// 定义广播接收器,接收 Wi-Fi 状态更新广播private lateinit var wifiReceiver: WifiReceiver// 用于显示 Wi-Fi 状态的 TextView 控件private lateinit var wifiStatus: TextViewprivate lateinit var wifiManager: WifiManageroverride fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main)
//        val toolbar: Toolbar = findViewById(R.id.toolbar)
//        setSupportActionBar(toolbar)// 获取布局中的 TextView 控件wifiStatus = findViewById(R.id.statusWifi)wifiManager = applicationContext.getSystemService(Context.WIFI_SERVICE) as WifiManager// 创建 wifiReceiver 实例wifiReceiver = WifiReceiver(wifiStatus)// 注册 Wi-Fi 状态广播接收器val intentFilter = IntentFilter()intentFilter.addAction(WifiManager.WIFI_STATE_CHANGED_ACTION) // Wi-Fi 状态变化的广播registerReceiver(wifiReceiver, intentFilter)}override fun onDestroy() {super.onDestroy()// 注销广播接收器,避免内存泄漏unregisterReceiver(wifiReceiver)}// 广播接收器类,用于监听 Wi-Fi 状态变化class WifiReceiver(private val statusWifi: TextView) : BroadcastReceiver() {private lateinit var wifiManager: WifiManageroverride fun onReceive(context: Context?, intent: Intent?) {// 获取 WifiManager 实例wifiManager = context?.applicationContext?.getSystemService(Context.WIFI_SERVICE) as WifiManager// 更新 Wifi 状态wifiStateUpdate()}private fun wifiStateUpdate() {// 获取当前的 Wifi 状态val wifiState = wifiManager.wifiStateval context = statusWifi.context// 根据 Wifi 状态更新 UIif (wifiState == WifiManager.WIFI_STATE_ENABLED) {// Wifi 已开启statusWifi.text = context.getString(R.string.status_wifi_open)} else if (wifiState == WifiManager.WIFI_STATE_DISABLED) {// Wifi 已关闭statusWifi.text = context.getString(R.string.status_wifi_close)}statusWifi.invalidate()}}
}

AndroidManifest.xml,注意这里要改一下跟你的项目模块名对上,别直接复制还倒打一耙怪到这来。 

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="com.example.t7" ><!-- Wi-Fi 状态权限 --><uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /><applicationandroid:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:roundIcon="@mipmap/ic_launcher_round"android:supportsRtl="true"android:theme="@style/Theme.T7" ><activityandroid:name=".MainActivity"android:exported="true" ><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity></application></manifest>

打开虚拟手机的设置找到wifi项把它打开关闭,也可以从上面拉下来开启,类似平时用手机打开wifi的,然后观察界面显示。

手机电池电量提醒

 实现手机电池电量提醒

(1)要求能够按百分比显示电量;

(2)监听电量变化的广播

android.intent.action.BATTERY_LOW、android.intent.action.BATTERY_OKAY、android.intent.action.BATTERY_CHANGED三条信息;

(3)正常电量下,显示“正常电量”,同时计算并显示具体电量。

(4)当电量电量低于20%时,用红色字体显示电量,并且显示文本“请及时充电!”

(5)计算电量batteryPct。

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:padding="16dp"><!-- 第一个 TextView: 显示文本1 --><TextViewandroid:id="@+id/textViewText1"android:layout_width="wrap_content"android:layout_height="50sp"android:text="@string/text1"android:textSize="30sp"android:gravity="start"/><!-- 第二个 TextView: 显示电池百分比 --><TextViewandroid:id="@+id/textViewBattery"android:layout_width="wrap_content"android:layout_height="47sp"android:text="@string/battery_percentage"android:textSize="30sp"android:layout_toEndOf="@id/textViewText1"android:layout_marginStart="4dp"android:layout_marginTop="3sp"android:gravity="end" /><!-- 一个黑色横向 View --><Viewandroid:layout_width="match_parent"android:layout_height="2dp"android:layout_below="@id/textViewText1"android:layout_alignParentStart="true"android:background="@color/black" /><!-- 第三个 TextView: 显示电池提示信息 --><TextViewandroid:id="@+id/textViewTips"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="@string/battery_normal_tips"android:textSize="40sp"android:gravity="center"android:layout_below="@id/textViewText1"android:layout_marginTop="20dp" /></RelativeLayout>
<resources><string name="app_name">Pct</string><string name="text1">手机电量:</string><string name="battery_percentage">100%</string><string name="battery_normal_tips">正常电量</string><string name="battery_charge_tips">请及时充电!</string>
</resources>
import android.app.Activity
import android.content.BroadcastReceiver
import android.content.Context
import android.content.Intent
import android.content.IntentFilter
import android.os.Bundle
import android.os.BatteryManager
import android.widget.TextView
import android.widget.Toastclass MainActivity : Activity() {private lateinit var batteryLevel: TextViewprivate lateinit var batteryTips: TextViewprivate lateinit var batteryReceiver: BroadcastReceiveroverride fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main)// 获取布局中的 TextView 控件batteryLevel = findViewById(R.id.textViewBattery)batteryTips = findViewById(R.id.textViewTips)// 创建并注册广播接收器batteryReceiver = BatteryReceiver()val intentFilter = IntentFilter()intentFilter.addAction(Intent.ACTION_BATTERY_CHANGED) // 电池变化intentFilter.addAction(Intent.ACTION_BATTERY_LOW)     // 电池低电量intentFilter.addAction(Intent.ACTION_BATTERY_OKAY)    // 电池恢复正常registerReceiver(batteryReceiver, intentFilter)}override fun onDestroy() {super.onDestroy()// 注销广播接收器unregisterReceiver(batteryReceiver)}// 广播接收器类:处理电池变化的逻辑inner class BatteryReceiver : BroadcastReceiver() {override fun onReceive(context: Context?, intent: Intent?) {intent?.let {when (it.action) {Intent.ACTION_BATTERY_CHANGED -> {val batteryPct:Float? = getBatteryPercentage(it)// 更新电池百分比显示batteryPct?.let { pct ->updateBatteryStatus(pct)}}Intent.ACTION_BATTERY_LOW -> {// 电池电量过低时显示提示信息batteryTips.text = context?.getString(R.string.battery_charge_tips)batteryTips.setTextColor(context?.resources?.getColor(android.R.color.holo_red_dark) ?: 0)}Intent.ACTION_BATTERY_OKAY -> {// 电池恢复正常时显示提示信息batteryTips.text = context?.getString(R.string.battery_normal_tips)batteryTips.setTextColor(context?.resources?.getColor(android.R.color.black) ?: 0)}else -> {}}}}// 获取电池百分比private fun getBatteryPercentage(intent: Intent): Float {val level = intent.getIntExtra(BatteryManager.EXTRA_LEVEL, -1)val scale = intent.getIntExtra(BatteryManager.EXTRA_SCALE, -1)return level * 100 / scale.toFloat()}// 更新电池状态private fun updateBatteryStatus(batteryPct: Float) {batteryLevel.text = "${batteryPct.toInt()}%" // 显示电池百分比if (batteryPct < 20) {batteryTips.text = "请及时充电!"batteryTips.setTextColor(getColor(android.R.color.holo_red_dark))} else {// 电量正常时,显示“正常电量”batteryTips.text = "正常电量"batteryTips.setTextColor(getColor(android.R.color.black))}}}
}
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="com.example.pct"><applicationandroid:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:roundIcon="@mipmap/ic_launcher_round"android:supportsRtl="true"android:theme="@style/Theme.T7"><activityandroid:name=".MainActivity"android:exported="true"><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity></application></manifest>

怎样调节虚拟机的电量观察提示变化,点击这里。

然后滑动滑条即可观察到提示变化。 

 

实验心得

写到困了,却等不到的赞。 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/60102.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据库SQL——什么是实体-联系模型(E-R模型)?

目录 什么是实体-联系模型&#xff1f; 1.实体集 2.联系集 3.映射基数 一对一&#xff08;1:1&#xff09; 一对多&#xff08;1:n&#xff09; 多对一&#xff08;n:1&#xff09; 多对多&#xff08;m:n&#xff09; 全部参与&#xff1a; 4.主码 弱实体集&#xf…

共筑开源技术新篇章 | 2024 CCF中国开源大会盛大开幕

在这个技术革新日新月异的时代&#xff0c;开源精神如同点燃创新火焰的火种&#xff0c;照亮了无数技术探索者的征途。2024年11月9日&#xff0c;备受瞩目的2024 CCF中国开源大会在深圳这座充满活力的创新之城盛大开幕。这场开源领域的顶级盛事&#xff0c;以“湾区聚力 开源启…

[极客大挑战 2019]Secret File 1

[极客大挑战 2019]Secret File 1 审题 看到题目应该是一道简单的按照要求找flag的题目 知识点 跟着题目走 解题 一&#xff0c;查看源码 找到网站进入 点开发现 【注意它说没看清吗】 二&#xff0c;使用BP抓包试试 发现新出现了/action.php 抓到后放到Repeater中响应 得…

初识Electron 进程通信

概述 Electron chromium nodejs native API&#xff0c;也就是将node环境和浏览器环境整合到了一起&#xff0c;这样就构成了桌面端&#xff08;chromium负责渲染、node负责操作系统API等&#xff09; 流程模型 预加载脚本&#xff1a;运行在浏览器环境下&#xff0c;但是…

语义分割实战——基于DeepLabv3+神经网络头发分割系统源码

第一步&#xff1a;准备数据 头发分割数据&#xff0c;总共有1050张图片&#xff0c;里面的像素值为0和1&#xff0c;所以看起来全部是黑的&#xff0c;不影响使用 第二步&#xff1a;搭建模型 DeepLabV3的网络结构如下图所示&#xff0c;主要为Encoder-Decoder结构。其中&am…

c# 开发web服务 webserver

024-11-10<<<<<<<<<<<<<<<<<<<<<<<<<< 开始插件前Cyber_CallWeb acajax_dac_database_viewer 2024-11-10<<<<<<<<<<<<<<<<<<<<…

「C/C++」C/C++ 预处理 之 常用预处理宏

✨博客主页何曾参静谧的博客&#x1f4cc;文章专栏「C/C」C/C程序设计&#x1f4da;全部专栏「VS」Visual Studio「C/C」C/C程序设计「UG/NX」BlockUI集合「Win」Windows程序设计「DSA」数据结构与算法「UG/NX」NX二次开发「QT」QT5程序设计「File」数据文件格式「PK」Parasoli…

Javascript中如何实现函数缓存?函数缓存有哪些应用场景?

#一、是什么 函数缓存&#xff0c;就是将函数运算过的结果进行缓存 本质上就是用空间&#xff08;缓存存储&#xff09;换时间&#xff08;计算过程&#xff09; 常用于缓存数据计算结果和缓存对象 解释 const add (a,b) > ab; const calc memoize(add); // 函数缓存…

Maven的依赖管理、传递、冲突、父子工程的继承和聚合

目录 一、基于IDEA 进行Maven依赖管理 (一)依赖管理概念 (二)Maven工程核心信息配置和解读&#xff08;GAVP&#xff09; (三)Maven工程依赖管理配置 1.依赖管理和依赖添加 2.依赖版本统一提取和维护 (四)依赖范围 (五)Maven工程依赖下载失败错误解决&#xff08;重点…

iOS SmartCodable 替换 HandyJSON 适配记录

前言 HandyJSON群里说建议不要再使用HandyJSON&#xff0c;我最终选择了SmartCodable 来替换&#xff0c;原因如下&#xff1a; 首先按照 SmartCodable 官方教程替换 大概要替换的内容如图&#xff1a; 详细的替换教程请前往&#xff1a;使用SmartCodable 平替 HandyJSON …

1.2 图像处理基本操作

在本实战中&#xff0c;我们将学习如何使用OpenCV进行基本的图像处理操作。首先&#xff0c;我们将通过cv2.imread()函数读取图像&#xff0c;并使用cv2.imshow()在窗口中显示它。接着&#xff0c;我们将探索如何通过cv2.imwrite()保存图像&#xff0c;并设置不同的参数以控制图…

使用Python实现音频降噪

在音频处理领域&#xff0c;背景噪声是一个常见的问题。为了提高音频的质量&#xff0c;我们需要对音频进行降噪处理。本文将介绍如何使用 Python 实现音频降噪。 依赖库安装 在开始之前&#xff0c;我们需要安装以下依赖库&#xff1a; pydub&#xff1a;用于音频文件的读取…

与AMD GPU上的对比语言-图像预训练(CLIP)模型交互

Interacting with Contrastive Language-Image Pre-Training (CLIP) model on AMD GPU — ROCm Blogs 2024年4月16日&#xff0c;由Sean Song撰写. 引言 对比语言-图像预训练&#xff08;CLIP&#xff09;是一种多模态深度学习模型&#xff0c;连接视觉和自然语言。它在Open…

2024年第四届“网鼎杯”网络安全比赛---朱雀组Crypto- WriteUp

2024年第四届“网鼎杯”网络安全比赛---朱雀组Crypto-WriteUp Crypto&#xff1a;Crypto-2&#xff1a;Crypto-3&#xff1a; 前言&#xff1a;本次比赛已经结束&#xff0c;用于赛后复现&#xff0c;欢迎大家交流学习&#xff01; Crypto&#xff1a; Crypto-2&#xff1a; …

下载mysql的jar,添加至jmeter中,编写jdbc协议脚本1106

下载jar包&#xff1a; 步骤1&#xff1a;进入maven仓库官网https://mvnrepository.com/ 步骤2&#xff1a;搜索实际的数据库 步骤3&#xff1a;点击 Mysql connnector/J 步骤5、查看数据库的版本号&#xff0c;选择具体版本&#xff0c;我的是mysql 8.0.16,下图&#xff0c;…

从“点”到“面”,热成像防爆手机如何为安全织就“透视网”?

市场上测温产品让人眼花缭乱&#xff0c;通过调研分析&#xff0c;小编发现测温枪占很高比重。但是&#xff0c;测温枪局限于显示单一数值信息&#xff0c;无法直观地展示物体的整体温度分布情况&#xff0c;而且几乎没有功能拓展能力。以AORO A23为代表的热成像防爆手机改变了…

模型训练中GPU利用率低?

买了块魔改华硕猛禽2080ti&#xff0c;找了下没找到什么测试显存的软件&#xff0c;于是用训练模型来测试魔改后的显存稳定性&#xff0c;因为模型训练器没有资源监测&#xff0c;于是用了Windows任务管理器来查看显卡使用情况&#xff0c;却发现GPU的利用率怎么这么低&#xf…

开源代码管理平台Gitlab如何本地化部署并实现公网环境远程访问私有仓库

文章目录 前言1. 下载Gitlab2. 安装Gitlab3. 启动Gitlab4. 安装cpolar5. 创建隧道配置访问地址6. 固定GitLab访问地址6.1 保留二级子域名6.2 配置二级子域名 7. 测试访问二级子域名 前言 本文主要介绍如何在Linux CentOS8 中搭建GitLab私有仓库并且结合内网穿透工具实现在公网…

在vue3的vite网络请求报错 [vite] http proxy error:

在开发的过程中 代理proxy报错: [vite] http proxy error: /ranking/hostRank?dateType1 Error: connect ETIMEDOUT 43.xxx.xxx.xxx:443 网络请求是http的: // vite.config.ts import { Agent } from node:http;server: {host: 0.0.0.0,port: port,open: true,https: false,…

云计算 esxi 如何 部署iscsi ,配合windows 2012 iscsi 存储

1 windows 2012 如何创建iscsi 存储服务器&#xff0c;看前面的文章 iscsi 服务上的地址 192.168.10.196 192.168.10.196 2 如何在esxi 创建iscsi 注意地址是192.168.10.196 这是服务器的地址 很明显这是我们esxi 主机上发现的iscsi 磁盘 、