Android: is there any additional information from Intent.ACTION_TIME_CHANGED?

后端 未结 3 957
清酒与你
清酒与你 2021-01-06 04:51

Is there any additional information available from Intent.ACTION_TIME_CHANGED? There\'s nothing in getData() or getExtras().

I would like to know:

  • T

相关标签:
3条回答
  • 2021-01-06 05:34

    You can do one thing if the accuracy of previous time is not that important. You can get the previous time with +/- 1 minute accurate by following way..

    Register for broadcast action ACTION_TIME_TICK (This will be broadcasted every minute).

    When ever the time ticks, if there is a difference of more than 1 minute between your current time and last tick time, you can infer that there occured a time change. After that you just update the new time to shared preference. Thats all.

    1. Register for ACTION_TIME_TICK broadcast.
    2. When broadcast received : 2.1 If first time broadcast, Enter the current system time to Shared Preference. 2.2 else compare the current time with previously entered time and if occurs a difference of more than 1 minute, means the time time has changed. Then update the new system time to SP.

    Happy coding.

    0 讨论(0)
  • 2021-01-06 05:35

    I looked into source code of Android and this broadcast doesn't have any extras. So, there is no way to learn this info.

    0 讨论(0)
  • 2021-01-06 05:38

    I don't think getting the why the time changed is possible, though finding out the amount the time was changed should be possible by comparing System.currentTimeMillis() to the SystemClock.elapsedRealtime(), since SystemClock.elapsedRealtime() does not get adjusted in this case.

    An example would be something like:

    private long realtimeOffset = System.currentTimeMillis() - SystemClock.elapsedRealtime();
    private void onReceive(Context context, Intent intent) {
        if(Intent.ACTION_TIME_CHANGED.equals(intent.getAction()) {
            long prevRealtimeOffset = realtimeOffset;
            realtimeOffset = System.currentTimeMillis() - SystemClock.elapsedRealtime();
            Log.i(TAG, "Clock was adjusted by: " + (realtimeOffset - prevRealtimeOffset) + " ms");
        }
    }
    
    0 讨论(0)
提交回复
热议问题