因此,我允许用户选择两个日期开始和结束时间,并连接到通知方法,该方法将检查当前时间是否在他的选择之间。但是,比较似乎无法返回正确的结果。这是BrodcatRecevier
中的方法:
public void CheackAlarmAllow(){
SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm");
FinalTime = Calendar.getInstance();
FinalTime.get(Calendar.HOUR);
FinalTime.get(Calendar.MINUTE);
FinalTime.get(Calendar.SECOND);
FinalTimeS = dateFormat.format (FinalTime.getTime());
DatabaseHelper db = new DatabaseHelper(this);
ProfileHelper response = db.getNotification();
try {
FirstTime = dateFormat.parse (response.StartTimePicker);
SecondTime = dateFormat.parse (response.EndimePicker);
FinalTimeD = dateFormat.parse (FinalTimeS);
}catch (ParseException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
if(FinalTimeD.after(FirstTime)&& FinalTime.before(SecondTime))
{
Log.w("Not Allowed","Working");
}
else
{
Log.w("FirstTime", String.valueOf(FirstTime));
Log.w("Second", String.valueOf(SecondTime));
Log.w("Final", String.valueOf(FinalTimeD));
Log.w(" Allowed","Working");
createNotification();
}
}
,这里的日志返回。
06-03 08:14:10.597 30078-7708/com.ahmad.Project W/FirstTime: Thu Jan 01
03:00:00 MST 1970
06-03 08:14:10.598 30078-7708/com.ahmad. Project W/Second: Thu Jan 01
10:00:00 MST 1970
06-03 08:14:10.598 30078-7708/com.ahmad. Project W/Final: Thu Jan 01
08:14:00 MST 1970
06-03 08:14:10.598 30078-7708/com.ahmad. Project W/ Allowed: Working
如果检查if(FinalTimeD.after(FirstTime)&& FinalTime.before(SecondTime))
失败,因为FirstTime
和SeconfTime
是类型Date
和Calendar.after()
返回true
,仅当传递传递的param是类型Calendar
时来自Calender.after()
的Oracle文档: -
public boolean之后(对象(返回该日历是否返回 表示在指定对象表示的时间之后的一段时间。 该方法等于:
compareTo(when(> 0时,仅当何时是日历实例。否则,该方法返回false。
edit (从下面的注释中复制代码段以完成完整(
Calendar calendar = Calendar.getInstance();
Date newDate = calendar.setTime(date);