Vit*_*uss 11 android chronometer
从特定时间开始计时器我遇到了问题.有一个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() +"]");
Run Code Online (Sandbox Code Playgroud)
输出:
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]
Run Code Online (Sandbox Code Playgroud)
实际上,为什么这个长时间值不同(11624388和1338644123032)?
当我从基座开始我的天文台时
chronometer.setBase(SystemClock.elapsedRealtime());
Run Code Online (Sandbox Code Playgroud)
- 它总是工作正常("00:00"和上升)
但是当我尝试设置过去日期的日期时(昨天):
chronometer.setBase(yesterday.getTime());
Run Code Online (Sandbox Code Playgroud)
- 它显示"00:0("并且每秒更新最新的字符")","*","/"和其他
您能告诉我如何将计时器基座设置为Date对象?
小智 29
我实际上有一个类似的问题(日期来自外部服务,而不是数据库),我想显示日期的年龄.
事实证明这很简单:
long lastSuccess = serviceDate.getTime(); //Some Date object
long elapsedRealtimeOffset = System.currentTimeMillis() - SystemClock.elapsedRealtime();
pollAgeView.setBase(lastSuccess - elapsedRealtimeOffset);
pollAgeView.start();
Run Code Online (Sandbox Code Playgroud)
实际上,为什么这么长的时间值不同(11624388 和 1338644123032)?
SystemClock.elapsedRealtime()是自设备打开以来的毫秒数。其他值基于System.currentTimeMillis()Unix 纪元以来的毫秒数。
您能告诉我如何将计时器底座设置为日期对象吗?
你不知道。那不是目的Chronometer。引用文档Chronometer:
您可以在 elapsedRealtime() 时基中给它一个开始时间,并从此开始计数,或者如果您不给它一个基准时间,它将使用您调用 start() 的时间。
| 归档时间: |
|
| 查看次数: |
7525 次 |
| 最近记录: |