11

我从特定时间开始计时表时遇到问题。我希望我的计时器从一个 Date 对象开始:

Date d = new Date(); //now, just for example
chronometer.setBase(d.getTime()); //long value of d
Log.d("Date: " , "d.getTime() time is [" + d.getTime() +"]");
Log.d("Chron: " , "chronometer.getBase() is [" + chronometer.getBase() +"]");
//let's print out elapsedRealtime from official sample
Log.d("Chron: " , "SystemClock.elapsedRealtime() is [" + SystemClock.elapsedRealtime() +"]");

输出:

06-02 13:35:23.025: D/Date:(928): d.getTime() time is [1338644123032]
06-02 13:35:23.037: D/Chron:(928): chronometer.getBase() is [1338644123032]
06-02 13:35:23.037: D/Chron:(928): SystemClock.elapsedRealtime() is [11624388]

实际上,为什么这么长的时间值不同(11624388 和 1338644123032)?

当我从底座启动我的计时器时

chronometer.setBase(SystemClock.elapsedRealtime());

- 它总是工作正常(“00:00”和上升)

但是当我尝试从过去的日期(昨天)设置日期时:

chronometer.setBase(yesterday.getTime());

- 它显示“00:0(”并每秒将最新的字符更改为“)”、“*”、“/”等

您能否建议我如何将计时器底座设置为 Date 对象?

4

2 回答 2

33

我实际上有一个类似的问题(日期来自外部服务,而不是数据库),我想显示日期有多早。

事实证明很简单:

long lastSuccess = serviceDate.getTime(); //Some Date object
long elapsedRealtimeOffset = System.currentTimeMillis() - SystemClock.elapsedRealtime();
pollAgeView.setBase(lastSuccess - elapsedRealtimeOffset);
pollAgeView.start();
于 2013-11-04T18:20:38.190 回答
4

实际上,为什么这么长的时间值不同(11624388 和 1338644123032)?

SystemClock.elapsedRealtime()是自设备开启以来的毫秒数。其他值基于System.currentTimeMillis()Unix 纪元以来的毫秒数。

您能否建议我如何将计时器底座设置为 Date 对象?

你没有。那不是Chronometer目的。引用文档Chronometer

你可以在 elapsedRealtime() 时基中给它一个开始时间,它会从那个开始计数,或者如果你不给它一个基准时间,它将使用你调用 start() 的时间。

于 2012-06-02T14:05:30.197 回答