ACTION_BATTERY_CHANGED срабатывает как сумасшедший

Хорошо, я работаю над AppWidget, который проверяет уровень заряда батареи и отображает его в TextView. Мой код выглядит так:

public class BattWidget extends AppWidgetProvider {

private RemoteViews views = new RemoteViews("com.nickavv.cleanwidgets", R.layout.battlayout);

@Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager, int appWidgetIds[]) {
    final int N = appWidgetIds.length;
    context.getApplicationContext().registerReceiver(this,new IntentFilter(Intent.ACTION_BATTERY_CHANGED));
    for (int i = 0; i < N; i++) {
        int appWidgetId = appWidgetIds[i];
        appWidgetManager.updateAppWidget(appWidgetId, views);
    }
}

@Override
public void onReceive(Context context, Intent intent) {
    super.onReceive(context, intent);
    Log.d("onReceive", "Received intent " + intent);
    if (intent.getAction().equals(Intent.ACTION_BATTERY_CHANGED)) {
        Integer level = intent.getIntExtra("level", -1);
        views.setTextViewText(R.id.batteryText, level+"%");
        AppWidgetManager myAWM = AppWidgetManager.getInstance(context);
        ComponentName cn = new ComponentName(context, AirWidget.class);
        onUpdate(context, myAWM, myAWM.getAppWidgetIds(cn));
    }
}
}

И меня это беспокоит, потому что, как только я перетаскиваю виджет на рабочий стол, он начинает запускать около 100 из этих вызовов журнала в секунду, говоря, что он получает ACTION_BATTERY_CHANGED. Разве это не должно транслироваться только на каждый процент уменьшения? Это фактически привело к зависанию всего моего лаунчера, мне пришлось удалить его. Это не может быть правдой.

12
задан Nick 2 October 2011 в 06:04
поделиться