1

我正在尝试使用一个 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");
            }
        });

    }
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

对您来说完美的解决方案是使用 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);
于 2014-03-13T09:28:19.817 回答