summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMartin Fietz <Martin.Fietz@gmail.com>2016-08-13 09:56:35 +0200
committerGitHub <noreply@github.com>2016-08-13 09:56:35 +0200
commitda063d5e812777666615cafe98a2edf8fab3059c (patch)
treeeef8d80dc087d8b7916380deee92b680f5ec2555
parenteaa1745fa67b7d8a86f5f26e22fa23e6c33c3073 (diff)
parent9e1a016373a0c602ab1ea22d17c36d54e16b4daf (diff)
downloadAntennaPod-da063d5e812777666615cafe98a2edf8fab3059c.zip
Merge pull request #2095 from mfietz/issue/2070-sleep-time-shake
On shake, reset timer to the current waiting time
-rw-r--r--core/src/main/java/de/danoeh/antennapod/core/service/playback/PlaybackServiceTaskManager.java16
1 files changed, 9 insertions, 7 deletions
diff --git a/core/src/main/java/de/danoeh/antennapod/core/service/playback/PlaybackServiceTaskManager.java b/core/src/main/java/de/danoeh/antennapod/core/service/playback/PlaybackServiceTaskManager.java
index 7fd7602a8..0c7d5e718 100644
--- a/core/src/main/java/de/danoeh/antennapod/core/service/playback/PlaybackServiceTaskManager.java
+++ b/core/src/main/java/de/danoeh/antennapod/core/service/playback/PlaybackServiceTaskManager.java
@@ -299,7 +299,8 @@ public class PlaybackServiceTaskManager {
private static final String TAG = "SleepTimer";
private static final long UPDATE_INTERVAL = 1000L;
private static final long NOTIFICATION_THRESHOLD = 10000;
- private long waitingTime;
+ private final long waitingTime;
+ private long timeLeft;
private final boolean shakeToReset;
private final boolean vibrate;
private ShakeListener shakeListener;
@@ -307,6 +308,7 @@ public class PlaybackServiceTaskManager {
public SleepTimer(long waitingTime, boolean shakeToReset, boolean vibrate) {
super();
this.waitingTime = waitingTime;
+ this.timeLeft = waitingTime;
this.shakeToReset = shakeToReset;
this.vibrate = vibrate;
}
@@ -316,14 +318,14 @@ public class PlaybackServiceTaskManager {
Log.d(TAG, "Starting");
boolean notifiedAlmostExpired = false;
long lastTick = System.currentTimeMillis();
- while (waitingTime > 0) {
+ while (timeLeft > 0) {
try {
Thread.sleep(UPDATE_INTERVAL);
long now = System.currentTimeMillis();
- waitingTime -= now - lastTick;
+ timeLeft -= now - lastTick;
lastTick = now;
- if(waitingTime < NOTIFICATION_THRESHOLD && !notifiedAlmostExpired) {
+ if(timeLeft < NOTIFICATION_THRESHOLD && !notifiedAlmostExpired) {
Log.d(TAG, "Sleep timer is about to expire");
if(vibrate) {
Vibrator v = (Vibrator) context.getSystemService(Context.VIBRATOR_SERVICE);
@@ -337,7 +339,7 @@ public class PlaybackServiceTaskManager {
callback.onSleepTimerAlmostExpired();
notifiedAlmostExpired = true;
}
- if (waitingTime <= 0) {
+ if (timeLeft <= 0) {
Log.d(TAG, "Sleep timer expired");
if(shakeListener != null) {
shakeListener.pause();
@@ -358,11 +360,11 @@ public class PlaybackServiceTaskManager {
}
public long getWaitingTime() {
- return waitingTime;
+ return timeLeft;
}
public void onShake() {
- setSleepTimer(15 * 60 * 1000, shakeToReset, vibrate);
+ setSleepTimer(waitingTime, shakeToReset, vibrate);
callback.onSleepTimerReset();
shakeListener.pause();
shakeListener = null;