2012-05-16 83 views
1

我必须计算以小时,分钟和秒为单位的时差,并在每秒之后更新我启动活动的时间。我正在使用此代码。计算当前时间和未来时间之间的时差,每秒后

   private Handler handler=new Handler() ; 
private Runnable updateTimeTask = new Runnable() { 
    @Override 
    public void run() { 

      updateTime(); 
      //handler.postDelayed(updateTimeTask, 1000); 

    } 
    };   @Override 
protected void onResume() { 
    super.onResume(); 



    int delay = 1000; // delay for 1 sec. 

    int period = 1000; // repeat every 4 sec. 

    Timer timer = new Timer(); 

    timer.scheduleAtFixedRate(new TimerTask() { 

    public void run() { 

     handler.post(updateTimeTask); 

    } 

    }, delay, period);   }   
     private void updateTime() { 

    final TextView time = (TextView) findViewById(R.id.txtViewTime); 
    final TextView date = (TextView) findViewById(R.id.txtViewAlarmDesc); 


    pref = new Prefs(this); 
    String goal_dateTime= pref.getValue("first_goal_dateTime", ""); 

    Date d1 = Utils.strToDate(goal_dateTime); 


    Calendar cal = Calendar.getInstance(); 
    if(d1!=null && d1.after(new Date())) 
    { 
    cal.setTime(d1); 
    } 
    Date cur = new Date(); 
    Calendar cal_cur = Calendar.getInstance(); 
    cal_cur.setTime(cur); 


    final SimpleDateFormat formatterTime = new SimpleDateFormat("H:mm"); 

     long milliseconds1 = cal.getTimeInMillis(); 
     long milliseconds2 = cal_cur.getTimeInMillis(); 
     long diff = milliseconds1 - milliseconds2; 
     long diffSeconds = diff/1000; 
     long diffMinutes = diff/(60 * 1000); 
     long diffHours = diff/(60 * 60 * 1000); 
     long diffDays = diff/(24 * 60 * 60 * 1000); 


     time.setText(diffHours + " : " + diffMinutes+" : "+diffSeconds); 
     date.setText(String.valueOf(diffDays+" days left to complete goal")); 


} 

但是,当我第一次开始的活动,它工作正常,当我开始从它的另一个活动,并再次到它,应用程序只是挂起,出现黑屏,并且多少时间之后它给我的错误像ANR,keydispatchtimeout。

我已经尝试了几种解决方案,如在一个单独的线程中调用我的录入(),但它给了我一个错误,“只有创建视图层次可以触摸其观点原来的线程。”

任何形式的帮助提前将不胜感激。非常感谢。

问候, Munazzaķ

回答

0

我怀疑你的问题可能当你离开活动时,你并没有删除你的回调。我以稍微不同的方式使用postDelayed而不是scheduleAtFixedRate执行相同的事情,如下所示:

private Handler h = new Handler(); 
    private static final long TIME_EVERY_SECOND = 1000; 

    private Runnable onEverySecond = new Runnable() { 
      public void run() { 
       updateTime(); 
       h.postDelayed(onEverySecond, TIME_EVERY_SECOND); 
      } 
     }; 

     @Override 
     public void onPause() { 
      super.onPause(); 

      if (h != null) { 
       h.removeCallbacks(onEverySecond); 
      } 
     } 

     @Override 
     public void onResume() { 
      super.onResume(); 
      h.postDelayed(onEverySecond, TIME_EVERY_SECOND); 
     } 
+0

非常感谢Damian,我的问题已解决。自从多日以来,我一直陷于困境非常感谢你。 – Munazza

0

您应该使用runOnUiThread更新您的看法。

+0

非常感谢您的回复Simon。 我试图使用runOnUiThread来运行它,它没有给我ANR Keydispatchtimeout,但它仍然太慢,并且出现黑屏,并且在Logcat中有如下消息。 05-17 00:32:40.573:W/ActivityManager(61):启动超时已过,放弃唤醒锁! HistoryRecord的活动空闲超时{406cd788 alarm.app/.AlarmAppActivity} HistoryRecord的活动销毁超时{406cd788 alarm.app/.AllGoalsActivity} – Munazza