2

AlarmManagerを使用して毎秒更新しようとしている、単なるテキストビューのウィジェットがあります。アプリを実行すると、Log.d("test", "hello1") が LogCat に表示されますが、Log.d("test", "service") は表示されないため、プログラムが表示されません。 MyService クラスに到達することさえあります。

助けていただければ幸いです。

ありがとうございました。

ここに私の AppWidgetProvider クラスがあります:

public class NetworkSpeedWidget extends AppWidgetProvider {

private PendingIntent service = null; 

@Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager,
        int[] appWidgetIds) {
    Log.d("test", "hello");
    super.onUpdate(context, appWidgetManager, appWidgetIds);
    final AlarmManager m = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE); 
    final Intent i = new Intent(context, MyService.class);
    if (service == null)
    {
        service = PendingIntent.getService(context, 0, i, PendingIntent.FLAG_CANCEL_CURRENT);
    }
    Log.d("test", "hello1");
    m.setRepeating(AlarmManager.RTC, System.currentTimeMillis(),1000,service);

}

}

ここに私の MyService クラスがあります:

public class MyService extends Service{
@Override
public void onCreate()
{
    Log.d("test", "service");
    super.onCreate();
}

@Override
public int onStartCommand(Intent intent, int flags, int startId)
{
    buildUpdate();

    return super.onStartCommand(intent, flags, startId);
}

private void buildUpdate()
{


    MainActivity object = new MainActivity();
    String objectString = object.getMegaBitsPerSecondString();

    AppWidgetManager manager = AppWidgetManager.getInstance(this);
    ComponentName thisWidget = new ComponentName(this, NetworkSpeedWidget.class);
    int[]ids = manager.getAppWidgetIds(thisWidget);
    final int N = ids.length;
    for (int i = 0; i < N; i++){
        int awID = ids[i];
        RemoteViews v = new RemoteViews(getPackageName(), R.layout.widget);
        v.setTextViewText(R.id.widgetTextView,objectString);            
        manager.updateAppWidget(awID, v);
    }
}

@Override
public IBinder onBind(Intent intent)
{
    return null;
}
}
4

1 に答える 1