0

ここで簡単な時計ウィジェットを作成するのは興味深いです。そして、それを行うためのベストプラクティスは何だろうか?ほとんどの場合、正常に動作しますが、時計ウィジェットが遅れていると言う人もいます。実際の時間は午前10時ですが、ウィジェットにはおそらく午前9時48分が表示されます。

マニフェストにこれがあります

    <receiver
        android:name="my.package.name.MyClock"
        android:label="@string/widget_name">

        <intent-filter>
            <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
        </intent-filter>

        <meta-data
            android:name="android.appwidget.provider"
            android:resource="@xml/my_clock" />
    </receiver>


    <service
        android:name="MyClock$UpdateService"
        android:label="UpdateService" >
        <intent-filter>
            <action android:name="my.package.name.UPDATE" />
        </intent-filter>             
    </service>

そしてこれは私のメインのJavaクラスです

パブリッククラスMyClockはAppWidgetProviderを拡張します{

@Override
public void onDisabled(Context context) {
    super.onDisabled(context);
    context.stopService(new Intent(context, UpdateService.class));
}

@Override
public void onEnabled(Context context) {
    super.onEnabled(context);
    context.startService(new Intent(UpdateService.ACTION_UPDATE));
}    

@Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
    super.onUpdate(context, appWidgetManager, appWidgetIds);
    context.startService(new Intent(UpdateService.ACTION_UPDATE));
} 

public static final class UpdateService extends Service {
    static final String ACTION_UPDATE = "my.package.name.UPDATE";

    private final static IntentFilter sIntentFilter;

    private String mMinuteFormat;
    private String mHourFormat;

    private Calendar mCalendar;

    static {
        sIntentFilter = new IntentFilter();
        sIntentFilter.addAction(Intent.ACTION_TIME_TICK);
        sIntentFilter.addAction(Intent.ACTION_TIMEZONE_CHANGED);
        sIntentFilter.addAction(Intent.ACTION_TIME_CHANGED);
    }


    @Override
    public void onCreate() {
        super.onCreate();
        reinit();
        registerReceiver(mTimeChangedReceiver, sIntentFilter);
    }

  @Override
    public void onDestroy() {
        super.onDestroy();
        unregisterReceiver(mTimeChangedReceiver);
    }

    @Override
    public void onStart(Intent intent, int startId) {
        super.onStart(intent, startId);
        reinit();
        update();
    }

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

    private void update() {
        mCalendar.setTimeInMillis(System.currentTimeMillis());
        final CharSequence minute = DateFormat.format(mMinuteFormat, mCalendar);
        final CharSequence hour = DateFormat.format(mHourFormat, mCalendar);

        RemoteViews views = null;             views = new RemoteViews(getPackageName(), R.layout.main);
        views.setTextViewText(R.id.HOUR, hour);
        views.setTextViewText(R.id.MINUTE, minute);                   

        //Refresh the widget
        ComponentName widget = new ComponentName(this, MyClock.class);
        AppWidgetManager manager = AppWidgetManager.getInstance(this);
        manager.updateAppWidget(widget, views);          
    }    

    private void reinit() {
        mHourFormat = "hh";
        mMinuteFormat = "mm";            
    }

    private final BroadcastReceiver mTimeChangedReceiver = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {
            final String action = intent.getAction();

            if (action.equals(Intent.ACTION_TIME_CHANGED) ||
                action.equals(Intent.ACTION_TIMEZONE_CHANGED))
            {
                reinit();

            }

            update();

        }
    };

}     }

私は何が欠けていますか?ウィジェットが遅れるのはなぜですか?ここで問題を見つけるのを手伝ってくれませんか。そして、私は正しいアプローチをしていますか?時計ウィジェットを毎分更新するためにAlarmManagerではなくサービスを使用していますか?

よろしく

4

1 に答える 1

0

この問題につながる可能性のある非常に多くの理由がありますが、おそらく、サービスがシステムによって強制終了されます。バックグラウンドサービスがシステムによって強制終了されるのを防ぐ方法はありません。ほとんどの場合、バックグラウンドサービスを安全にするだけですが、通知アイコンはユーザーにとって非常に煩わしいものです。

使用するのが最善だと思いますAlarmManager。最近、この手法を使用して時計ウィジェットも更新しました。AlarmManagerはブロードキャストを行うため、アプリケーションが強制終了されても、送信する前に再作成されます。

于 2012-05-27T00:30:56.703 に答える