桌面小部件开发
AppWidgetProvider是android提供实现桌面小部件的类,本质是一个广播,即BroadcastReceiver。是继承关系
开发步骤:
1.在res/layout/下新建一个XML文件,命令为widget.xml,名称和内容可以自定义
<?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="vertical"> <ImageView android:id="@+id/imageView1" android:layout_width="wrap_content" android:layout_height="warp_content" android:src="@drawable/icon1"/> </LinearLayout>
2.在res/xml/下新建appwidget_provider_info.xml,名称随意
<?xml version="1.0" encoding="utf-8"?> <appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android" android:initiaLayout="@layout/widget" android:minHeight="84dp" android:minWidth="84dp" android:updatePeriodMillis="86400000"> </appwidget-provider>
initialLayout--初始化布局
updatePeriodMillis--自动更新周期
3.继承AppWidgetProvider的实现类
桌面小部件不管是初始化界面还是后续的更新界面都必须使用RemoteViews来完成
4.在AndroidManifest.xml中声明
<receiver android:name=".MyAppWidgetProvider"> <meta-data android:name="android.appwidget.provider" android:resource="@xml/appwidget_provider_info"> </meta-data> <intent-filter> <action android:name="com.ryg.chapter_5.action.CLICK"/> <action android:name="android.appwidget.action.APPWIDGET_UPDATE"/> </intent-filter> </receiver>
第一个Action用于识别小部件的单机行为
第二个Action则作为小部件的标识而必须存在
AppWidgetProvider的常用方法
onEnable:当该窗口小部件第一次添加到桌面时调用该方法,可添加多次但只是在第一次调用
onUpdate:小部件被添加时或者每次小部件更新时都会调用一次该方法,小部件的更新时机由updatePeriodMillis来指定,每个周期小部件都会自动更新一次
onDeleted:每删除一次桌面小部件就调用一次
onDisabled:当最后一个该类型的桌面小部件被删除时调用该方法,注意是最后一个
onReceive:广播的内置方法,用于分发具体的事件给其他方法
标签:
桌面小部件
, AppWidgetProvider
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现