我制作了一个可运行的秒表,它可以正常工作并在大多数情况下正确更新时间。但有时,当我切换到另一个 fragment 然后切换回来时,它会运行随机的秒数(从 2 到 15 秒),然后停止。处理程序仍在运行,但文本并未更新。当我再次切换 fragment 时,它会跳到正确的时间,然后恢复滴答作响。这很奇怪,因为它并不是每次我切换 fragment 时都会这样做,但它经常发生。
//code in fragment 1 class
start.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (!MainActivity.timeOn && spinner.getSelectedItem()!=null){
MainActivity.timeOn=true;
if(MainActivity.timeOn) {
MainActivity.paused = false;
MainActivity.stopTime=false;
MainActivity.StartTime = SystemClock.uptimeMillis();
MainActivity.handler.postDelayed(MainActivity.runnable, 0);
}
}}
});
//code in main Activity class
public static Runnable runnable = new Runnable() {
public void run() {
MillisecondTime = SystemClock.uptimeMillis() - StartTime;
UpdateTime = TimeBuff + MillisecondTime;
Seconds = (int) (UpdateTime / 1000);
Minutes =1 +( Seconds / 60);
Hours = Minutes / 60;
Seconds = Seconds % 60;
MilliSeconds = (int) (UpdateTime % 1000);
minuteSum = (Hours * 60) + Minutes;
minuteSumDaily = (Hours * 60) + Minutes;
textView.setText("" + Hours + ":"
+ String.format("%02d", Minutes) + ":"
+ String.format("%02d", Seconds));
handler.postDelayed(this, 0);
}
};
最佳答案
要回答您的问题,请将处理程序回调移至服务。即使您的用户离开您的应用程序去写短信、电子邮件或打电话,这也将保持准确的时间。
无论您尝试连续运行 Runnable,您只需要每秒运行一次(例如 handler.postDelayed(this, 1000);
),但硬编码 1000
毫秒会在每次执行时引入一个小错误。您可以编写一种方法来检查偏移量并进行相应调整...但是类 Chronometer和 CountDownTimer方便地已经为您做到了这一点。您应该切换到使用其中之一或复制它们的回调方法。
(是的,CountDownTimer 的计数方向错误,但只是颠倒了数学运算。)
最后,查看 DateUtils.formatElapsedTime() 。它需要几毫秒并输出特定于区域设置的“HH:mm:ss”。
关于java - 处理程序随机停止更新 setText,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48412174/