背景
项目中有时需要在安卓桌面添加widget,方便用户查看或做一些操作.
Demo实现效果图用于实现一个显示日期的widget
class TimerService : Service() {
private lateinit var rv: RemoteViews
private lateinit var manager: AppWidgetManager
// 定义定时器
private lateinit var timer: Timer
// 定义格式化日期时间
@SuppressLint("SimpleDateFormat")
private val sdf = SimpleDateFormat("HH : mm-MM / dd E")
override fun onCreate() {
super.onCreate()
timer = Timer()
timer.schedule(object : TimerTask() {
override fun run() {
updateViews()
}
}, 0, 1000)
}
private fun updateViews() {
rv = RemoteViews(packageName, R.layout.time_widget)
val cn = ComponentName(applicationContext, WidgetProvider::class.java)
manager = AppWidgetManager.getInstance(applicationContext)
val str = sdf.format(Date())
val timeStr = str.substring(0, 7)
rv.setTextViewText(R.id.timeTv, timeStr)
manager.updateAppWidget(cn, rv)
}
override fun onDestroy() {
super.onDestroy()
timer.cancel()
}
override fun onBind(arg0: Intent): IBinder? {
return null
}
}
class WidgetProvider : AppWidgetProvider() {
override fun onReceive(context: Context, intent: Intent) {
// 接收开机和启动程序时候的广播时执行
super.onReceive(context, intent)
context.startService(Intent(context, TimerService::class.java))
}
override fun onEnabled(context: Context) {
// Widget添加到屏幕时执行
super.onEnabled(context)
context.startService(Intent(context, TimerService::class.java))
}
override fun onDisabled(context: Context) {
// 最后一次Widget从屏幕移除时执行
super.onDisabled(context)
context.stopService(Intent(context, TimerService::class.java))
}
}
5. 运行安装app后,在手机上添加桌面控件
##6. FAQ 一定要保持app是运行的,否则widget就不会更新了.
完整代码https://gitee.com/cxyzy1/desktopWidgetDemo