Android 桌面微件在第一次开机后延迟显示

观看视频里的看开机后11:03的时候就界面亮屏
从log中看: 10-19 11:04:07 才开始启动 APP

10-19 11:04:07.472 I/ActivityManager( 954): Start proc 9004:com.xxx.xxx/u0a49 for broadcast
{com.xxx.xxx/com.xxx.xxx.widget.WeatherWidget}

从启动APP 到 APP Widget 完成各种初始化并最终显示用了 最后一个更新时间

10-19 11:04:09.319 D/WeatherWidget( 9004): action:android.appwidget.action.APPWIDGET_UPDATE

大概耗时2S做哟的时间。所以大量时间耗费在启动app之前
【问题根因】进程启动慢导致,具体定位是由于
【act=android.appwidget.action.APPWIDGET_UPDATE】
广播拉起慢导致,通过dumpsys activity broadcasts,也确实看到了此action属于后台广播。
【解决方案】将广播APPWIDGET_UPDATE提升至前台广播。
/framework/base/services/appwidget/java/com/adnroid/server/appwidget/AppWidgetServiceImpl.java

private void sendUpdateIntentLocked(Provider provider, int[] appWidgetIds) {
 Intent intent = new Intent(AppWidgetManager.ACTION_APPWIDGET_UPDATE);
 intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, appWidgetIds);
 intent.setComponent(provider.id.componentName);
 intent.addFlags(Intent.FLAG_RECEIVER_FOREGROUND);//将APPWIDGET_UPDATE提升至前台广播。
 sendBroadcastAsUser(intent, provider.id.getProfile());
 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值