17

過去 2 日間、インターネットで検索していましたが、役立つチュートリアルが見つかりませんでした。サービスを作成し、サービスの開始時にステータス バーに通知を送信しています。通知を表示した後にそのサービスを停止し、5 分後に再び開始するようにします。可能な場合はお知らせください。役立つチュートリアルがあれば教えてください。TimerTaskとを聞いて、AlarmManagerそれらも使用しようとしましたが、望ましい結果を得ることができませんでした。

編集:アプリケーションが実行されていない場合でも、5 分ごとにサービスを開始する必要があります。

4

3 に答える 3

25

TimerTaskこれはアプリケーションが継続的に実行されているかどうかに依存するため、 a は使用しません。AlarmManager実装により、アプリケーションが実行間で強制終了されても安全になります。

使用しようとしAlarmManagerたが、望ましい結果が得られなかったと述べることは、それを正しく行う方法を誰にも教えていないという点で、役に立ちません。何が起こったのかを表現する方がはるかに便利です。

http://web.archive.org/web/20170713001201/http://code4reference.com/2012/07/tutorial-on-android-alarmmanager/には、 に関する有用なチュートリアルと思われるものが含まれていますAlarmManager。重要な点は次のとおりです。

1) アラームのIntent有効期限が切れると、アラームが発火します。Intentどのようなものをどのように実装するかは、あなた次第です。私が提供したリンクには、BroadcastReceiver に基づく完全な例があります。

2) 次のような例でアラームをインストールできます。

public void setOnetimeTimer(Context context) {
    AlarmManager am=(AlarmManager)context.getSystemService(Context.ALARM_SERVICE);
    Intent intent = new Intent(context, AlarmManagerBroadcastReceiver.class);
    intent.putExtra(ONE_TIME, Boolean.TRUE);
    PendingIntent pi = PendingIntent.getBroadcast(context, 0, intent, 0);
    am.set(AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + (1000 * 60 * 5), pi);
}
于 2012-12-11T12:49:28.823 に答える
13

以下に、サービスを開始するための MainActivity.java、5 分間のサービスを提供する 2 番目のファイル MyService.java、3 番目のファイルであるマニフェスト ファイルの 3 つのファイルを用意しました。

MainActivity.java

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        startService(new Intent(this, MyService.class)); //start service which is MyService.java
    }
}

MyService.java

 public class MyService extends Service {

    public static final int notify = 300000;  //interval between two services(Here Service run every 5 Minute)
    private Handler mHandler = new Handler();   //run on another Thread to avoid crash
    private Timer mTimer = null;    //timer handling

    @Override
    public IBinder onBind(Intent intent) {
        throw new UnsupportedOperationException("Not yet implemented");
    }

    @Override
    public void onCreate() {
        if (mTimer != null) // Cancel if already existed
            mTimer.cancel();
        else
            mTimer = new Timer();   //recreate new
        mTimer.scheduleAtFixedRate(new TimeDisplay(), 0, notify);   //Schedule task
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        mTimer.cancel();    //For Cancel Timer
        Toast.makeText(this, "Service is Destroyed", Toast.LENGTH_SHORT).show();
    }

    //class TimeDisplay for handling task
    class TimeDisplay extends TimerTask {
        @Override
        public void run() {
            // run on another thread
            mHandler.post(new Runnable() {
                @Override
                public void run() {
                    // display toast
                    Toast.makeText(MyService.this, "Service is running", Toast.LENGTH_SHORT).show();
                }
            });
        }
    }
}

AndroidManifest.xml

  <service android:name=".MyService" android:enabled="true" android:exported="true"></service>
于 2016-12-28T11:05:06.927 に答える
-4

Timerオブジェクトを作成し、TimerTask実行したいコードを実行する を与えます。

Timer timer = new Timer ();
TimerTask hourlyTask = new TimerTask () {
    @Override
    public void run () {
        // your code here...
    }
};

// schedule the task to run starting now and then every hour...
timer.schedule (hourlyTask, 0l, 1000*60*60);   // 1000*10*60 every 10 minut

Timer オブジェクトを使用する利点は、それぞれが独自のタイミング、遅延などを持つ複数の TimerTask オブジェクトを処理できることです。クラスとして宣言することにより、Timer オブジェクトを保持している限り、タイマーを開始および停止することもできます。変数か何か。

于 2012-12-11T12:42:34.373 に答える