1

連続実行のためにTimerTaskをスケジュールするタイマーを作成しようとしています。何回動作するかわかりません。ユーザーがクリックするとタイマーが停止し、別のユーザーがクリックするとタイマーが再び実行されます。停止するまですべてが機能します。スケジュールを変更すると、タイマーがキャンセルされたか、すでにスケジュールされているという例外が発生します。どうすれば停止して再度実行できますか?考えられることはすべて試しましたが、まだ機能していません。

これは私が試している最新のコードです:

        Timer myTimer;

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    cameraTimedTask = new camera(this);

        myTimer = new Timer("cameraTimer");

        Button b=(Button)findViewById(R.id.b);
        b.setOnClickListener(new OnClickListener(){
            public void onClick(View v) {
                myTimer.purge();
                myTimer.scheduleAtFixedRate(cameraTimedTask, 1000, 5000);
            }
        });

        Button bb=(Button)findViewById(R.id.button);
        bb.setOnClickListener(new OnClickListener(){
            public void onClick(View v) {
                myTimer.cancel();
                myTimer.purge();
                myTimer = null;
                myTimer = new Timer("camerasTimer");
                Log.i("Check","[main]"+" timer stopped");
            }
        });

    }
4

3 に答える 3

2

TimerTask を再スケジュールすることはできません。毎回新しいものが必要です。さらに、Android では Handlers と postDelayed を使用することをお勧めします。

于 2012-05-02T15:51:51.257 に答える
1

私の意見では、タイマーの代わりにカウントダウンタイマーを使用してみてください

クイック使用:

 new CountDownTimer(30000, 1000) {

 public void onTick(long millisUntilFinished) {
     mTextField.setText("seconds remaining: " + millisUntilFinished / 1000);
 }

 public void onFinish() {
     mTextField.setText("done!");
 }
}.start();

または、より複雑なものが必要な場合:

 public class MyCountDownTimer extends CountDownTimer {
   public MyCountDownTimer(long startTime, long interval) {
    super(startTime, interval);

  }
  @Override
   public void onFinish() {
   text.setText("Time's up!");
  }

  @Override
 public void onTick(long millisUntilFinished) {
 text.setText("" + millisUntilFinished / 1000);

 }

}
于 2014-03-13T09:32:52.457 に答える
0

あなたにとって完璧な解決策は、ハンドラーを使用することです

private Runnable runnable;
private Handler handler;

@Override
protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   handler = new Handler();
   runnable = new Runnable() {

    @Override
    public void run() {
          // run code delayed code in here once
    }
};

次に、複数回繰り返すコードで、投稿されたコールバックを削除してから、実行のために再スケジュールする必要があります。

handler.removeCallbacks(runnable);
handler.postDelayed(runnable, 200);
于 2014-03-13T09:28:19.817 に答える