2016-07-15 30 views
0

我有一個計劃的計時器 -mHandler的handleMessage有時更新錯誤的TextView

public void startTimer(long delay_minutes) { 
    final long delay = delay_minutes; 
    delay_countup = (double) delay; 

    //Start the scheduled time 
    departuretimer = new Timer(); 
    departuretimer.scheduleAtFixedRate(new TimerTask() { 
     public void run() { 
      countup = 0.0 + delay_countup; 
      Log.d("hi","Values 0" + delay_countup + countup); 
      mHandler.obtainMessage(1).sendToTarget(); 
      delay_countup = delay_countup + 0.5; 
      Log.d("hi","Values 1" + delay_countup); 
     } 
    }, 0, 30000); 
} 

public Handler mHandler = new Handler() { 
     public void handleMessage(Message msg) { 
      Log.d("hi","Values 3" + countup); 
      delay_time.setText(String.valueOf(countup) + "min"); 
      rootView.invalidate(); 
     } 
    }; 

日誌總是顯示正確的價值觀,但在UI中有時出現了問題。問題是,例如 -

delay_countup = 50.0 
countup = 50.0 
Textview updates as 50.0 //This is correct 

Now, 
delay_countup = 50.5 
countup = 50.5 
Textview updates as 0.5 //This is incorrect. I need 50.5 

有時會發生這種情況。爲什麼是這樣?

編輯

在處理剛加入日誌太...

Values 0 = 34.5 34.5 
Values 3 = 0.5 
+0

嘗試'delay_time.setText(countup +「min」);'在你的'mHandler'中 –

+0

好吧,但這將如何影響?是String.valueOf導致問題? – Mark023

+0

我不知道我只給了建議。它有效嗎? –

回答

1

嘗試這種方式,改變你的mHandler等作爲,

public Handler mHandler = new Handler() { 
    public void handleMessage(Message msg) { 

    String result = (String)msg.obj; 

     delay_time.setText(result + "min"); 
     rootView.invalidate(); 
    } 
}; 

而不是mHandler.obtainMessage(1).sendToTarget();使用,

Message message = mHandler.obtainMessage(); 
message.obj = countup; 
mHandler.sendMessage(message); 

這可能會幫助你。

+0

結果的值爲空 – Mark023

+0

對不起,我忘記了一些代碼,看到編輯答案 –

+0

應用程序正在崩潰...我認爲有些東西是空的。這是處理程序的問題嗎? – Mark023