在Android中重新安排计时器

时间:2012-05-02 15:47:56

标签: java android timer

我正在尝试让Timer安排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");
            }
        });

    }

3 个答案:

答案 0 :(得分:2)

您无法重新安排TimerTask。你每次都需要一个新的。此外,建议在android中使用Handler和postDelayed。

答案 1 :(得分: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);

 }

}

答案 2 :(得分:0)

完美的解决方案是使用Handler

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);