Обновление виджетов Android

на основе в этом уроке Я создал виджет, который должен показывать время. Способ java работает, но способ обслуживания-нет.

HelloWidget.java:

public class HelloWidget extends AppWidgetProvider {

    @Override
    public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {

        Intent intent = new Intent(context, UpdateService.class);
        context.startService(intent);
    }
}

UpdateService.java:

public final class UpdateService extends Service {
    @Override
    public void onStart(Intent intent, int startId) {
        RemoteViews updateViews = new RemoteViews(this.getPackageName(), R.layout.main);

        Date date = new Date();
        java.text.DateFormat format = SimpleDateFormat.getTimeInstance(
                SimpleDateFormat.MEDIUM, Locale.getDefault());
                updateViews.setTextViewText(R.id.widget_textview, "Current Time " + format.format(date));

        ComponentName thisWidget = new ComponentName(this, HelloWidget.class);
        AppWidgetManager manager = AppWidgetManager.getInstance(this);
        manager.updateAppWidget(thisWidget, updateViews);
    }

    @Override
    public IBinder onBind(Intent intent) {
        // TODO Auto-generated method stub
        return null;
    }
}

на hello_widget_provider.в XML эта строка: android:updatePeriodMillis="1000"

:

виджет показывает текущее время, но он не обновляется (java-путь есть.)

моя главная цель-обновлять виджет, например, в 18: 56 каждый день. Idk, если это хороший способ, но я попытался изменить метод onUpdate, как показано ниже, но у него есть проблема с ALARM_SERVICE: ALARM_SERVICE не может быть разрешен переменной

public class HelloWidget extends AppWidgetProvider {

    @Override
    public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {

        AlarmManager alarmManager;
        Intent intent = new Intent(context, AlarmReceiver.class);
        PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0,
          intent, PendingIntent.FLAG_UPDATE_CURRENT);
        alarmManager = (AlarmManager) getSystemService(ALARM_SERVICE);
        Calendar cal = Calendar.getInstance();
        cal.set(Calendar.HOUR_OF_DAY, 18);
        cal.set(Calendar.MINUTE, 56);
        cal.set(Calendar.SECOND, 0);
        cal.set(Calendar.MILLISECOND, 0);
        alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, cal.getTimeInMillis(), 86400, pendingIntent);
   }
}

любая помощь приветствуется.

2 ответов


оглядываясь назад, когда я задал этот вопрос, я понимаю, сколько я узнал за последние 1,5 года.

Так как я работаю с виджетом в последние две недели и я только что нашел этот вопрос без ответа, я решил исправить это. Надеюсь, это поможет другим.

AppWidgetProvider должен выглядеть следующим образом:

public class MyWidget extends AppWidgetProvider {

    public static String ACTION_WIDGET_CONFIGURE = "ConfigureWidget";
    public static String ACTION_WIDGET_RECEIVER = "ActionReceiverWidget";
    private PendingIntent service = null;  

       @Override
       public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {


           final AlarmManager m = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);

           final Calendar TIME = Calendar.getInstance();
           TIME.set(Calendar.MINUTE, 0);
           TIME.set(Calendar.SECOND, 0);
           TIME.set(Calendar.MILLISECOND, 0);

           final Intent i = new Intent(context, MyService.class);

           if (service == null)
           {
               service = PendingIntent.getService(context, 0, i, PendingIntent.FLAG_CANCEL_CURRENT);
           }

           m.setRepeating(AlarmManager.RTC, TIME.getTime().getTime(), 1000 * 1, service);

    }

      @Override
       public void onDeleted(Context context, int[] appWidgetIds) {
               super.onDeleted(context, appWidgetIds);
       }

       @Override
       public void onDisabled(Context context) {
               super.onDisabled(context);

               final AlarmManager m = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);  
               if (service != null)
               {
                   m.cancel(service);
               }
       }

       @Override
       public void onEnabled(Context context) {
               super.onEnabled(context);
       }

       @Override
       public void onReceive(Context context, Intent intent) {

         super.onReceive(context, intent);

       }

}

Сервис:

public class MyService extends Service
{
    @Override
    public void onCreate()
    {
        super.onCreate();
    }

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

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

    private void buildUpdate()
    {
        String lastUpdated = DateFormat.format("hh:mm:ss", new Date()).toString();

        RemoteViews view = new RemoteViews(getPackageName(), R.layout.widget_layout);
        view.setTextViewText(R.id.btn_widget, lastUpdated);

        ComponentName thisWidget = new ComponentName(this, MyWidget.class);
        AppWidgetManager manager = AppWidgetManager.getInstance(this);
        manager.updateAppWidget(thisWidget, view);
    }

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

также, зарегистрируйте поставщика и обслуживание в Манифест:

<receiver android:name="MyWidget" android:label="Tutorial_Widget 1x1">
            <intent-filter>
                <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
                <action android:name="com.something.MyWidget.ACTION_WIDGET_RECEIVER"/>
            </intent-filter>    
            <meta-data android:name="android.appwidget.provider" android:resource="@xml/widget_info"/>
        </receiver>

         <service android:enabled="true" android:name=".MyService" />

ALARM_SERVICE-это статическое поле класса контекста. Такой тип связи.ALARM_SERVICE или использовать статический импорт.

помните, что при установке значения атрибута updatePeriodMillis не гарантируется, что метод onUpdate будет вызываться именно с этим периодом.