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());
 }

你可能感兴趣的:(Android,android)